* hackathon: Refactor Jan into an Electron app * chore: correct NextJS export output path * chore: build electron app for all production targets * fix: correct assetPrefix for production build * chore: preferences shortcut * chore: refactor * chore: refactor into ts * feature/#52-compile-plugin-with-webpack * chore: introduce renderer <=> plugins <=> main invocation * chore: suppress errors - deprecate graphql & next-auth * chore: data plugin functions * add llm support Signed-off-by: James <james@jan.ai> * chore: update plugin * chore: introduce data-plugin * chore: plugin invokes main with args and synchronously * chore: install db plugin should setup db * feature: Data Driver Plugin - Load conversations and messages from data plugin * chore: store text message sent * chore: shared core services * feature: inference service * chore: conversations ordering * adding model management service Signed-off-by: James <james@jan.ai> * chore: strict type * feature: abstract plugin preferences * chore: abstract plugin preference * Revert "chore: strict type" This reverts commit 9be188d827a0b2e081e9e04b192c323799de5bb5. * chore: base-plugin styling * feature: create and delete conversation * chore: fix plugin search & clean messages * chore: typing indicator * chore: refactor useSendChatMessage * chore: persists inserted id to in-memory messages * chore: search conversation history * add delete and download model (#189) Signed-off-by: James <james@jan.ai> Co-authored-by: James <james@jan.ai> * chore: add empty state for conversation list * chore: prompt missing extension function & fix app crashes * chore: prompt user to install required plugins * chore: add launch background * chore: relaunch app on model downloaded * Jan app add installation instruction (#191) Co-authored-by: Hien To <> * Chore: rename folder web-client to app (#192) * Chore: rename folder web-client to app --------- Co-authored-by: Hien To <> * revert: add pre-install package * add progress for downloading model Signed-off-by: James <james@jan.ai> * feature: production bundle * add download progress Signed-off-by: James <james@jan.ai> * chore: add new chat function * fix: electron asar unpack modules & dynamic import * chore: fix unpack * chore: fix dev pack * Add instruction to build dmg file to README.md * init model dynamically Signed-off-by: James <james@jan.ai> --------- Signed-off-by: James <james@jan.ai> Co-authored-by: James <james@jan.ai> Co-authored-by: NamH <NamNh0122@gmail.com> Co-authored-by: hiento09 <136591877+hiento09@users.noreply.github.com> Co-authored-by: Hien To <>
88 lines
2.6 KiB
JavaScript
88 lines
2.6 KiB
JavaScript
import Activation from "./Activation.js"
|
|
|
|
/**
|
|
* This object contains a register of plugin registrations to an activation points, and the means to work with them.
|
|
* @namespace activationPoints
|
|
*/
|
|
|
|
/**
|
|
* @constant {Array.<Activation>} activationRegister
|
|
* @private
|
|
* Store of activations used by the consumer
|
|
*/
|
|
const activationRegister = []
|
|
|
|
/**
|
|
* Register a plugin with its activation points (as defined in its manifest).
|
|
* @param {Plugin} plugin plugin object as provided by the main process.
|
|
* @returns {void}
|
|
* @alias activationPoints.register
|
|
*/
|
|
export function register(plugin) {
|
|
if (!Array.isArray(plugin.activationPoints)) throw new Error(
|
|
`Plugin ${plugin.name || 'without name'} does not have any activation points set up in its manifest.`
|
|
)
|
|
for (const ap of plugin.activationPoints) {
|
|
// Ensure plugin is not already registered to activation point
|
|
const duplicate = activationRegister.findIndex(act =>
|
|
act.plugin === plugin.name && act.activationPoint === ap
|
|
)
|
|
|
|
// Create new activation and add it to the register
|
|
if (duplicate < 0) activationRegister.push(new Activation(plugin.name, ap, plugin.url))
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Trigger all activations registered to the given activation point. See {@link Plugin}.
|
|
* This will call the function with the same name as the activation point on the path specified in the plugin.
|
|
* @param {string} activationPoint Name of the activation to trigger
|
|
* @returns {Promise.<Boolean>} Resolves to true when the activations are complete.
|
|
* @alias activationPoints.trigger
|
|
*/
|
|
export async function trigger(activationPoint) {
|
|
// Make sure all triggers are complete before returning
|
|
await Promise.all(
|
|
// Trigger each relevant activation point from the register and return an array of trigger promises
|
|
activationRegister.reduce((triggered, act) => {
|
|
if (act.activationPoint === activationPoint) {
|
|
triggered.push(act.trigger())
|
|
}
|
|
return triggered
|
|
}, [])
|
|
)
|
|
return true
|
|
}
|
|
|
|
/**
|
|
* Remove a plugin from the activations register.
|
|
* @param {string} plugin Name of the plugin to remove.
|
|
* @returns {void}
|
|
* @alias activationPoints.remove
|
|
*/
|
|
export function remove(plugin) {
|
|
let i = activationRegister.length
|
|
while (i--) {
|
|
if (activationRegister[i].plugin === plugin) {
|
|
activationRegister.splice(i, 1)
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Remove all activations from the activation register.
|
|
* @returns {void}
|
|
* @alias activationPoints.clear
|
|
*/
|
|
export function clear() {
|
|
activationRegister.length = 0
|
|
}
|
|
|
|
/**
|
|
* Fetch all activations.
|
|
* @returns {Array.<Activation>} Found extension points
|
|
* @alias activationPoints.get
|
|
*/
|
|
export function get() {
|
|
return [...activationRegister]
|
|
} |