valyrian.js 8.0.0 → 8.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/flux-store/index.js +10 -1
- package/dist/flux-store/index.js.map +2 -2
- package/dist/flux-store/index.min.js +1 -1
- package/dist/flux-store/index.min.js.map +1 -1
- package/dist/flux-store/index.mjs +10 -1
- package/dist/flux-store/index.mjs.map +2 -2
- package/dist/hooks/index.js +3 -1
- package/dist/hooks/index.js.map +2 -2
- package/dist/hooks/index.min.js +1 -1
- package/dist/hooks/index.min.js.map +1 -1
- package/dist/hooks/index.mjs +3 -1
- package/dist/hooks/index.mjs.map +2 -2
- package/dist/index.js +2 -0
- package/dist/index.js.map +2 -2
- package/dist/index.min.js +1 -1
- package/dist/index.min.js.map +1 -1
- package/dist/index.mjs +2 -0
- package/dist/index.mjs.map +2 -2
- package/dist/{flux-store → lib/flux-store}/index.d.ts +1 -1
- package/dist/lib/flux-store/index.d.ts.map +1 -0
- package/dist/lib/hooks/index.d.ts.map +1 -0
- package/dist/{index.d.ts → lib/index.d.ts} +14 -12
- package/dist/lib/index.d.ts.map +1 -0
- package/dist/lib/native-store/index.d.ts.map +1 -0
- package/dist/{node → lib/node}/index.d.ts +1 -1
- package/dist/lib/node/index.d.ts.map +1 -0
- package/dist/{node → lib/node}/utils/icons.d.ts +4 -5
- package/dist/lib/node/utils/icons.d.ts.map +1 -0
- package/dist/{node → lib/node}/utils/inline.d.ts +1 -1
- package/dist/lib/node/utils/inline.d.ts.map +1 -0
- package/dist/lib/node/utils/session-storage.d.ts.map +1 -0
- package/dist/lib/node/utils/sw.d.ts.map +1 -0
- package/dist/{node → lib/node}/utils/tree-adapter.d.ts +1 -1
- package/dist/lib/node/utils/tree-adapter.d.ts.map +1 -0
- package/dist/{pulse-store → lib/pulse-store}/index.d.ts +5 -2
- package/dist/lib/pulse-store/index.d.ts.map +1 -0
- package/dist/lib/request/index.d.ts +37 -0
- package/dist/lib/request/index.d.ts.map +1 -0
- package/dist/{router → lib/router}/index.d.ts +6 -4
- package/dist/lib/router/index.d.ts.map +1 -0
- package/dist/{signals → lib/signals}/index.d.ts +1 -1
- package/dist/lib/signals/index.d.ts.map +1 -0
- package/dist/{suspense → lib/suspense}/index.d.ts +1 -1
- package/dist/lib/suspense/index.d.ts.map +1 -0
- package/dist/lib/sw/index.d.ts.map +1 -0
- package/dist/lib/translate/index.d.ts.map +1 -0
- package/dist/lib/utils/deep-freeze.d.ts.map +1 -0
- package/dist/lib/utils/getter-setter.d.ts.map +1 -0
- package/dist/lib/utils/has-changed.d.ts.map +1 -0
- package/dist/lib/utils/index.d.ts.map +1 -0
- package/dist/node/index.js +1 -0
- package/dist/node/index.js.map +2 -2
- package/dist/node/index.mjs +1 -0
- package/dist/node/index.mjs.map +2 -2
- package/dist/pulse-store/index.js +1 -1
- package/dist/pulse-store/index.js.map +2 -2
- package/dist/pulse-store/index.min.js +1 -1
- package/dist/pulse-store/index.min.js.map +1 -1
- package/dist/pulse-store/index.mjs +1 -1
- package/dist/pulse-store/index.mjs.map +2 -2
- package/dist/request/index.js.map +2 -2
- package/dist/request/index.min.js.map +1 -1
- package/dist/request/index.mjs.map +2 -2
- package/dist/router/index.js.map +2 -2
- package/dist/router/index.min.js.map +1 -1
- package/dist/router/index.mjs.map +2 -2
- package/dist/signals/index.js.map +1 -1
- package/dist/signals/index.min.js.map +1 -1
- package/dist/signals/index.mjs.map +1 -1
- package/dist/suspense/index.js.map +2 -2
- package/dist/suspense/index.min.js.map +1 -1
- package/dist/suspense/index.mjs.map +2 -2
- package/lib/flux-store/index.ts +12 -1
- package/lib/hooks/index.ts +4 -2
- package/lib/index.ts +17 -10
- package/lib/node/utils/icons.ts +4 -4
- package/lib/node/utils/inline.ts +2 -0
- package/lib/node/utils/tree-adapter.ts +1 -1
- package/lib/pulse-store/index.ts +15 -8
- package/lib/request/index.ts +13 -13
- package/lib/router/index.ts +6 -4
- package/lib/signals/index.ts +1 -1
- package/lib/suspense/index.ts +2 -2
- package/package.json +3 -2
- package/tsconfig.json +5 -4
- package/dist/flux-store/index.d.ts.map +0 -1
- package/dist/hooks/index.d.ts.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/native-store/index.d.ts.map +0 -1
- package/dist/node/index.d.ts.map +0 -1
- package/dist/node/utils/icons.d.ts.map +0 -1
- package/dist/node/utils/inline.d.ts.map +0 -1
- package/dist/node/utils/session-storage.d.ts.map +0 -1
- package/dist/node/utils/sw.d.ts.map +0 -1
- package/dist/node/utils/tree-adapter.d.ts.map +0 -1
- package/dist/pulse-store/index.d.ts.map +0 -1
- package/dist/request/index.d.ts +0 -37
- package/dist/request/index.d.ts.map +0 -1
- package/dist/router/index.d.ts.map +0 -1
- package/dist/signals/index.d.ts.map +0 -1
- package/dist/suspense/index.d.ts.map +0 -1
- package/dist/sw/index.d.ts.map +0 -1
- package/dist/translate/index.d.ts.map +0 -1
- package/dist/utils/deep-freeze.d.ts.map +0 -1
- package/dist/utils/getter-setter.d.ts.map +0 -1
- package/dist/utils/has-changed.d.ts.map +0 -1
- package/dist/utils/index.d.ts.map +0 -1
- /package/dist/{hooks → lib/hooks}/index.d.ts +0 -0
- /package/dist/{native-store → lib/native-store}/index.d.ts +0 -0
- /package/dist/{node → lib/node}/utils/session-storage.d.ts +0 -0
- /package/dist/{node → lib/node}/utils/sw.d.ts +0 -0
- /package/dist/{sw → lib/sw}/index.d.ts +0 -0
- /package/dist/{translate → lib/translate}/index.d.ts +0 -0
- /package/dist/{utils → lib/utils}/deep-freeze.d.ts +0 -0
- /package/dist/{utils → lib/utils}/getter-setter.d.ts +0 -0
- /package/dist/{utils → lib/utils}/has-changed.d.ts +0 -0
- /package/dist/{utils → lib/utils}/index.d.ts +0 -0
package/dist/flux-store/index.js
CHANGED
|
@@ -199,8 +199,17 @@ var FluxStore = class _FluxStore {
|
|
|
199
199
|
this.init.listeners[event].forEach((callback) => callback(this, ...args));
|
|
200
200
|
}
|
|
201
201
|
// This method will add a listener to the store
|
|
202
|
-
on(event, listener) {
|
|
202
|
+
on(event, listener, namespace) {
|
|
203
203
|
this.isFunction("listener", listener);
|
|
204
|
+
if (namespace) {
|
|
205
|
+
const { store, key } = this.getStore(this, namespace);
|
|
206
|
+
this.keyExists("event", store.init.listeners, event);
|
|
207
|
+
if (store.init.listeners[event].indexOf(listener) === -1) {
|
|
208
|
+
store.init.listeners[event].push(listener);
|
|
209
|
+
this.trigger("addlistener", event, listener);
|
|
210
|
+
}
|
|
211
|
+
return () => this.off(event, listener);
|
|
212
|
+
}
|
|
204
213
|
this.keyExists("event", this.init.listeners, event);
|
|
205
214
|
if (this.init.listeners[event].indexOf(listener) === -1) {
|
|
206
215
|
this.init.listeners[event].push(listener);
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../lib/flux-store/index.ts"],
|
|
4
|
-
"sourcesContent": ["import { debouncedUpdate } from \"valyrian.js\";\nimport { deepCloneUnfreeze, deepFreeze } from \"valyrian.js/utils\";\n\ninterface StoreOptions {\n state?: Record<string, any> | (() => Record<string, any>);\n // eslint-disable-next-line no-unused-vars\n mutations?: Record<string, (state: Record<string, any>, ...args: any[]) => void>;\n // eslint-disable-next-line no-unused-vars, no-use-before-define\n actions?: Record<string, (store: FluxStore, ...args: any[]) => any>;\n getters?: Record<\n string,\n // eslint-disable-next-line no-unused-vars\n (state: Record<string, any>, getters: Record<string, any>, globalState?: any, globalGetters?: any) => any\n >;\n modules?: Record<string, StoreOptions>;\n shouldFreeze?: boolean;\n namespace?: string;\n // eslint-disable-next-line no-use-before-define\n rootStore?: FluxStore;\n}\n\n// This is the store entity\nexport class FluxStore {\n public state: Record<string, any>;\n public getters: Record<string, any>;\n private init: {\n frozen: boolean;\n plugins: Function[];\n // eslint-disable-next-line no-use-before-define\n modules: Record<string, FluxStore>;\n childModuleNamespaces: string[];\n listeners: Record<string, Function[]>;\n getters: StoreOptions[\"getters\"];\n mutations: StoreOptions[\"mutations\"];\n actions: StoreOptions[\"actions\"];\n };\n // eslint-disable-next-line no-use-before-define\n public rootStore: FluxStore | null;\n public namespace: string | null;\n\n // eslint-disable-next-line sonarjs/cognitive-complexity\n constructor({\n state = {},\n mutations = {},\n actions = {},\n getters = {},\n modules = {},\n shouldFreeze = true,\n namespace,\n rootStore\n }: StoreOptions = {}) {\n // Initialize the localState for this store\n const localState = typeof state === \"function\" ? state() : state;\n\n // We create a proxy for the state\n this.state = new Proxy(localState || {}, {\n // Every time we try to access a property from the state we try to deep freeze the property\n // to prevent direct modifications to the state\n get: (state, prop: string) => {\n if ((this.rootStore || this).init.modules[prop]) {\n return state[prop];\n }\n if (shouldFreeze) {\n // We are accessing a property from outside the store\n if (this.init.frozen) {\n return deepFreeze(state[prop]);\n }\n\n // We are accessing a property from inside the store\n // So we need to unfreeze the state\n const newState = deepCloneUnfreeze(state);\n for (const key of Reflect.ownKeys(newState)) {\n localState[key] = newState[key];\n }\n }\n return state[prop];\n },\n // If the user tries to set directly it will throw an error, only if we have unfrozen the state via commit\n // this will proceed to set the value\n set: (state, prop: string, value: any) => {\n this.isUnfrozen();\n const old = state[prop];\n state[prop] = value;\n if (this.namespace) {\n prop = `${this.namespace}.${prop}`;\n }\n (this.rootStore || this).trigger(\"set\", prop, value, old);\n return true;\n },\n // If the user tries to delete directly it will throw an error, only if we have unfrozen the state via commit\n // this will proceed to delete the property\n deleteProperty: (state, prop: string) => {\n this.isUnfrozen();\n const old = state[prop];\n Reflect.deleteProperty(state, prop);\n if (this.namespace) {\n prop = `${this.namespace}.${prop}`;\n }\n (this.rootStore || this).trigger(\"delete\", prop, old);\n return true;\n }\n });\n\n // If this is a store been attached to another store\n // this will have the rootStore for future reference\n this.rootStore = rootStore || null;\n\n // If this is a store been attached to another store\n // this will have the namespace attached\n this.namespace = namespace || null;\n\n // We initialize the store with the initial values\n this.init = {\n frozen: true,\n plugins: [],\n modules: {},\n childModuleNamespaces: Object.keys(modules || {}),\n listeners: {\n set: [],\n delete: [],\n beforecommit: [],\n commit: [],\n beforedispatch: [],\n dispatch: [],\n getter: [],\n addlistener: [],\n removelistener: [],\n plugin: [],\n registerModule: [],\n unregisterModule: []\n },\n getters: getters || {},\n mutations: mutations || {},\n actions: actions || {}\n };\n\n // We create a proxy for the getters\n this.getters = new Proxy(getters || {}, {\n // When we try to get a property of the getter we will call the original\n // getter method passing the state as first argument and the other getters as second\n // if we try to get a non existent getter it will fail silently as if\n // we were trying to get an undefined property\n get: (getters, getter: string) => {\n try {\n const { store, key } = this.getStore(this, getter);\n if (store instanceof FluxStore && store.init.getters![key]) {\n const value = store.init.getters;\n if (this.namespace) {\n getter = `${this.namespace}.${getter}`;\n }\n (this.rootStore || this).trigger(\"getter\", getter, value);\n return value;\n }\n } catch (error) {\n return;\n }\n }\n });\n\n // Finally we attach the initial modules\n if (modules) {\n Object.keys(modules).forEach((namespace) => {\n const n = this.namespace ? `${this.namespace}.${namespace}` : namespace;\n (this.rootStore || this).registerModule(n, modules[namespace]);\n });\n }\n }\n\n private keyExists(objectname: string, object: Record<string, any>, key: string) {\n if (!object[key]) {\n throw new Error(`The ${objectname} \"${key}\" does not exists.`);\n }\n }\n\n private isFunction(type: string, callback: Function) {\n if (typeof callback !== \"function\") {\n throw new Error(`You need to provide a valid function as ${type}.`);\n }\n }\n\n // Giving a dot based namespace this method will be used to find the module to be called\n private getStore(store: FluxStore, namespace: string) {\n let key = namespace;\n if (key.indexOf(\".\") > -1) {\n const parts = key.split(\".\");\n key = parts.pop()!;\n const moduleName = parts.join(\".\");\n this.keyExists(\"module\", store.init.modules, moduleName);\n store = store.init.modules[moduleName];\n }\n return {\n store,\n key\n };\n }\n\n private isUnfrozen() {\n if (this.init.frozen) {\n throw new Error(\"You need to commit a mutation to change the state\");\n }\n }\n\n // This method unfroze the state and process a mutation\n public commit(mutation: string, ...args: any[]) {\n const { store, key } = this.getStore(this, mutation);\n this.keyExists(\"mutation\", store.init.mutations!, key);\n store.init.frozen = false;\n this.trigger(\"beforecommit\", mutation, ...args);\n store.init.mutations;\n this.trigger(\"commit\", mutation, ...args);\n store.init.frozen = true;\n\n // We call the debounced update to notify the changes\n debouncedUpdate();\n }\n\n // This method will dispatch an action\n public async dispatch(action: string, ...args: any[]): Promise<any> {\n const { store, key } = this.getStore(this, action);\n this.keyExists(\"action\", store.init.actions!, key);\n this.trigger(\"beforedispatch\", action, ...args);\n try {\n const result = await store.init.actions;\n this.trigger(\"dispatch\", action, ...args);\n return result;\n } finally {\n debouncedUpdate();\n }\n }\n\n // This method will trigger an event\n public trigger(event: string, ...args: any[]) {\n this.init.listeners[event].forEach((callback) => callback(this, ...args));\n }\n\n // This method will add a listener to the store\n public on(event: string, listener: Function) {\n this.isFunction(\"listener\", listener);\n this.keyExists(\"event\", this.init.listeners, event);\n if (this.init.listeners[event].indexOf(listener) === -1) {\n this.init.listeners[event].push(listener);\n this.trigger(\"addlistener\", event, listener);\n }\n return () => this.off(event, listener);\n }\n\n // Remove a listener from the store\n public off(event: string, listener: Function) {\n this.isFunction(\"listener\", listener);\n this.keyExists(\"event\", this.init.listeners, event);\n const index = this.init.listeners[event].indexOf(listener);\n if (index > -1) {\n this.init.listeners[event].splice(index, 1);\n this.trigger(\"removelistener\", event, listener);\n }\n }\n\n // This method will add a plugin to the store\n public use(plugin: Function, ...options: any[]) {\n this.isFunction(\"plugin\", plugin);\n if (this.init.plugins.indexOf(plugin) === -1) {\n plugin(this, ...options);\n this.init.plugins.push(plugin);\n this.trigger(\"plugin\", plugin, ...options);\n }\n }\n\n // This method will register a module to the store\n public registerModule(namespace: string, module: StoreOptions) {\n const rootStore = this;\n if (rootStore.init.modules[namespace]) {\n throw new Error(`A module with the namespace \"${namespace}\" is already registered.`);\n }\n const newStore = new FluxStore({ ...module, rootStore, namespace });\n rootStore.init.frozen = false;\n rootStore.init.modules[namespace] = newStore;\n rootStore.state[namespace] = newStore.state;\n rootStore.init.frozen = true;\n rootStore.trigger(\"registerModule\", namespace, module, newStore);\n\n // We call the debounced update to notify the changes\n debouncedUpdate();\n }\n\n // This method will unregister a module from the store\n public unregisterModule(namespace: string) {\n const rootStore = this;\n const store = rootStore.init.modules[namespace];\n if (store) {\n store.init.childModuleNamespaces.forEach((n) => rootStore.unregisterModule(`${namespace}.${n}`));\n rootStore.init.frozen = false;\n Reflect.deleteProperty(rootStore.init.modules, namespace);\n Reflect.deleteProperty(rootStore.state, namespace);\n rootStore.init.frozen = true;\n rootStore.trigger(\"unregisterModule\", namespace, store);\n\n // We call the debounced update to notify the changes\n debouncedUpdate();\n }\n }\n}\n"],
|
|
5
|
-
"mappings": "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
|
|
4
|
+
"sourcesContent": ["import { debouncedUpdate } from \"valyrian.js\";\nimport { deepCloneUnfreeze, deepFreeze } from \"valyrian.js/utils\";\n\ninterface StoreOptions {\n state?: Record<string, any> | (() => Record<string, any>);\n // eslint-disable-next-line no-unused-vars\n mutations?: Record<string, (state: Record<string, any>, ...args: any[]) => void>;\n // eslint-disable-next-line no-unused-vars, no-use-before-define\n actions?: Record<string, (store: FluxStore, ...args: any[]) => any>;\n getters?: Record<\n string,\n // eslint-disable-next-line no-unused-vars\n (state: Record<string, any>, getters: Record<string, any>, globalState?: any, globalGetters?: any) => any\n >;\n modules?: Record<string, StoreOptions>;\n shouldFreeze?: boolean;\n namespace?: string;\n // eslint-disable-next-line no-use-before-define\n rootStore?: FluxStore;\n}\n\n// This is the store entity\nexport class FluxStore {\n public state: Record<string, any>;\n public getters: Record<string, any>;\n private init: {\n frozen: boolean;\n plugins: Function[];\n // eslint-disable-next-line no-use-before-define\n modules: Record<string, FluxStore>;\n childModuleNamespaces: string[];\n listeners: Record<string, Function[]>;\n getters: StoreOptions[\"getters\"];\n mutations: StoreOptions[\"mutations\"];\n actions: StoreOptions[\"actions\"];\n };\n // eslint-disable-next-line no-use-before-define\n public rootStore: FluxStore | null;\n public namespace: string | null;\n\n // eslint-disable-next-line sonarjs/cognitive-complexity\n constructor({\n state = {},\n mutations = {},\n actions = {},\n getters = {},\n modules = {},\n shouldFreeze = true,\n namespace,\n rootStore\n }: StoreOptions = {}) {\n // Initialize the localState for this store\n const localState = typeof state === \"function\" ? state() : state;\n\n // We create a proxy for the state\n this.state = new Proxy(localState || {}, {\n // Every time we try to access a property from the state we try to deep freeze the property\n // to prevent direct modifications to the state\n get: (state, prop: string) => {\n if ((this.rootStore || this).init.modules[prop]) {\n return state[prop];\n }\n if (shouldFreeze) {\n // We are accessing a property from outside the store\n if (this.init.frozen) {\n return deepFreeze(state[prop]);\n }\n\n // We are accessing a property from inside the store\n // So we need to unfreeze the state\n const newState = deepCloneUnfreeze(state);\n for (const key of Reflect.ownKeys(newState)) {\n localState[key] = newState[key];\n }\n }\n return state[prop];\n },\n // If the user tries to set directly it will throw an error, only if we have unfrozen the state via commit\n // this will proceed to set the value\n set: (state, prop: string, value: any) => {\n this.isUnfrozen();\n const old = state[prop];\n state[prop] = value;\n if (this.namespace) {\n prop = `${this.namespace}.${prop}`;\n }\n (this.rootStore || this).trigger(\"set\", prop, value, old);\n return true;\n },\n // If the user tries to delete directly it will throw an error, only if we have unfrozen the state via commit\n // this will proceed to delete the property\n deleteProperty: (state, prop: string) => {\n this.isUnfrozen();\n const old = state[prop];\n Reflect.deleteProperty(state, prop);\n if (this.namespace) {\n prop = `${this.namespace}.${prop}`;\n }\n (this.rootStore || this).trigger(\"delete\", prop, old);\n return true;\n }\n });\n\n // If this is a store been attached to another store\n // this will have the rootStore for future reference\n this.rootStore = rootStore || null;\n\n // If this is a store been attached to another store\n // this will have the namespace attached\n this.namespace = namespace || null;\n\n // We initialize the store with the initial values\n this.init = {\n frozen: true,\n plugins: [],\n modules: {},\n childModuleNamespaces: Object.keys(modules || {}),\n listeners: {\n set: [],\n delete: [],\n beforecommit: [],\n commit: [],\n beforedispatch: [],\n dispatch: [],\n getter: [],\n addlistener: [],\n removelistener: [],\n plugin: [],\n registerModule: [],\n unregisterModule: []\n },\n getters: getters || {},\n mutations: mutations || {},\n actions: actions || {}\n };\n\n // We create a proxy for the getters\n this.getters = new Proxy(getters || {}, {\n // When we try to get a property of the getter we will call the original\n // getter method passing the state as first argument and the other getters as second\n // if we try to get a non existent getter it will fail silently as if\n // we were trying to get an undefined property\n get: (getters, getter: string) => {\n try {\n const { store, key } = this.getStore(this, getter);\n if (store instanceof FluxStore && store.init.getters![key]) {\n const value = store.init.getters;\n if (this.namespace) {\n getter = `${this.namespace}.${getter}`;\n }\n (this.rootStore || this).trigger(\"getter\", getter, value);\n return value;\n }\n } catch (error) {\n return;\n }\n }\n });\n\n // Finally we attach the initial modules\n if (modules) {\n Object.keys(modules).forEach((namespace) => {\n const n = this.namespace ? `${this.namespace}.${namespace}` : namespace;\n (this.rootStore || this).registerModule(n, modules[namespace]);\n });\n }\n }\n\n private keyExists(objectname: string, object: Record<string, any>, key: string) {\n if (!object[key]) {\n throw new Error(`The ${objectname} \"${key}\" does not exists.`);\n }\n }\n\n private isFunction(type: string, callback: Function) {\n if (typeof callback !== \"function\") {\n throw new Error(`You need to provide a valid function as ${type}.`);\n }\n }\n\n // Giving a dot based namespace this method will be used to find the module to be called\n private getStore(store: FluxStore, namespace: string) {\n let key = namespace;\n if (key.indexOf(\".\") > -1) {\n const parts = key.split(\".\");\n key = parts.pop()!;\n const moduleName = parts.join(\".\");\n this.keyExists(\"module\", store.init.modules, moduleName);\n store = store.init.modules[moduleName];\n }\n return {\n store,\n key\n };\n }\n\n private isUnfrozen() {\n if (this.init.frozen) {\n throw new Error(\"You need to commit a mutation to change the state\");\n }\n }\n\n // This method unfroze the state and process a mutation\n public commit(mutation: string, ...args: any[]) {\n const { store, key } = this.getStore(this, mutation);\n this.keyExists(\"mutation\", store.init.mutations!, key);\n store.init.frozen = false;\n this.trigger(\"beforecommit\", mutation, ...args);\n store.init.mutations;\n this.trigger(\"commit\", mutation, ...args);\n store.init.frozen = true;\n\n // We call the debounced update to notify the changes\n debouncedUpdate();\n }\n\n // This method will dispatch an action\n public async dispatch(action: string, ...args: any[]): Promise<any> {\n const { store, key } = this.getStore(this, action);\n this.keyExists(\"action\", store.init.actions!, key);\n this.trigger(\"beforedispatch\", action, ...args);\n try {\n const result = await store.init.actions;\n this.trigger(\"dispatch\", action, ...args);\n return result;\n } finally {\n debouncedUpdate();\n }\n }\n\n // This method will trigger an event\n public trigger(event: string, ...args: any[]) {\n this.init.listeners[event].forEach((callback) => callback(this, ...args));\n }\n\n // This method will add a listener to the store\n public on(event: string, listener: Function, namespace?: string) {\n this.isFunction(\"listener\", listener);\n\n if (namespace) {\n const { store, key } = this.getStore(this, namespace);\n this.keyExists(\"event\", store.init.listeners, event);\n if (store.init.listeners[event].indexOf(listener) === -1) {\n store.init.listeners[event].push(listener);\n this.trigger(\"addlistener\", event, listener);\n }\n return () => this.off(event, listener);\n }\n\n this.keyExists(\"event\", this.init.listeners, event);\n if (this.init.listeners[event].indexOf(listener) === -1) {\n this.init.listeners[event].push(listener);\n this.trigger(\"addlistener\", event, listener);\n }\n return () => this.off(event, listener);\n }\n\n // Remove a listener from the store\n public off(event: string, listener: Function) {\n this.isFunction(\"listener\", listener);\n this.keyExists(\"event\", this.init.listeners, event);\n const index = this.init.listeners[event].indexOf(listener);\n if (index > -1) {\n this.init.listeners[event].splice(index, 1);\n this.trigger(\"removelistener\", event, listener);\n }\n }\n\n // This method will add a plugin to the store\n public use(plugin: Function, ...options: any[]) {\n this.isFunction(\"plugin\", plugin);\n if (this.init.plugins.indexOf(plugin) === -1) {\n plugin(this, ...options);\n this.init.plugins.push(plugin);\n this.trigger(\"plugin\", plugin, ...options);\n }\n }\n\n // This method will register a module to the store\n public registerModule(namespace: string, module: StoreOptions) {\n const rootStore = this;\n if (rootStore.init.modules[namespace]) {\n throw new Error(`A module with the namespace \"${namespace}\" is already registered.`);\n }\n const newStore = new FluxStore({ ...module, rootStore, namespace });\n rootStore.init.frozen = false;\n rootStore.init.modules[namespace] = newStore;\n rootStore.state[namespace] = newStore.state;\n rootStore.init.frozen = true;\n rootStore.trigger(\"registerModule\", namespace, module, newStore);\n\n // We call the debounced update to notify the changes\n debouncedUpdate();\n }\n\n // This method will unregister a module from the store\n public unregisterModule(namespace: string) {\n const rootStore = this;\n const store = rootStore.init.modules[namespace];\n if (store) {\n store.init.childModuleNamespaces.forEach((n) => rootStore.unregisterModule(`${namespace}.${n}`));\n rootStore.init.frozen = false;\n Reflect.deleteProperty(rootStore.init.modules, namespace);\n Reflect.deleteProperty(rootStore.state, namespace);\n rootStore.init.frozen = true;\n rootStore.trigger(\"unregisterModule\", namespace, store);\n\n // We call the debounced update to notify the changes\n debouncedUpdate();\n }\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["state", "getters", "namespace", "module"]
|
|
7
7
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
(()=>{"use strict";var e=Object.defineProperty,t=Object.getOwnPropertyDescriptor,i=Object.getOwnPropertyNames,s=Object.prototype.hasOwnProperty,r={};((t,i)=>{for(var s in i)e(t,s,{get:i[s],enumerable:!0})})(r,{FluxStore:()=>
|
|
1
|
+
(()=>{"use strict";var e=Object.defineProperty,t=Object.getOwnPropertyDescriptor,i=Object.getOwnPropertyNames,s=Object.prototype.hasOwnProperty,r={};((t,i)=>{for(var s in i)e(t,s,{get:i[s],enumerable:!0})})(r,{FluxStore:()=>c});var n,o=(n=r,((r,n,o,a)=>{if(n&&"object"==typeof n||"function"==typeof n)for(let h of i(n))s.call(r,h)||h===o||e(r,h,{get:()=>n[h],enumerable:!(a=t(n,h))||a.enumerable});return r})(e({},"__esModule",{value:!0}),n)),a=require("valyrian.js"),h=require("valyrian.js/utils"),c=class e{state;getters;init;rootStore;namespace;constructor({state:t={},mutations:i={},actions:s={},getters:r={},modules:n={},shouldFreeze:o=!0,namespace:a,rootStore:c}={}){const l="function"==typeof t?t():t;this.state=new Proxy(l||{},{get:(e,t)=>{if((this.rootStore||this).init.modules[t])return e[t];if(o){if(this.init.frozen)return(0,h.deepFreeze)(e[t]);const i=(0,h.deepCloneUnfreeze)(e);for(const e of Reflect.ownKeys(i))l[e]=i[e]}return e[t]},set:(e,t,i)=>{this.isUnfrozen();const s=e[t];return e[t]=i,this.namespace&&(t=`${this.namespace}.${t}`),(this.rootStore||this).trigger("set",t,i,s),!0},deleteProperty:(e,t)=>{this.isUnfrozen();const i=e[t];return Reflect.deleteProperty(e,t),this.namespace&&(t=`${this.namespace}.${t}`),(this.rootStore||this).trigger("delete",t,i),!0}}),this.rootStore=c||null,this.namespace=a||null,this.init={frozen:!0,plugins:[],modules:{},childModuleNamespaces:Object.keys(n||{}),listeners:{set:[],delete:[],beforecommit:[],commit:[],beforedispatch:[],dispatch:[],getter:[],addlistener:[],removelistener:[],plugin:[],registerModule:[],unregisterModule:[]},getters:r||{},mutations:i||{},actions:s||{}},this.getters=new Proxy(r||{},{get:(t,i)=>{try{const{store:t,key:s}=this.getStore(this,i);if(t instanceof e&&t.init.getters[s]){const e=t.init.getters[s](t.state,t.getters,this.state,this.getters);return this.namespace&&(i=`${this.namespace}.${i}`),(this.rootStore||this).trigger("getter",i,e),e}}catch(e){return}}}),n&&Object.keys(n).forEach(e=>{const t=this.namespace?`${this.namespace}.${e}`:e;(this.rootStore||this).registerModule(t,n[e])})}keyExists(e,t,i){if(!t[i])throw new Error(`The ${e} "${i}" does not exists.`)}isFunction(e,t){if("function"!=typeof t)throw new Error(`You need to provide a valid function as ${e}.`)}getStore(e,t){let i=t;if(i.indexOf(".")>-1){const t=i.split(".");i=t.pop();const s=t.join(".");this.keyExists("module",e.init.modules,s),e=e.init.modules[s]}return{store:e,key:i}}isUnfrozen(){if(this.init.frozen)throw new Error("You need to commit a mutation to change the state")}commit(e,...t){const{store:i,key:s}=this.getStore(this,e);this.keyExists("mutation",i.init.mutations,s),i.init.frozen=!1,this.trigger("beforecommit",e,...t),i.init.mutations[s](i.state,...t),this.trigger("commit",e,...t),i.init.frozen=!0,(0,a.debouncedUpdate)()}async dispatch(e,...t){const{store:i,key:s}=this.getStore(this,e);this.keyExists("action",i.init.actions,s),this.trigger("beforedispatch",e,...t);try{const r=await i.init.actions[s](i,...t);return this.trigger("dispatch",e,...t),r}finally{(0,a.debouncedUpdate)()}}trigger(e,...t){this.init.listeners[e].forEach(e=>e(this,...t))}on(e,t,i){if(this.isFunction("listener",t),i){const{store:s,key:r}=this.getStore(this,i);return this.keyExists("event",s.init.listeners,e),-1===s.init.listeners[e].indexOf(t)&&(s.init.listeners[e].push(t),this.trigger("addlistener",e,t)),()=>this.off(e,t)}return this.keyExists("event",this.init.listeners,e),-1===this.init.listeners[e].indexOf(t)&&(this.init.listeners[e].push(t),this.trigger("addlistener",e,t)),()=>this.off(e,t)}off(e,t){this.isFunction("listener",t),this.keyExists("event",this.init.listeners,e);const i=this.init.listeners[e].indexOf(t);i>-1&&(this.init.listeners[e].splice(i,1),this.trigger("removelistener",e,t))}use(e,...t){this.isFunction("plugin",e),-1===this.init.plugins.indexOf(e)&&(e(this,...t),this.init.plugins.push(e),this.trigger("plugin",e,...t))}registerModule(t,i){const s=this;if(s.init.modules[t])throw new Error(`A module with the namespace "${t}" is already registered.`);const r=new e({...i,rootStore:s,namespace:t});s.init.frozen=!1,s.init.modules[t]=r,s.state[t]=r.state,s.init.frozen=!0,s.trigger("registerModule",t,i,r),(0,a.debouncedUpdate)()}unregisterModule(e){const t=this,i=t.init.modules[e];i&&(i.init.childModuleNamespaces.forEach(i=>t.unregisterModule(`${e}.${i}`)),t.init.frozen=!1,Reflect.deleteProperty(t.init.modules,e),Reflect.deleteProperty(t.state,e),t.init.frozen=!0,t.trigger("unregisterModule",e,i),(0,a.debouncedUpdate)())}};"undefined"!=typeof module?module.exports=o:self.ValyrianFluxStore=o})();//# sourceMappingURL=index.min.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["flux_store_exports","__export","FluxStore","__EXPORTS__","import_valyrian","require","import_utils","_FluxStore","state","getters","init","rootStore","namespace","constructor","mutations","actions","modules","shouldFreeze","localState","this","Proxy","get","prop","frozen","deepFreeze","newState","deepCloneUnfreeze","key","Reflect","ownKeys","set","value","isUnfrozen","old","trigger","deleteProperty","plugins","childModuleNamespaces","Object","keys","listeners","delete","beforecommit","commit","beforedispatch","dispatch","getter","addlistener","removelistener","plugin","registerModule","unregisterModule","store","getStore","error","forEach","n","keyExists","objectname","object","Error","isFunction","type","callback","indexOf","parts","split","pop","moduleName","join","mutation","args","debouncedUpdate","action","result","event","on","listener","push","off","index","splice","use","options","module","newStore"],"sources":["../../lib/flux-store/index.ts"],"sourcesContent":["import { debouncedUpdate } from \"valyrian.js\";\nimport { deepCloneUnfreeze, deepFreeze } from \"valyrian.js/utils\";\n\ninterface StoreOptions {\n  state?: Record<string, any> | (() => Record<string, any>);\n  // eslint-disable-next-line no-unused-vars\n  mutations?: Record<string, (state: Record<string, any>, ...args: any[]) => void>;\n  // eslint-disable-next-line no-unused-vars, no-use-before-define\n  actions?: Record<string, (store: FluxStore, ...args: any[]) => any>;\n  getters?: Record<\n    string,\n    // eslint-disable-next-line no-unused-vars\n    (state: Record<string, any>, getters: Record<string, any>, globalState?: any, globalGetters?: any) => any\n  >;\n  modules?: Record<string, StoreOptions>;\n  shouldFreeze?: boolean;\n  namespace?: string;\n  // eslint-disable-next-line no-use-before-define\n  rootStore?: FluxStore;\n}\n\n// This is the store entity\nexport class FluxStore {\n  public state: Record<string, any>;\n  public getters: Record<string, any>;\n  private init: {\n    frozen: boolean;\n    plugins: Function[];\n    // eslint-disable-next-line no-use-before-define\n    modules: Record<string, FluxStore>;\n    childModuleNamespaces: string[];\n    listeners: Record<string, Function[]>;\n    getters: StoreOptions[\"getters\"];\n    mutations: StoreOptions[\"mutations\"];\n    actions: StoreOptions[\"actions\"];\n  };\n  // eslint-disable-next-line no-use-before-define\n  public rootStore: FluxStore | null;\n  public namespace: string | null;\n\n  // eslint-disable-next-line sonarjs/cognitive-complexity\n  constructor({\n    state = {},\n    mutations = {},\n    actions = {},\n    getters = {},\n    modules = {},\n    shouldFreeze = true,\n    namespace,\n    rootStore\n  }: StoreOptions = {}) {\n    // Initialize the localState for this store\n    const localState = typeof state === \"function\" ? state() : state;\n\n    // We create a proxy for the state\n    this.state = new Proxy(localState || {}, {\n      // Every time we try to access a property from the state we try to deep freeze the property\n      // to prevent direct modifications to the state\n      get: (state, prop: string) => {\n        if ((this.rootStore || this).init.modules[prop]) {\n          return state[prop];\n        }\n        if (shouldFreeze) {\n          // We are accessing a property from outside the store\n          if (this.init.frozen) {\n            return deepFreeze(state[prop]);\n          }\n\n          // We are accessing a property from inside the store\n          // So we need to unfreeze the state\n          const newState = deepCloneUnfreeze(state);\n          for (const key of Reflect.ownKeys(newState)) {\n            localState[key] = newState[key];\n          }\n        }\n        return state[prop];\n      },\n      // If the user tries to set directly it will throw an error, only if we have unfrozen the state via commit\n      // this will proceed to set the value\n      set: (state, prop: string, value: any) => {\n        this.isUnfrozen();\n        const old = state[prop];\n        state[prop] = value;\n        if (this.namespace) {\n          prop = `${this.namespace}.${prop}`;\n        }\n        (this.rootStore || this).trigger(\"set\", prop, value, old);\n        return true;\n      },\n      // If the user tries to delete directly it will throw an error, only if we have unfrozen the state via commit\n      // this will proceed to delete the property\n      deleteProperty: (state, prop: string) => {\n        this.isUnfrozen();\n        const old = state[prop];\n        Reflect.deleteProperty(state, prop);\n        if (this.namespace) {\n          prop = `${this.namespace}.${prop}`;\n        }\n        (this.rootStore || this).trigger(\"delete\", prop, old);\n        return true;\n      }\n    });\n\n    // If this is a store been attached to another store\n    // this will have the rootStore for future reference\n    this.rootStore = rootStore || null;\n\n    // If this is a store been attached to another store\n    // this will have the namespace attached\n    this.namespace = namespace || null;\n\n    // We initialize the store with the initial values\n    this.init = {\n      frozen: true,\n      plugins: [],\n      modules: {},\n      childModuleNamespaces: Object.keys(modules || {}),\n      listeners: {\n        set: [],\n        delete: [],\n        beforecommit: [],\n        commit: [],\n        beforedispatch: [],\n        dispatch: [],\n        getter: [],\n        addlistener: [],\n        removelistener: [],\n        plugin: [],\n        registerModule: [],\n        unregisterModule: []\n      },\n      getters: getters || {},\n      mutations: mutations || {},\n      actions: actions || {}\n    };\n\n    // We create a proxy for the getters\n    this.getters = new Proxy(getters || {}, {\n      // When we try to get a property of the getter we will call the original\n      // getter method passing the state as first argument and the other getters as second\n      // if we try to get a non existent getter it will fail silently as if\n      // we were trying to get an undefined property\n      get: (getters, getter: string) => {\n        try {\n          const { store, key } = this.getStore(this, getter);\n          if (store instanceof FluxStore && store.init.getters![key]) {\n            const value = store.init.getters![key](store.state, store.getters, this.state, this.getters);\n            if (this.namespace) {\n              getter = `${this.namespace}.${getter}`;\n            }\n            (this.rootStore || this).trigger(\"getter\", getter, value);\n            return value;\n          }\n        } catch (error) {\n          return;\n        }\n      }\n    });\n\n    // Finally we attach the initial modules\n    if (modules) {\n      Object.keys(modules).forEach((namespace) => {\n        const n = this.namespace ? `${this.namespace}.${namespace}` : namespace;\n        (this.rootStore || this).registerModule(n, modules[namespace]);\n      });\n    }\n  }\n\n  private keyExists(objectname: string, object: Record<string, any>, key: string) {\n    if (!object[key]) {\n      throw new Error(`The ${objectname} \"${key}\" does not exists.`);\n    }\n  }\n\n  private isFunction(type: string, callback: Function) {\n    if (typeof callback !== \"function\") {\n      throw new Error(`You need to provide a valid function as ${type}.`);\n    }\n  }\n\n  // Giving a dot based namespace this method will be used to find the module to be called\n  private getStore(store: FluxStore, namespace: string) {\n    let key = namespace;\n    if (key.indexOf(\".\") > -1) {\n      const parts = key.split(\".\");\n      key = parts.pop()!;\n      const moduleName = parts.join(\".\");\n      this.keyExists(\"module\", store.init.modules, moduleName);\n      store = store.init.modules[moduleName];\n    }\n    return {\n      store,\n      key\n    };\n  }\n\n  private isUnfrozen() {\n    if (this.init.frozen) {\n      throw new Error(\"You need to commit a mutation to change the state\");\n    }\n  }\n\n  // This method unfroze the state and process a mutation\n  public commit(mutation: string, ...args: any[]) {\n    const { store, key } = this.getStore(this, mutation);\n    this.keyExists(\"mutation\", store.init.mutations!, key);\n    store.init.frozen = false;\n    this.trigger(\"beforecommit\", mutation, ...args);\n    store.init.mutations![key](store.state, ...args);\n    this.trigger(\"commit\", mutation, ...args);\n    store.init.frozen = true;\n\n    // We call the debounced update to notify the changes\n    debouncedUpdate();\n  }\n\n  // This method will dispatch an action\n  public async dispatch(action: string, ...args: any[]): Promise<any> {\n    const { store, key } = this.getStore(this, action);\n    this.keyExists(\"action\", store.init.actions!, key);\n    this.trigger(\"beforedispatch\", action, ...args);\n    try {\n      const result = await store.init.actions![key](store, ...args);\n      this.trigger(\"dispatch\", action, ...args);\n      return result;\n    } finally {\n      debouncedUpdate();\n    }\n  }\n\n  // This method will trigger an event\n  public trigger(event: string, ...args: any[]) {\n    this.init.listeners[event].forEach((callback) => callback(this, ...args));\n  }\n\n  // This method will add a listener to the store\n  public on(event: string, listener: Function) {\n    this.isFunction(\"listener\", listener);\n    this.keyExists(\"event\", this.init.listeners, event);\n    if (this.init.listeners[event].indexOf(listener) === -1) {\n      this.init.listeners[event].push(listener);\n      this.trigger(\"addlistener\", event, listener);\n    }\n    return () => this.off(event, listener);\n  }\n\n  // Remove a listener from the store\n  public off(event: string, listener: Function) {\n    this.isFunction(\"listener\", listener);\n    this.keyExists(\"event\", this.init.listeners, event);\n    const index = this.init.listeners[event].indexOf(listener);\n    if (index > -1) {\n      this.init.listeners[event].splice(index, 1);\n      this.trigger(\"removelistener\", event, listener);\n    }\n  }\n\n  // This method will add a plugin to the store\n  public use(plugin: Function, ...options: any[]) {\n    this.isFunction(\"plugin\", plugin);\n    if (this.init.plugins.indexOf(plugin) === -1) {\n      plugin(this, ...options);\n      this.init.plugins.push(plugin);\n      this.trigger(\"plugin\", plugin, ...options);\n    }\n  }\n\n  // This method will register a module to the store\n  public registerModule(namespace: string, module: StoreOptions) {\n    const rootStore = this;\n    if (rootStore.init.modules[namespace]) {\n      throw new Error(`A module with the namespace \"${namespace}\" is already registered.`);\n    }\n    const newStore = new FluxStore({ ...module, rootStore, namespace });\n    rootStore.init.frozen = false;\n    rootStore.init.modules[namespace] = newStore;\n    rootStore.state[namespace] = newStore.state;\n    rootStore.init.frozen = true;\n    rootStore.trigger(\"registerModule\", namespace, module, newStore);\n\n    // We call the debounced update to notify the changes\n    debouncedUpdate();\n  }\n\n  // This method will unregister a module from the store\n  public unregisterModule(namespace: string) {\n    const rootStore = this;\n    const store = rootStore.init.modules[namespace];\n    if (store) {\n      store.init.childModuleNamespaces.forEach((n) => rootStore.unregisterModule(`${namespace}.${n}`));\n      rootStore.init.frozen = false;\n      Reflect.deleteProperty(rootStore.init.modules, namespace);\n      Reflect.deleteProperty(rootStore.state, namespace);\n      rootStore.init.frozen = true;\n      rootStore.trigger(\"unregisterModule\", namespace, store);\n\n      // We call the debounced update to notify the changes\n      debouncedUpdate();\n    }\n  }\n}\n"],"mappings":"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"}
|
|
1
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["flux_store_exports","__export","FluxStore","__EXPORTS__","import_valyrian","require","import_utils","_FluxStore","state","getters","init","rootStore","namespace","constructor","mutations","actions","modules","shouldFreeze","localState","this","Proxy","get","prop","frozen","deepFreeze","newState","deepCloneUnfreeze","key","Reflect","ownKeys","set","value","isUnfrozen","old","trigger","deleteProperty","plugins","childModuleNamespaces","Object","keys","listeners","delete","beforecommit","commit","beforedispatch","dispatch","getter","addlistener","removelistener","plugin","registerModule","unregisterModule","store","getStore","error","forEach","n","keyExists","objectname","object","Error","isFunction","type","callback","indexOf","parts","split","pop","moduleName","join","mutation","args","debouncedUpdate","action","result","event","on","listener","push","off","index","splice","use","options","module","newStore"],"sources":["../../lib/flux-store/index.ts"],"sourcesContent":["import { debouncedUpdate } from \"valyrian.js\";\nimport { deepCloneUnfreeze, deepFreeze } from \"valyrian.js/utils\";\n\ninterface StoreOptions {\n  state?: Record<string, any> | (() => Record<string, any>);\n  // eslint-disable-next-line no-unused-vars\n  mutations?: Record<string, (state: Record<string, any>, ...args: any[]) => void>;\n  // eslint-disable-next-line no-unused-vars, no-use-before-define\n  actions?: Record<string, (store: FluxStore, ...args: any[]) => any>;\n  getters?: Record<\n    string,\n    // eslint-disable-next-line no-unused-vars\n    (state: Record<string, any>, getters: Record<string, any>, globalState?: any, globalGetters?: any) => any\n  >;\n  modules?: Record<string, StoreOptions>;\n  shouldFreeze?: boolean;\n  namespace?: string;\n  // eslint-disable-next-line no-use-before-define\n  rootStore?: FluxStore;\n}\n\n// This is the store entity\nexport class FluxStore {\n  public state: Record<string, any>;\n  public getters: Record<string, any>;\n  private init: {\n    frozen: boolean;\n    plugins: Function[];\n    // eslint-disable-next-line no-use-before-define\n    modules: Record<string, FluxStore>;\n    childModuleNamespaces: string[];\n    listeners: Record<string, Function[]>;\n    getters: StoreOptions[\"getters\"];\n    mutations: StoreOptions[\"mutations\"];\n    actions: StoreOptions[\"actions\"];\n  };\n  // eslint-disable-next-line no-use-before-define\n  public rootStore: FluxStore | null;\n  public namespace: string | null;\n\n  // eslint-disable-next-line sonarjs/cognitive-complexity\n  constructor({\n    state = {},\n    mutations = {},\n    actions = {},\n    getters = {},\n    modules = {},\n    shouldFreeze = true,\n    namespace,\n    rootStore\n  }: StoreOptions = {}) {\n    // Initialize the localState for this store\n    const localState = typeof state === \"function\" ? state() : state;\n\n    // We create a proxy for the state\n    this.state = new Proxy(localState || {}, {\n      // Every time we try to access a property from the state we try to deep freeze the property\n      // to prevent direct modifications to the state\n      get: (state, prop: string) => {\n        if ((this.rootStore || this).init.modules[prop]) {\n          return state[prop];\n        }\n        if (shouldFreeze) {\n          // We are accessing a property from outside the store\n          if (this.init.frozen) {\n            return deepFreeze(state[prop]);\n          }\n\n          // We are accessing a property from inside the store\n          // So we need to unfreeze the state\n          const newState = deepCloneUnfreeze(state);\n          for (const key of Reflect.ownKeys(newState)) {\n            localState[key] = newState[key];\n          }\n        }\n        return state[prop];\n      },\n      // If the user tries to set directly it will throw an error, only if we have unfrozen the state via commit\n      // this will proceed to set the value\n      set: (state, prop: string, value: any) => {\n        this.isUnfrozen();\n        const old = state[prop];\n        state[prop] = value;\n        if (this.namespace) {\n          prop = `${this.namespace}.${prop}`;\n        }\n        (this.rootStore || this).trigger(\"set\", prop, value, old);\n        return true;\n      },\n      // If the user tries to delete directly it will throw an error, only if we have unfrozen the state via commit\n      // this will proceed to delete the property\n      deleteProperty: (state, prop: string) => {\n        this.isUnfrozen();\n        const old = state[prop];\n        Reflect.deleteProperty(state, prop);\n        if (this.namespace) {\n          prop = `${this.namespace}.${prop}`;\n        }\n        (this.rootStore || this).trigger(\"delete\", prop, old);\n        return true;\n      }\n    });\n\n    // If this is a store been attached to another store\n    // this will have the rootStore for future reference\n    this.rootStore = rootStore || null;\n\n    // If this is a store been attached to another store\n    // this will have the namespace attached\n    this.namespace = namespace || null;\n\n    // We initialize the store with the initial values\n    this.init = {\n      frozen: true,\n      plugins: [],\n      modules: {},\n      childModuleNamespaces: Object.keys(modules || {}),\n      listeners: {\n        set: [],\n        delete: [],\n        beforecommit: [],\n        commit: [],\n        beforedispatch: [],\n        dispatch: [],\n        getter: [],\n        addlistener: [],\n        removelistener: [],\n        plugin: [],\n        registerModule: [],\n        unregisterModule: []\n      },\n      getters: getters || {},\n      mutations: mutations || {},\n      actions: actions || {}\n    };\n\n    // We create a proxy for the getters\n    this.getters = new Proxy(getters || {}, {\n      // When we try to get a property of the getter we will call the original\n      // getter method passing the state as first argument and the other getters as second\n      // if we try to get a non existent getter it will fail silently as if\n      // we were trying to get an undefined property\n      get: (getters, getter: string) => {\n        try {\n          const { store, key } = this.getStore(this, getter);\n          if (store instanceof FluxStore && store.init.getters![key]) {\n            const value = store.init.getters![key](store.state, store.getters, this.state, this.getters);\n            if (this.namespace) {\n              getter = `${this.namespace}.${getter}`;\n            }\n            (this.rootStore || this).trigger(\"getter\", getter, value);\n            return value;\n          }\n        } catch (error) {\n          return;\n        }\n      }\n    });\n\n    // Finally we attach the initial modules\n    if (modules) {\n      Object.keys(modules).forEach((namespace) => {\n        const n = this.namespace ? `${this.namespace}.${namespace}` : namespace;\n        (this.rootStore || this).registerModule(n, modules[namespace]);\n      });\n    }\n  }\n\n  private keyExists(objectname: string, object: Record<string, any>, key: string) {\n    if (!object[key]) {\n      throw new Error(`The ${objectname} \"${key}\" does not exists.`);\n    }\n  }\n\n  private isFunction(type: string, callback: Function) {\n    if (typeof callback !== \"function\") {\n      throw new Error(`You need to provide a valid function as ${type}.`);\n    }\n  }\n\n  // Giving a dot based namespace this method will be used to find the module to be called\n  private getStore(store: FluxStore, namespace: string) {\n    let key = namespace;\n    if (key.indexOf(\".\") > -1) {\n      const parts = key.split(\".\");\n      key = parts.pop()!;\n      const moduleName = parts.join(\".\");\n      this.keyExists(\"module\", store.init.modules, moduleName);\n      store = store.init.modules[moduleName];\n    }\n    return {\n      store,\n      key\n    };\n  }\n\n  private isUnfrozen() {\n    if (this.init.frozen) {\n      throw new Error(\"You need to commit a mutation to change the state\");\n    }\n  }\n\n  // This method unfroze the state and process a mutation\n  public commit(mutation: string, ...args: any[]) {\n    const { store, key } = this.getStore(this, mutation);\n    this.keyExists(\"mutation\", store.init.mutations!, key);\n    store.init.frozen = false;\n    this.trigger(\"beforecommit\", mutation, ...args);\n    store.init.mutations![key](store.state, ...args);\n    this.trigger(\"commit\", mutation, ...args);\n    store.init.frozen = true;\n\n    // We call the debounced update to notify the changes\n    debouncedUpdate();\n  }\n\n  // This method will dispatch an action\n  public async dispatch(action: string, ...args: any[]): Promise<any> {\n    const { store, key } = this.getStore(this, action);\n    this.keyExists(\"action\", store.init.actions!, key);\n    this.trigger(\"beforedispatch\", action, ...args);\n    try {\n      const result = await store.init.actions![key](store, ...args);\n      this.trigger(\"dispatch\", action, ...args);\n      return result;\n    } finally {\n      debouncedUpdate();\n    }\n  }\n\n  // This method will trigger an event\n  public trigger(event: string, ...args: any[]) {\n    this.init.listeners[event].forEach((callback) => callback(this, ...args));\n  }\n\n  // This method will add a listener to the store\n  public on(event: string, listener: Function, namespace?: string) {\n    this.isFunction(\"listener\", listener);\n\n    if (namespace) {\n      const { store, key } = this.getStore(this, namespace);\n      this.keyExists(\"event\", store.init.listeners, event);\n      if (store.init.listeners[event].indexOf(listener) === -1) {\n        store.init.listeners[event].push(listener);\n        this.trigger(\"addlistener\", event, listener);\n      }\n      return () => this.off(event, listener);\n    }\n\n    this.keyExists(\"event\", this.init.listeners, event);\n    if (this.init.listeners[event].indexOf(listener) === -1) {\n      this.init.listeners[event].push(listener);\n      this.trigger(\"addlistener\", event, listener);\n    }\n    return () => this.off(event, listener);\n  }\n\n  // Remove a listener from the store\n  public off(event: string, listener: Function) {\n    this.isFunction(\"listener\", listener);\n    this.keyExists(\"event\", this.init.listeners, event);\n    const index = this.init.listeners[event].indexOf(listener);\n    if (index > -1) {\n      this.init.listeners[event].splice(index, 1);\n      this.trigger(\"removelistener\", event, listener);\n    }\n  }\n\n  // This method will add a plugin to the store\n  public use(plugin: Function, ...options: any[]) {\n    this.isFunction(\"plugin\", plugin);\n    if (this.init.plugins.indexOf(plugin) === -1) {\n      plugin(this, ...options);\n      this.init.plugins.push(plugin);\n      this.trigger(\"plugin\", plugin, ...options);\n    }\n  }\n\n  // This method will register a module to the store\n  public registerModule(namespace: string, module: StoreOptions) {\n    const rootStore = this;\n    if (rootStore.init.modules[namespace]) {\n      throw new Error(`A module with the namespace \"${namespace}\" is already registered.`);\n    }\n    const newStore = new FluxStore({ ...module, rootStore, namespace });\n    rootStore.init.frozen = false;\n    rootStore.init.modules[namespace] = newStore;\n    rootStore.state[namespace] = newStore.state;\n    rootStore.init.frozen = true;\n    rootStore.trigger(\"registerModule\", namespace, module, newStore);\n\n    // We call the debounced update to notify the changes\n    debouncedUpdate();\n  }\n\n  // This method will unregister a module from the store\n  public unregisterModule(namespace: string) {\n    const rootStore = this;\n    const store = rootStore.init.modules[namespace];\n    if (store) {\n      store.init.childModuleNamespaces.forEach((n) => rootStore.unregisterModule(`${namespace}.${n}`));\n      rootStore.init.frozen = false;\n      Reflect.deleteProperty(rootStore.init.modules, namespace);\n      Reflect.deleteProperty(rootStore.state, namespace);\n      rootStore.init.frozen = true;\n      rootStore.trigger(\"unregisterModule\", namespace, store);\n\n      // We call the debounced update to notify the changes\n      debouncedUpdate();\n    }\n  }\n}\n"],"mappings":"gJAAAA,EAAA,G,yDAAAC,CAAAD,EAAA,CAAAE,UAAA,IAAAA,IAAA,I,EAAAC,G,EAAAH,E,0MAAAI,EAAgCC,QAAA,eAChCC,EAA8CD,QAAA,qBAqBjCH,EAAN,MAAMK,EACJC,MACAC,QACCC,KAYDC,UACAC,UAGP,WAAAC,EAAYL,MACVA,EAAQ,CAAC,EAAAM,UACTA,EAAY,CAAC,EAAAC,QACbA,EAAU,CAAC,EAAAN,QACXA,EAAU,CAAC,EAAAO,QACXA,EAAU,CAAC,EAAAC,aACXA,GAAe,EAAAL,UACfA,EAAAD,UACAA,GACgB,CAAC,GAEjB,MAAMO,EAA8B,mBAAVV,EAAuBA,IAAUA,EAG3DW,KAAKX,MAAQ,IAAIY,MAAMF,GAAc,CAAC,EAAG,CAGvCG,IAAK,CAACb,EAAOc,KACX,IAAKH,KAAKR,WAAaQ,MAAMT,KAAKM,QAAQM,GACxC,OAAOd,EAAMc,GAEf,GAAIL,EAAc,CAEhB,GAAIE,KAAKT,KAAKa,OACZ,SAAOjB,EAAAkB,YAAWhB,EAAMc,IAK1B,MAAMG,GAAA,EAAWnB,EAAAoB,mBAAkBlB,GACnC,UAAWmB,KAAOC,QAAQC,QAAQJ,GAChCP,EAAWS,GAAOF,EAASE,EAE/B,CACA,OAAOnB,EAAMc,EAAI,EAInBQ,IAAK,CAACtB,EAAOc,EAAcS,KACzBZ,KAAKa,aACL,MAAMC,EAAMzB,EAAMc,GAMlB,OALAd,EAAMc,GAAQS,EACVZ,KAAKP,YACPU,EAAO,GAAGH,KAAKP,aAAaU,MAE7BH,KAAKR,WAAaQ,MAAMe,QAAQ,MAAOZ,EAAMS,EAAOE,IAC9C,GAITE,eAAgB,CAAC3B,EAAOc,KACtBH,KAAKa,aACL,MAAMC,EAAMzB,EAAMc,GAMlB,OALAM,QAAQO,eAAe3B,EAAOc,GAC1BH,KAAKP,YACPU,EAAO,GAAGH,KAAKP,aAAaU,MAE7BH,KAAKR,WAAaQ,MAAMe,QAAQ,SAAUZ,EAAMW,IAC1C,KAMXd,KAAKR,UAAYA,GAAa,KAI9BQ,KAAKP,UAAYA,GAAa,KAG9BO,KAAKT,KAAO,CACVa,QAAQ,EACRa,QAAS,GACTpB,QAAS,CAAC,EACVqB,sBAAuBC,OAAOC,KAAKvB,GAAW,CAAC,GAC/CwB,UAAW,CACTV,IAAK,GACLW,OAAQ,GACRC,aAAc,GACdC,OAAQ,GACRC,eAAgB,GAChBC,SAAU,GACVC,OAAQ,GACRC,YAAa,GACbC,eAAgB,GAChBC,OAAQ,GACRC,eAAgB,GAChBC,iBAAkB,IAEpB1C,QAASA,GAAW,CAAC,EACrBK,UAAWA,GAAa,CAAC,EACzBC,QAASA,GAAW,CAAC,GAIvBI,KAAKV,QAAU,IAAIW,MAAMX,GAAW,CAAC,EAAG,CAKtCY,IAAK,CAACZ,EAASqC,KACb,IACE,MAAMM,MAAEA,EAAAzB,IAAOA,GAAQR,KAAKkC,SAASlC,KAAM2B,GAC3C,GAAIM,aAAiB7C,GAAa6C,EAAM1C,KAAKD,QAASkB,GAAM,CAC1D,MAAMI,EAAQqB,EAAM1C,KAAKD,QAASkB,GAAKyB,EAAM5C,MAAO4C,EAAM3C,QAASU,KAAKX,MAAOW,KAAKV,SAKpF,OAJIU,KAAKP,YACPkC,EAAS,GAAG3B,KAAKP,aAAakC,MAE/B3B,KAAKR,WAAaQ,MAAMe,QAAQ,SAAUY,EAAQf,GAC5CA,CACT,CACF,OAASuB,GACP,MACF,KAKAtC,GACFsB,OAAOC,KAAKvB,GAASuC,QAAS3C,IAC5B,MAAM4C,EAAIrC,KAAKP,UAAY,GAAGO,KAAKP,aAAaA,IAAcA,GAC7DO,KAAKR,WAAaQ,MAAM+B,eAAeM,EAAGxC,EAAQJ,GAAU,EAGnE,CAEQ,SAAA6C,CAAUC,EAAoBC,EAA6BhC,GACjE,IAAKgC,EAAOhC,GACV,MAAM,IAAIiC,MAAM,OAAOF,MAAe/B,sBAE1C,CAEQ,UAAAkC,CAAWC,EAAcC,GAC/B,GAAwB,mBAAbA,EACT,MAAM,IAAIH,MAAM,2CAA2CE,KAE/D,CAGQ,QAAAT,CAASD,EAAkBxC,GACjC,IAAIe,EAAMf,EACV,GAAIe,EAAIqC,QAAQ,MAAO,EAAI,CACzB,MAAMC,EAAQtC,EAAIuC,MAAM,KACxBvC,EAAMsC,EAAME,MACZ,MAAMC,EAAaH,EAAMI,KAAK,KAC9BlD,KAAKsC,UAAU,SAAUL,EAAM1C,KAAKM,QAASoD,GAC7ChB,EAAQA,EAAM1C,KAAKM,QAAQoD,EAC7B,CACA,MAAO,CACLhB,QACAzB,MAEJ,CAEQ,UAAAK,GACN,GAAIb,KAAKT,KAAKa,OACZ,MAAM,IAAIqC,MAAM,oDAEpB,CAGO,MAAAjB,CAAO2B,KAAqBC,GACjC,MAAMnB,MAAEA,EAAAzB,IAAOA,GAAQR,KAAKkC,SAASlC,KAAMmD,GAC3CnD,KAAKsC,UAAU,WAAYL,EAAM1C,KAAKI,UAAYa,GAClDyB,EAAM1C,KAAKa,QAAS,EACpBJ,KAAKe,QAAQ,eAAgBoC,KAAaC,GAC1CnB,EAAM1C,KAAKI,UAAWa,GAAKyB,EAAM5C,SAAU+D,GAC3CpD,KAAKe,QAAQ,SAAUoC,KAAaC,GACpCnB,EAAM1C,KAAKa,QAAS,GAGpB,EAAAnB,EAAAoE,kBACF,CAGA,cAAa3B,CAAS4B,KAAmBF,GACvC,MAAMnB,MAAEA,EAAAzB,IAAOA,GAAQR,KAAKkC,SAASlC,KAAMsD,GAC3CtD,KAAKsC,UAAU,SAAUL,EAAM1C,KAAKK,QAAUY,GAC9CR,KAAKe,QAAQ,iBAAkBuC,KAAWF,GAC1C,IACE,MAAMG,QAAetB,EAAM1C,KAAKK,QAASY,GAAKyB,KAAUmB,GAExD,OADApD,KAAKe,QAAQ,WAAYuC,KAAWF,GAC7BG,CACT,UACE,EAAAtE,EAAAoE,kBACF,CACF,CAGO,OAAAtC,CAAQyC,KAAkBJ,GAC/BpD,KAAKT,KAAK8B,UAAUmC,GAAOpB,QAASQ,GAAaA,EAAS5C,QAASoD,GACrE,CAGO,EAAAK,CAAGD,EAAeE,EAAoBjE,GAG3C,GAFAO,KAAK0C,WAAW,WAAYgB,GAExBjE,EAAW,CACb,MAAMwC,MAAEA,EAAAzB,IAAOA,GAAQR,KAAKkC,SAASlC,KAAMP,GAM3C,OALAO,KAAKsC,UAAU,QAASL,EAAM1C,KAAK8B,UAAWmC,IACQ,IAAlDvB,EAAM1C,KAAK8B,UAAUmC,GAAOX,QAAQa,KACtCzB,EAAM1C,KAAK8B,UAAUmC,GAAOG,KAAKD,GACjC1D,KAAKe,QAAQ,cAAeyC,EAAOE,IAE9B,IAAM1D,KAAK4D,IAAIJ,EAAOE,EAC/B,CAOA,OALA1D,KAAKsC,UAAU,QAAStC,KAAKT,KAAK8B,UAAWmC,IACQ,IAAjDxD,KAAKT,KAAK8B,UAAUmC,GAAOX,QAAQa,KACrC1D,KAAKT,KAAK8B,UAAUmC,GAAOG,KAAKD,GAChC1D,KAAKe,QAAQ,cAAeyC,EAAOE,IAE9B,IAAM1D,KAAK4D,IAAIJ,EAAOE,EAC/B,CAGO,GAAAE,CAAIJ,EAAeE,GACxB1D,KAAK0C,WAAW,WAAYgB,GAC5B1D,KAAKsC,UAAU,QAAStC,KAAKT,KAAK8B,UAAWmC,GAC7C,MAAMK,EAAQ7D,KAAKT,KAAK8B,UAAUmC,GAAOX,QAAQa,GAC7CG,GAAQ,IACV7D,KAAKT,KAAK8B,UAAUmC,GAAOM,OAAOD,EAAO,GACzC7D,KAAKe,QAAQ,iBAAkByC,EAAOE,GAE1C,CAGO,GAAAK,CAAIjC,KAAqBkC,GAC9BhE,KAAK0C,WAAW,SAAUZ,IACgB,IAAtC9B,KAAKT,KAAK0B,QAAQ4B,QAAQf,KAC5BA,EAAO9B,QAASgE,GAChBhE,KAAKT,KAAK0B,QAAQ0C,KAAK7B,GACvB9B,KAAKe,QAAQ,SAAUe,KAAWkC,GAEtC,CAGO,cAAAjC,CAAetC,EAAmBwE,GACvC,MAAMzE,EAAYQ,KAClB,GAAIR,EAAUD,KAAKM,QAAQJ,GACzB,MAAM,IAAIgD,MAAM,gCAAgChD,6BAElD,MAAMyE,EAAW,IAAI9E,EAAU,IAAK6E,EAAQzE,YAAWC,cACvDD,EAAUD,KAAKa,QAAS,EACxBZ,EAAUD,KAAKM,QAAQJ,GAAayE,EACpC1E,EAAUH,MAAMI,GAAayE,EAAS7E,MACtCG,EAAUD,KAAKa,QAAS,EACxBZ,EAAUuB,QAAQ,iBAAkBtB,EAAWwE,EAAQC,IAGvD,EAAAjF,EAAAoE,kBACF,CAGO,gBAAArB,CAAiBvC,GACtB,MAAMD,EAAYQ,KACZiC,EAAQzC,EAAUD,KAAKM,QAAQJ,GACjCwC,IACFA,EAAM1C,KAAK2B,sBAAsBkB,QAASC,GAAM7C,EAAUwC,iBAAiB,GAAGvC,KAAa4C,MAC3F7C,EAAUD,KAAKa,QAAS,EACxBK,QAAQO,eAAexB,EAAUD,KAAKM,QAASJ,GAC/CgB,QAAQO,eAAexB,EAAUH,MAAOI,GACxCD,EAAUD,KAAKa,QAAS,EACxBZ,EAAUuB,QAAQ,mBAAoBtB,EAAWwC,IAGjD,EAAAhD,EAAAoE,mBAEJ,G"}
|
|
@@ -175,8 +175,17 @@ var FluxStore = class _FluxStore {
|
|
|
175
175
|
this.init.listeners[event].forEach((callback) => callback(this, ...args));
|
|
176
176
|
}
|
|
177
177
|
// This method will add a listener to the store
|
|
178
|
-
on(event, listener) {
|
|
178
|
+
on(event, listener, namespace) {
|
|
179
179
|
this.isFunction("listener", listener);
|
|
180
|
+
if (namespace) {
|
|
181
|
+
const { store, key } = this.getStore(this, namespace);
|
|
182
|
+
this.keyExists("event", store.init.listeners, event);
|
|
183
|
+
if (store.init.listeners[event].indexOf(listener) === -1) {
|
|
184
|
+
store.init.listeners[event].push(listener);
|
|
185
|
+
this.trigger("addlistener", event, listener);
|
|
186
|
+
}
|
|
187
|
+
return () => this.off(event, listener);
|
|
188
|
+
}
|
|
180
189
|
this.keyExists("event", this.init.listeners, event);
|
|
181
190
|
if (this.init.listeners[event].indexOf(listener) === -1) {
|
|
182
191
|
this.init.listeners[event].push(listener);
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../lib/flux-store/index.ts"],
|
|
4
|
-
"sourcesContent": ["import { debouncedUpdate } from \"valyrian.js\";\nimport { deepCloneUnfreeze, deepFreeze } from \"valyrian.js/utils\";\n\ninterface StoreOptions {\n state?: Record<string, any> | (() => Record<string, any>);\n // eslint-disable-next-line no-unused-vars\n mutations?: Record<string, (state: Record<string, any>, ...args: any[]) => void>;\n // eslint-disable-next-line no-unused-vars, no-use-before-define\n actions?: Record<string, (store: FluxStore, ...args: any[]) => any>;\n getters?: Record<\n string,\n // eslint-disable-next-line no-unused-vars\n (state: Record<string, any>, getters: Record<string, any>, globalState?: any, globalGetters?: any) => any\n >;\n modules?: Record<string, StoreOptions>;\n shouldFreeze?: boolean;\n namespace?: string;\n // eslint-disable-next-line no-use-before-define\n rootStore?: FluxStore;\n}\n\n// This is the store entity\nexport class FluxStore {\n public state: Record<string, any>;\n public getters: Record<string, any>;\n private init: {\n frozen: boolean;\n plugins: Function[];\n // eslint-disable-next-line no-use-before-define\n modules: Record<string, FluxStore>;\n childModuleNamespaces: string[];\n listeners: Record<string, Function[]>;\n getters: StoreOptions[\"getters\"];\n mutations: StoreOptions[\"mutations\"];\n actions: StoreOptions[\"actions\"];\n };\n // eslint-disable-next-line no-use-before-define\n public rootStore: FluxStore | null;\n public namespace: string | null;\n\n // eslint-disable-next-line sonarjs/cognitive-complexity\n constructor({\n state = {},\n mutations = {},\n actions = {},\n getters = {},\n modules = {},\n shouldFreeze = true,\n namespace,\n rootStore\n }: StoreOptions = {}) {\n // Initialize the localState for this store\n const localState = typeof state === \"function\" ? state() : state;\n\n // We create a proxy for the state\n this.state = new Proxy(localState || {}, {\n // Every time we try to access a property from the state we try to deep freeze the property\n // to prevent direct modifications to the state\n get: (state, prop: string) => {\n if ((this.rootStore || this).init.modules[prop]) {\n return state[prop];\n }\n if (shouldFreeze) {\n // We are accessing a property from outside the store\n if (this.init.frozen) {\n return deepFreeze(state[prop]);\n }\n\n // We are accessing a property from inside the store\n // So we need to unfreeze the state\n const newState = deepCloneUnfreeze(state);\n for (const key of Reflect.ownKeys(newState)) {\n localState[key] = newState[key];\n }\n }\n return state[prop];\n },\n // If the user tries to set directly it will throw an error, only if we have unfrozen the state via commit\n // this will proceed to set the value\n set: (state, prop: string, value: any) => {\n this.isUnfrozen();\n const old = state[prop];\n state[prop] = value;\n if (this.namespace) {\n prop = `${this.namespace}.${prop}`;\n }\n (this.rootStore || this).trigger(\"set\", prop, value, old);\n return true;\n },\n // If the user tries to delete directly it will throw an error, only if we have unfrozen the state via commit\n // this will proceed to delete the property\n deleteProperty: (state, prop: string) => {\n this.isUnfrozen();\n const old = state[prop];\n Reflect.deleteProperty(state, prop);\n if (this.namespace) {\n prop = `${this.namespace}.${prop}`;\n }\n (this.rootStore || this).trigger(\"delete\", prop, old);\n return true;\n }\n });\n\n // If this is a store been attached to another store\n // this will have the rootStore for future reference\n this.rootStore = rootStore || null;\n\n // If this is a store been attached to another store\n // this will have the namespace attached\n this.namespace = namespace || null;\n\n // We initialize the store with the initial values\n this.init = {\n frozen: true,\n plugins: [],\n modules: {},\n childModuleNamespaces: Object.keys(modules || {}),\n listeners: {\n set: [],\n delete: [],\n beforecommit: [],\n commit: [],\n beforedispatch: [],\n dispatch: [],\n getter: [],\n addlistener: [],\n removelistener: [],\n plugin: [],\n registerModule: [],\n unregisterModule: []\n },\n getters: getters || {},\n mutations: mutations || {},\n actions: actions || {}\n };\n\n // We create a proxy for the getters\n this.getters = new Proxy(getters || {}, {\n // When we try to get a property of the getter we will call the original\n // getter method passing the state as first argument and the other getters as second\n // if we try to get a non existent getter it will fail silently as if\n // we were trying to get an undefined property\n get: (getters, getter: string) => {\n try {\n const { store, key } = this.getStore(this, getter);\n if (store instanceof FluxStore && store.init.getters![key]) {\n const value = store.init.getters;\n if (this.namespace) {\n getter = `${this.namespace}.${getter}`;\n }\n (this.rootStore || this).trigger(\"getter\", getter, value);\n return value;\n }\n } catch (error) {\n return;\n }\n }\n });\n\n // Finally we attach the initial modules\n if (modules) {\n Object.keys(modules).forEach((namespace) => {\n const n = this.namespace ? `${this.namespace}.${namespace}` : namespace;\n (this.rootStore || this).registerModule(n, modules[namespace]);\n });\n }\n }\n\n private keyExists(objectname: string, object: Record<string, any>, key: string) {\n if (!object[key]) {\n throw new Error(`The ${objectname} \"${key}\" does not exists.`);\n }\n }\n\n private isFunction(type: string, callback: Function) {\n if (typeof callback !== \"function\") {\n throw new Error(`You need to provide a valid function as ${type}.`);\n }\n }\n\n // Giving a dot based namespace this method will be used to find the module to be called\n private getStore(store: FluxStore, namespace: string) {\n let key = namespace;\n if (key.indexOf(\".\") > -1) {\n const parts = key.split(\".\");\n key = parts.pop()!;\n const moduleName = parts.join(\".\");\n this.keyExists(\"module\", store.init.modules, moduleName);\n store = store.init.modules[moduleName];\n }\n return {\n store,\n key\n };\n }\n\n private isUnfrozen() {\n if (this.init.frozen) {\n throw new Error(\"You need to commit a mutation to change the state\");\n }\n }\n\n // This method unfroze the state and process a mutation\n public commit(mutation: string, ...args: any[]) {\n const { store, key } = this.getStore(this, mutation);\n this.keyExists(\"mutation\", store.init.mutations!, key);\n store.init.frozen = false;\n this.trigger(\"beforecommit\", mutation, ...args);\n store.init.mutations;\n this.trigger(\"commit\", mutation, ...args);\n store.init.frozen = true;\n\n // We call the debounced update to notify the changes\n debouncedUpdate();\n }\n\n // This method will dispatch an action\n public async dispatch(action: string, ...args: any[]): Promise<any> {\n const { store, key } = this.getStore(this, action);\n this.keyExists(\"action\", store.init.actions!, key);\n this.trigger(\"beforedispatch\", action, ...args);\n try {\n const result = await store.init.actions;\n this.trigger(\"dispatch\", action, ...args);\n return result;\n } finally {\n debouncedUpdate();\n }\n }\n\n // This method will trigger an event\n public trigger(event: string, ...args: any[]) {\n this.init.listeners[event].forEach((callback) => callback(this, ...args));\n }\n\n // This method will add a listener to the store\n public on(event: string, listener: Function) {\n this.isFunction(\"listener\", listener);\n this.keyExists(\"event\", this.init.listeners, event);\n if (this.init.listeners[event].indexOf(listener) === -1) {\n this.init.listeners[event].push(listener);\n this.trigger(\"addlistener\", event, listener);\n }\n return () => this.off(event, listener);\n }\n\n // Remove a listener from the store\n public off(event: string, listener: Function) {\n this.isFunction(\"listener\", listener);\n this.keyExists(\"event\", this.init.listeners, event);\n const index = this.init.listeners[event].indexOf(listener);\n if (index > -1) {\n this.init.listeners[event].splice(index, 1);\n this.trigger(\"removelistener\", event, listener);\n }\n }\n\n // This method will add a plugin to the store\n public use(plugin: Function, ...options: any[]) {\n this.isFunction(\"plugin\", plugin);\n if (this.init.plugins.indexOf(plugin) === -1) {\n plugin(this, ...options);\n this.init.plugins.push(plugin);\n this.trigger(\"plugin\", plugin, ...options);\n }\n }\n\n // This method will register a module to the store\n public registerModule(namespace: string, module: StoreOptions) {\n const rootStore = this;\n if (rootStore.init.modules[namespace]) {\n throw new Error(`A module with the namespace \"${namespace}\" is already registered.`);\n }\n const newStore = new FluxStore({ ...module, rootStore, namespace });\n rootStore.init.frozen = false;\n rootStore.init.modules[namespace] = newStore;\n rootStore.state[namespace] = newStore.state;\n rootStore.init.frozen = true;\n rootStore.trigger(\"registerModule\", namespace, module, newStore);\n\n // We call the debounced update to notify the changes\n debouncedUpdate();\n }\n\n // This method will unregister a module from the store\n public unregisterModule(namespace: string) {\n const rootStore = this;\n const store = rootStore.init.modules[namespace];\n if (store) {\n store.init.childModuleNamespaces.forEach((n) => rootStore.unregisterModule(`${namespace}.${n}`));\n rootStore.init.frozen = false;\n Reflect.deleteProperty(rootStore.init.modules, namespace);\n Reflect.deleteProperty(rootStore.state, namespace);\n rootStore.init.frozen = true;\n rootStore.trigger(\"unregisterModule\", namespace, store);\n\n // We call the debounced update to notify the changes\n debouncedUpdate();\n }\n }\n}\n"],
|
|
5
|
-
"mappings": "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
|
|
4
|
+
"sourcesContent": ["import { debouncedUpdate } from \"valyrian.js\";\nimport { deepCloneUnfreeze, deepFreeze } from \"valyrian.js/utils\";\n\ninterface StoreOptions {\n state?: Record<string, any> | (() => Record<string, any>);\n // eslint-disable-next-line no-unused-vars\n mutations?: Record<string, (state: Record<string, any>, ...args: any[]) => void>;\n // eslint-disable-next-line no-unused-vars, no-use-before-define\n actions?: Record<string, (store: FluxStore, ...args: any[]) => any>;\n getters?: Record<\n string,\n // eslint-disable-next-line no-unused-vars\n (state: Record<string, any>, getters: Record<string, any>, globalState?: any, globalGetters?: any) => any\n >;\n modules?: Record<string, StoreOptions>;\n shouldFreeze?: boolean;\n namespace?: string;\n // eslint-disable-next-line no-use-before-define\n rootStore?: FluxStore;\n}\n\n// This is the store entity\nexport class FluxStore {\n public state: Record<string, any>;\n public getters: Record<string, any>;\n private init: {\n frozen: boolean;\n plugins: Function[];\n // eslint-disable-next-line no-use-before-define\n modules: Record<string, FluxStore>;\n childModuleNamespaces: string[];\n listeners: Record<string, Function[]>;\n getters: StoreOptions[\"getters\"];\n mutations: StoreOptions[\"mutations\"];\n actions: StoreOptions[\"actions\"];\n };\n // eslint-disable-next-line no-use-before-define\n public rootStore: FluxStore | null;\n public namespace: string | null;\n\n // eslint-disable-next-line sonarjs/cognitive-complexity\n constructor({\n state = {},\n mutations = {},\n actions = {},\n getters = {},\n modules = {},\n shouldFreeze = true,\n namespace,\n rootStore\n }: StoreOptions = {}) {\n // Initialize the localState for this store\n const localState = typeof state === \"function\" ? state() : state;\n\n // We create a proxy for the state\n this.state = new Proxy(localState || {}, {\n // Every time we try to access a property from the state we try to deep freeze the property\n // to prevent direct modifications to the state\n get: (state, prop: string) => {\n if ((this.rootStore || this).init.modules[prop]) {\n return state[prop];\n }\n if (shouldFreeze) {\n // We are accessing a property from outside the store\n if (this.init.frozen) {\n return deepFreeze(state[prop]);\n }\n\n // We are accessing a property from inside the store\n // So we need to unfreeze the state\n const newState = deepCloneUnfreeze(state);\n for (const key of Reflect.ownKeys(newState)) {\n localState[key] = newState[key];\n }\n }\n return state[prop];\n },\n // If the user tries to set directly it will throw an error, only if we have unfrozen the state via commit\n // this will proceed to set the value\n set: (state, prop: string, value: any) => {\n this.isUnfrozen();\n const old = state[prop];\n state[prop] = value;\n if (this.namespace) {\n prop = `${this.namespace}.${prop}`;\n }\n (this.rootStore || this).trigger(\"set\", prop, value, old);\n return true;\n },\n // If the user tries to delete directly it will throw an error, only if we have unfrozen the state via commit\n // this will proceed to delete the property\n deleteProperty: (state, prop: string) => {\n this.isUnfrozen();\n const old = state[prop];\n Reflect.deleteProperty(state, prop);\n if (this.namespace) {\n prop = `${this.namespace}.${prop}`;\n }\n (this.rootStore || this).trigger(\"delete\", prop, old);\n return true;\n }\n });\n\n // If this is a store been attached to another store\n // this will have the rootStore for future reference\n this.rootStore = rootStore || null;\n\n // If this is a store been attached to another store\n // this will have the namespace attached\n this.namespace = namespace || null;\n\n // We initialize the store with the initial values\n this.init = {\n frozen: true,\n plugins: [],\n modules: {},\n childModuleNamespaces: Object.keys(modules || {}),\n listeners: {\n set: [],\n delete: [],\n beforecommit: [],\n commit: [],\n beforedispatch: [],\n dispatch: [],\n getter: [],\n addlistener: [],\n removelistener: [],\n plugin: [],\n registerModule: [],\n unregisterModule: []\n },\n getters: getters || {},\n mutations: mutations || {},\n actions: actions || {}\n };\n\n // We create a proxy for the getters\n this.getters = new Proxy(getters || {}, {\n // When we try to get a property of the getter we will call the original\n // getter method passing the state as first argument and the other getters as second\n // if we try to get a non existent getter it will fail silently as if\n // we were trying to get an undefined property\n get: (getters, getter: string) => {\n try {\n const { store, key } = this.getStore(this, getter);\n if (store instanceof FluxStore && store.init.getters![key]) {\n const value = store.init.getters;\n if (this.namespace) {\n getter = `${this.namespace}.${getter}`;\n }\n (this.rootStore || this).trigger(\"getter\", getter, value);\n return value;\n }\n } catch (error) {\n return;\n }\n }\n });\n\n // Finally we attach the initial modules\n if (modules) {\n Object.keys(modules).forEach((namespace) => {\n const n = this.namespace ? `${this.namespace}.${namespace}` : namespace;\n (this.rootStore || this).registerModule(n, modules[namespace]);\n });\n }\n }\n\n private keyExists(objectname: string, object: Record<string, any>, key: string) {\n if (!object[key]) {\n throw new Error(`The ${objectname} \"${key}\" does not exists.`);\n }\n }\n\n private isFunction(type: string, callback: Function) {\n if (typeof callback !== \"function\") {\n throw new Error(`You need to provide a valid function as ${type}.`);\n }\n }\n\n // Giving a dot based namespace this method will be used to find the module to be called\n private getStore(store: FluxStore, namespace: string) {\n let key = namespace;\n if (key.indexOf(\".\") > -1) {\n const parts = key.split(\".\");\n key = parts.pop()!;\n const moduleName = parts.join(\".\");\n this.keyExists(\"module\", store.init.modules, moduleName);\n store = store.init.modules[moduleName];\n }\n return {\n store,\n key\n };\n }\n\n private isUnfrozen() {\n if (this.init.frozen) {\n throw new Error(\"You need to commit a mutation to change the state\");\n }\n }\n\n // This method unfroze the state and process a mutation\n public commit(mutation: string, ...args: any[]) {\n const { store, key } = this.getStore(this, mutation);\n this.keyExists(\"mutation\", store.init.mutations!, key);\n store.init.frozen = false;\n this.trigger(\"beforecommit\", mutation, ...args);\n store.init.mutations;\n this.trigger(\"commit\", mutation, ...args);\n store.init.frozen = true;\n\n // We call the debounced update to notify the changes\n debouncedUpdate();\n }\n\n // This method will dispatch an action\n public async dispatch(action: string, ...args: any[]): Promise<any> {\n const { store, key } = this.getStore(this, action);\n this.keyExists(\"action\", store.init.actions!, key);\n this.trigger(\"beforedispatch\", action, ...args);\n try {\n const result = await store.init.actions;\n this.trigger(\"dispatch\", action, ...args);\n return result;\n } finally {\n debouncedUpdate();\n }\n }\n\n // This method will trigger an event\n public trigger(event: string, ...args: any[]) {\n this.init.listeners[event].forEach((callback) => callback(this, ...args));\n }\n\n // This method will add a listener to the store\n public on(event: string, listener: Function, namespace?: string) {\n this.isFunction(\"listener\", listener);\n\n if (namespace) {\n const { store, key } = this.getStore(this, namespace);\n this.keyExists(\"event\", store.init.listeners, event);\n if (store.init.listeners[event].indexOf(listener) === -1) {\n store.init.listeners[event].push(listener);\n this.trigger(\"addlistener\", event, listener);\n }\n return () => this.off(event, listener);\n }\n\n this.keyExists(\"event\", this.init.listeners, event);\n if (this.init.listeners[event].indexOf(listener) === -1) {\n this.init.listeners[event].push(listener);\n this.trigger(\"addlistener\", event, listener);\n }\n return () => this.off(event, listener);\n }\n\n // Remove a listener from the store\n public off(event: string, listener: Function) {\n this.isFunction(\"listener\", listener);\n this.keyExists(\"event\", this.init.listeners, event);\n const index = this.init.listeners[event].indexOf(listener);\n if (index > -1) {\n this.init.listeners[event].splice(index, 1);\n this.trigger(\"removelistener\", event, listener);\n }\n }\n\n // This method will add a plugin to the store\n public use(plugin: Function, ...options: any[]) {\n this.isFunction(\"plugin\", plugin);\n if (this.init.plugins.indexOf(plugin) === -1) {\n plugin(this, ...options);\n this.init.plugins.push(plugin);\n this.trigger(\"plugin\", plugin, ...options);\n }\n }\n\n // This method will register a module to the store\n public registerModule(namespace: string, module: StoreOptions) {\n const rootStore = this;\n if (rootStore.init.modules[namespace]) {\n throw new Error(`A module with the namespace \"${namespace}\" is already registered.`);\n }\n const newStore = new FluxStore({ ...module, rootStore, namespace });\n rootStore.init.frozen = false;\n rootStore.init.modules[namespace] = newStore;\n rootStore.state[namespace] = newStore.state;\n rootStore.init.frozen = true;\n rootStore.trigger(\"registerModule\", namespace, module, newStore);\n\n // We call the debounced update to notify the changes\n debouncedUpdate();\n }\n\n // This method will unregister a module from the store\n public unregisterModule(namespace: string) {\n const rootStore = this;\n const store = rootStore.init.modules[namespace];\n if (store) {\n store.init.childModuleNamespaces.forEach((n) => rootStore.unregisterModule(`${namespace}.${n}`));\n rootStore.init.frozen = false;\n Reflect.deleteProperty(rootStore.init.modules, namespace);\n Reflect.deleteProperty(rootStore.state, namespace);\n rootStore.init.frozen = true;\n rootStore.trigger(\"unregisterModule\", namespace, store);\n\n // We call the debounced update to notify the changes\n debouncedUpdate();\n }\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["state", "getters", "namespace"]
|
|
7
7
|
}
|
package/dist/hooks/index.js
CHANGED
|
@@ -44,7 +44,9 @@ var createHook = function createHook2({
|
|
|
44
44
|
if (!HookCalls) {
|
|
45
45
|
HookCalls = { hooks: [], hook_calls: -1 };
|
|
46
46
|
componentToHooksWeakMap.set(component, HookCalls);
|
|
47
|
-
(0, import_valyrian.onUnmount)(() =>
|
|
47
|
+
(0, import_valyrian.onUnmount)(() => {
|
|
48
|
+
componentToHooksWeakMap.delete(component);
|
|
49
|
+
});
|
|
48
50
|
}
|
|
49
51
|
(0, import_valyrian.onCleanup)(() => HookCalls.hook_calls = -1);
|
|
50
52
|
let hook = HookCalls.hooks[++HookCalls.hook_calls];
|
package/dist/hooks/index.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../lib/hooks/index.ts"],
|
|
4
|
-
"sourcesContent": ["import { Component, POJOComponent, current, directive, onCleanup, onUnmount, debouncedUpdate } from \"valyrian.js\";\nimport { hasChanged } from \"valyrian.js/utils\";\n\nexport type Hook = any;\n\nexport interface HookDefinition {\n // eslint-disable-next-line no-unused-vars\n onCreate: (...args: any[]) => any;\n // eslint-disable-next-line no-unused-vars\n onUpdate?: (hook: Hook, ...args: any[]) => any;\n // eslint-disable-next-line no-unused-vars\n onCleanup?: (hook: Hook) => any;\n // eslint-disable-next-line no-unused-vars\n onRemove?: (hook: Hook) => any;\n // eslint-disable-next-line no-unused-vars\n returnValue?: (hook: Hook) => any;\n}\n\nexport interface CreateHook {\n // eslint-disable-next-line no-unused-vars\n (HookDefinition: HookDefinition): (...args: any[]) => any;\n}\n\ntype HookCalls = {\n hooks: Hook[];\n hook_calls: number;\n};\n\nconst componentToHooksWeakMap = new WeakMap<Component | POJOComponent, HookCalls>();\n\nexport const createHook = function createHook({\n onCreate,\n onUpdate: onUpdateHook,\n onCleanup: onCleanupHook,\n onRemove,\n returnValue\n}: HookDefinition): Hook {\n return (...args: any[]) => {\n const component = current.component as Component | POJOComponent;\n let HookCalls = componentToHooksWeakMap.get(component);\n\n if (!HookCalls) {\n HookCalls = { hooks: [], hook_calls: -1 };\n componentToHooksWeakMap.set(component, HookCalls);\n onUnmount(() => componentToHooksWeakMap.delete(component));\n }\n\n onCleanup(() => ((HookCalls as HookCalls).hook_calls = -1));\n\n let hook = HookCalls.hooks[++HookCalls.hook_calls];\n if (hook) {\n onUpdateHook?.(hook, ...args);\n } else {\n hook = onCreate(...args);\n HookCalls.hooks.push(hook);\n onRemove && onUnmount(() => onRemove(hook));\n }\n\n onCleanupHook && onCleanup(() => onCleanupHook(hook));\n return returnValue ? returnValue(hook) : hook;\n };\n} as unknown as CreateHook;\n\n// Use state hook\nexport const useState = createHook({\n onCreate: (value) => {\n let state = value;\n function get() {\n return state;\n }\n\n function set(newValue: any) {\n if (current.event && !current.event.defaultPrevented) {\n current.event.preventDefault();\n }\n\n const resolvedValue = typeof newValue === \"function\" ? newValue(state) : newValue;\n\n if (hasChanged(state, resolvedValue)) {\n state = resolvedValue;\n debouncedUpdate();\n }\n }\n\n return [get, set];\n }\n});\n\nexport const useEffect = createHook({\n onCreate: (effect: Function, changes: any[]) => {\n const hook: {\n effect: Function;\n prev: any[];\n onRemove?: Function;\n onCleanup?: Function;\n } = { effect, prev: [] };\n // on unmount\n if (changes === null) {\n hook.onRemove = effect;\n return hook;\n }\n\n // on create\n hook.prev = changes;\n hook.onCleanup = hook.effect();\n return hook;\n },\n onUpdate: (hook, effect, changes) => {\n // on update\n if (typeof changes === \"undefined\") {\n hook.prev = changes;\n if (typeof hook.onCleanup === \"function\") {\n hook.onCleanup();\n }\n hook.onCleanup = hook.effect();\n return;\n }\n\n if (Array.isArray(changes) && changes.length === 0) {\n // Si las dependencias son un array vac\u00EDo, no se debe volver a ejecutar.\n return;\n }\n\n // on update if there are changes\n if (Array.isArray(changes) && hasChanged(hook.prev, changes)) {\n hook.prev = changes;\n if (typeof hook.onCleanup === \"function\") {\n hook.onCleanup();\n }\n hook.onCleanup = hook.effect();\n }\n },\n onRemove: (hook) => {\n if (typeof hook.onCleanup === \"function\") {\n hook.onCleanup();\n }\n if (typeof hook.onRemove === \"function\") {\n hook.onRemove();\n }\n }\n});\n\nexport const useRef = createHook({\n onCreate: (initialValue) => {\n directive(\"ref\", (ref, vnode) => {\n ref.current = vnode.dom;\n });\n return { current: initialValue };\n }\n});\n\nexport const useCallback = createHook({\n onCreate: (callback, changes) => {\n return { callback, changes };\n },\n onUpdate: (hook, callback, changes) => {\n if (hasChanged(hook.changes, changes)) {\n hook.changes = changes;\n hook.callback = callback;\n }\n },\n returnValue: (hook) => hook.callback\n});\n\nexport const useMemo = createHook({\n onCreate: (callback, changes) => {\n return { callback, changes, value: callback() };\n },\n onUpdate: (hook, callback, changes) => {\n if (hasChanged(hook.changes, changes)) {\n hook.changes = changes;\n hook.value = callback();\n }\n },\n returnValue: (hook) => hook.value\n});\n"],
|
|
5
|
-
"mappings": ";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,sBAAoG;AACpG,mBAA2B;AA2B3B,IAAM,0BAA0B,oBAAI,QAA8C;AAE3E,IAAM,aAAa,SAASA,YAAW;AAAA,EAC5C;AAAA,EACA,UAAU;AAAA,EACV,WAAW;AAAA,EACX;AAAA,EACA;AACF,GAAyB;AACvB,SAAO,IAAI,SAAgB;AACzB,UAAM,YAAY,wBAAQ;AAC1B,QAAI,YAAY,wBAAwB,IAAI,SAAS;AAErD,QAAI,CAAC,WAAW;AACd,kBAAY,EAAE,OAAO,CAAC,GAAG,YAAY,GAAG;AACxC,8BAAwB,IAAI,WAAW,SAAS;AAChD,qCAAU,MAAM,
|
|
4
|
+
"sourcesContent": ["import { Component, POJOComponent, current, directive, onCleanup, onUnmount, debouncedUpdate } from \"valyrian.js\";\nimport { hasChanged } from \"valyrian.js/utils\";\n\nexport type Hook = any;\n\nexport interface HookDefinition {\n // eslint-disable-next-line no-unused-vars\n onCreate: (...args: any[]) => any;\n // eslint-disable-next-line no-unused-vars\n onUpdate?: (hook: Hook, ...args: any[]) => any;\n // eslint-disable-next-line no-unused-vars\n onCleanup?: (hook: Hook) => any;\n // eslint-disable-next-line no-unused-vars\n onRemove?: (hook: Hook) => any;\n // eslint-disable-next-line no-unused-vars\n returnValue?: (hook: Hook) => any;\n}\n\nexport interface CreateHook {\n // eslint-disable-next-line no-unused-vars\n (HookDefinition: HookDefinition): (...args: any[]) => any;\n}\n\ntype HookCalls = {\n hooks: Hook[];\n hook_calls: number;\n};\n\nconst componentToHooksWeakMap = new WeakMap<Component | POJOComponent, HookCalls>();\n\nexport const createHook = function createHook({\n onCreate,\n onUpdate: onUpdateHook,\n onCleanup: onCleanupHook,\n onRemove,\n returnValue\n}: HookDefinition): Hook {\n return (...args: any[]) => {\n const component = current.component as Component | POJOComponent;\n let HookCalls = componentToHooksWeakMap.get(component);\n\n if (!HookCalls) {\n HookCalls = { hooks: [], hook_calls: -1 } as HookCalls;\n componentToHooksWeakMap.set(component, HookCalls);\n onUnmount(() => {\n componentToHooksWeakMap.delete(component);\n });\n }\n\n onCleanup(() => ((HookCalls as HookCalls).hook_calls = -1));\n\n let hook = HookCalls.hooks[++HookCalls.hook_calls];\n if (hook) {\n onUpdateHook?.(hook, ...args);\n } else {\n hook = onCreate(...args);\n HookCalls.hooks.push(hook);\n onRemove && onUnmount(() => onRemove(hook));\n }\n\n onCleanupHook && onCleanup(() => onCleanupHook(hook));\n return returnValue ? returnValue(hook) : hook;\n };\n} as unknown as CreateHook;\n\n// Use state hook\nexport const useState = createHook({\n onCreate: (value) => {\n let state = value;\n function get() {\n return state;\n }\n\n function set(newValue: any) {\n if (current.event && !current.event.defaultPrevented) {\n current.event.preventDefault();\n }\n\n const resolvedValue = typeof newValue === \"function\" ? newValue(state) : newValue;\n\n if (hasChanged(state, resolvedValue)) {\n state = resolvedValue;\n debouncedUpdate();\n }\n }\n\n return [get, set];\n }\n});\n\nexport const useEffect = createHook({\n onCreate: (effect: Function, changes: any[]) => {\n const hook: {\n effect: Function;\n prev: any[];\n onRemove?: Function;\n onCleanup?: Function;\n } = { effect, prev: [] };\n // on unmount\n if (changes === null) {\n hook.onRemove = effect;\n return hook;\n }\n\n // on create\n hook.prev = changes;\n hook.onCleanup = hook.effect();\n return hook;\n },\n onUpdate: (hook, effect, changes) => {\n // on update\n if (typeof changes === \"undefined\") {\n hook.prev = changes;\n if (typeof hook.onCleanup === \"function\") {\n hook.onCleanup();\n }\n hook.onCleanup = hook.effect();\n return;\n }\n\n if (Array.isArray(changes) && changes.length === 0) {\n // Si las dependencias son un array vac\u00EDo, no se debe volver a ejecutar.\n return;\n }\n\n // on update if there are changes\n if (Array.isArray(changes) && hasChanged(hook.prev, changes)) {\n hook.prev = changes;\n if (typeof hook.onCleanup === \"function\") {\n hook.onCleanup();\n }\n hook.onCleanup = hook.effect();\n }\n },\n onRemove: (hook) => {\n if (typeof hook.onCleanup === \"function\") {\n hook.onCleanup();\n }\n if (typeof hook.onRemove === \"function\") {\n hook.onRemove();\n }\n }\n});\n\nexport const useRef = createHook({\n onCreate: (initialValue) => {\n directive(\"ref\", (ref, vnode) => {\n ref.current = vnode.dom;\n });\n return { current: initialValue };\n }\n});\n\nexport const useCallback = createHook({\n onCreate: (callback, changes) => {\n return { callback, changes };\n },\n onUpdate: (hook, callback, changes) => {\n if (hasChanged(hook.changes, changes)) {\n hook.changes = changes;\n hook.callback = callback;\n }\n },\n returnValue: (hook) => hook.callback\n});\n\nexport const useMemo = createHook({\n onCreate: (callback, changes) => {\n return { callback, changes, value: callback() };\n },\n onUpdate: (hook, callback, changes) => {\n if (hasChanged(hook.changes, changes)) {\n hook.changes = changes;\n hook.value = callback();\n }\n },\n returnValue: (hook) => hook.value\n});\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["createHook"]
|
|
7
7
|
}
|
package/dist/hooks/index.min.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
(()=>{"use strict";var e=Object.defineProperty,n=Object.getOwnPropertyDescriptor,o=Object.getOwnPropertyNames,t=Object.prototype.hasOwnProperty,r={};((n,o)=>{for(var t in o)e(n,t,{get:o[t],enumerable:!0})})(r,{createHook:()=>s,useCallback:()=>d,useEffect:()=>i,useMemo:()=>h,useRef:()=>v,useState:()=>f});var a,u=(a=r,((r,a,u,l)=>{if(a&&"object"==typeof a||"function"==typeof a)for(let c of o(a))t.call(r,c)||c===u||e(r,c,{get:()=>a[c],enumerable:!(l=n(a,c))||l.enumerable});return r})(e({},"__esModule",{value:!0}),a)),l=require("valyrian.js"),c=require("valyrian.js/utils"),p=new WeakMap,s=function({onCreate:e,onUpdate:n,onCleanup:o,onRemove:t,returnValue:r}){return(...a)=>{const u=l.current.component;let c=p.get(u);c||(c={hooks:[],hook_calls:-1},p.set(u,c),(0,l.onUnmount)(()=>p.delete(u))),(0,l.onCleanup)(()=>c.hook_calls=-1);let s=c.hooks[++c.hook_calls];return s?n?.(s,...a):(s=e(...a),c.hooks.push(s),t&&(0,l.onUnmount)(()=>t(s))),o&&(0,l.onCleanup)(()=>o(s)),r?r(s):s}},f=s({onCreate:e=>{let n=e;return[function(){return n},function(e){l.current.event&&!l.current.event.defaultPrevented&&l.current.event.preventDefault();const o="function"==typeof e?e(n):e;(0,c.hasChanged)(n,o)&&(n=o,(0,l.debouncedUpdate)())}]}}),i=s({onCreate:(e,n)=>{const o={effect:e,prev:[]};return null===n?(o.onRemove=e,o):(o.prev=n,o.onCleanup=o.effect(),o)},onUpdate:(e,n,o)=>{if(void 0===o)return e.prev=o,"function"==typeof e.onCleanup&&e.onCleanup(),void(e.onCleanup=e.effect());Array.isArray(o)&&0===o.length||Array.isArray(o)&&(0,c.hasChanged)(e.prev,o)&&(e.prev=o,"function"==typeof e.onCleanup&&e.onCleanup(),e.onCleanup=e.effect())},onRemove:e=>{"function"==typeof e.onCleanup&&e.onCleanup(),"function"==typeof e.onRemove&&e.onRemove()}}),v=s({onCreate:e=>((0,l.directive)("ref",(e,n)=>{e.current=n.dom}),{current:e})}),d=s({onCreate:(e,n)=>({callback:e,changes:n}),onUpdate:(e,n,o)=>{(0,c.hasChanged)(e.changes,o)&&(e.changes=o,e.callback=n)},returnValue:e=>e.callback}),h=s({onCreate:(e,n)=>({callback:e,changes:n,value:e()}),onUpdate:(e,n,o)=>{(0,c.hasChanged)(e.changes,o)&&(e.changes=o,e.value=n())},returnValue:e=>e.value});"undefined"!=typeof module?module.exports=u:self.ValyrianHooks=u})();//# sourceMappingURL=index.min.js.map
|
|
1
|
+
(()=>{"use strict";var e=Object.defineProperty,n=Object.getOwnPropertyDescriptor,o=Object.getOwnPropertyNames,t=Object.prototype.hasOwnProperty,r={};((n,o)=>{for(var t in o)e(n,t,{get:o[t],enumerable:!0})})(r,{createHook:()=>s,useCallback:()=>d,useEffect:()=>i,useMemo:()=>h,useRef:()=>v,useState:()=>f});var a,u=(a=r,((r,a,u,l)=>{if(a&&"object"==typeof a||"function"==typeof a)for(let c of o(a))t.call(r,c)||c===u||e(r,c,{get:()=>a[c],enumerable:!(l=n(a,c))||l.enumerable});return r})(e({},"__esModule",{value:!0}),a)),l=require("valyrian.js"),c=require("valyrian.js/utils"),p=new WeakMap,s=function({onCreate:e,onUpdate:n,onCleanup:o,onRemove:t,returnValue:r}){return(...a)=>{const u=l.current.component;let c=p.get(u);c||(c={hooks:[],hook_calls:-1},p.set(u,c),(0,l.onUnmount)(()=>{p.delete(u)})),(0,l.onCleanup)(()=>c.hook_calls=-1);let s=c.hooks[++c.hook_calls];return s?n?.(s,...a):(s=e(...a),c.hooks.push(s),t&&(0,l.onUnmount)(()=>t(s))),o&&(0,l.onCleanup)(()=>o(s)),r?r(s):s}},f=s({onCreate:e=>{let n=e;return[function(){return n},function(e){l.current.event&&!l.current.event.defaultPrevented&&l.current.event.preventDefault();const o="function"==typeof e?e(n):e;(0,c.hasChanged)(n,o)&&(n=o,(0,l.debouncedUpdate)())}]}}),i=s({onCreate:(e,n)=>{const o={effect:e,prev:[]};return null===n?(o.onRemove=e,o):(o.prev=n,o.onCleanup=o.effect(),o)},onUpdate:(e,n,o)=>{if(void 0===o)return e.prev=o,"function"==typeof e.onCleanup&&e.onCleanup(),void(e.onCleanup=e.effect());Array.isArray(o)&&0===o.length||Array.isArray(o)&&(0,c.hasChanged)(e.prev,o)&&(e.prev=o,"function"==typeof e.onCleanup&&e.onCleanup(),e.onCleanup=e.effect())},onRemove:e=>{"function"==typeof e.onCleanup&&e.onCleanup(),"function"==typeof e.onRemove&&e.onRemove()}}),v=s({onCreate:e=>((0,l.directive)("ref",(e,n)=>{e.current=n.dom}),{current:e})}),d=s({onCreate:(e,n)=>({callback:e,changes:n}),onUpdate:(e,n,o)=>{(0,c.hasChanged)(e.changes,o)&&(e.changes=o,e.callback=n)},returnValue:e=>e.callback}),h=s({onCreate:(e,n)=>({callback:e,changes:n,value:e()}),onUpdate:(e,n,o)=>{(0,c.hasChanged)(e.changes,o)&&(e.changes=o,e.value=n())},returnValue:e=>e.value});"undefined"!=typeof module?module.exports=u:self.ValyrianHooks=u})();//# sourceMappingURL=index.min.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["hooks_exports","__export","createHook","useCallback","useEffect","useMemo","useRef","useState","__EXPORTS__","import_valyrian","require","import_utils","componentToHooksWeakMap","WeakMap","onCreate","onUpdate","onUpdateHook","onCleanup","onCleanupHook","onRemove","returnValue","args","component","current","HookCalls","get","hooks","hook_calls","set","onUnmount","delete","hook","push","value","state","newValue","event","defaultPrevented","preventDefault","resolvedValue","hasChanged","debouncedUpdate","effect","changes","prev","Array","isArray","length","initialValue","directive","ref","vnode","dom","callback"],"sources":["../../lib/hooks/index.ts"],"sourcesContent":["import { Component, POJOComponent, current, directive, onCleanup, onUnmount, debouncedUpdate } from \"valyrian.js\";\nimport { hasChanged } from \"valyrian.js/utils\";\n\nexport type Hook = any;\n\nexport interface HookDefinition {\n  // eslint-disable-next-line no-unused-vars\n  onCreate: (...args: any[]) => any;\n  // eslint-disable-next-line no-unused-vars\n  onUpdate?: (hook: Hook, ...args: any[]) => any;\n  // eslint-disable-next-line no-unused-vars\n  onCleanup?: (hook: Hook) => any;\n  // eslint-disable-next-line no-unused-vars\n  onRemove?: (hook: Hook) => any;\n  // eslint-disable-next-line no-unused-vars\n  returnValue?: (hook: Hook) => any;\n}\n\nexport interface CreateHook {\n  // eslint-disable-next-line no-unused-vars\n  (HookDefinition: HookDefinition): (...args: any[]) => any;\n}\n\ntype HookCalls = {\n  hooks: Hook[];\n  hook_calls: number;\n};\n\nconst componentToHooksWeakMap = new WeakMap<Component | POJOComponent, HookCalls>();\n\nexport const createHook = function createHook({\n  onCreate,\n  onUpdate: onUpdateHook,\n  onCleanup: onCleanupHook,\n  onRemove,\n  returnValue\n}: HookDefinition): Hook {\n  return (...args: any[]) => {\n    const component = current.component as Component | POJOComponent;\n    let HookCalls = componentToHooksWeakMap.get(component);\n\n    if (!HookCalls) {\n      HookCalls = { hooks: [], hook_calls: -1 };\n      componentToHooksWeakMap.set(component, HookCalls);\n      onUnmount(() => componentToHooksWeakMap.delete(component));\n    }\n\n    onCleanup(() => ((HookCalls as HookCalls).hook_calls = -1));\n\n    let hook = HookCalls.hooks[++HookCalls.hook_calls];\n    if (hook) {\n      onUpdateHook?.(hook, ...args);\n    } else {\n      hook = onCreate(...args);\n      HookCalls.hooks.push(hook);\n      onRemove && onUnmount(() => onRemove(hook));\n    }\n\n    onCleanupHook && onCleanup(() => onCleanupHook(hook));\n    return returnValue ? returnValue(hook) : hook;\n  };\n} as unknown as CreateHook;\n\n// Use state hook\nexport const useState = createHook({\n  onCreate: (value) => {\n    let state = value;\n    function get() {\n      return state;\n    }\n\n    function set(newValue: any) {\n      if (current.event && !current.event.defaultPrevented) {\n        current.event.preventDefault();\n      }\n\n      const resolvedValue = typeof newValue === \"function\" ? newValue(state) : newValue;\n\n      if (hasChanged(state, resolvedValue)) {\n        state = resolvedValue;\n        debouncedUpdate();\n      }\n    }\n\n    return [get, set];\n  }\n});\n\nexport const useEffect = createHook({\n  onCreate: (effect: Function, changes: any[]) => {\n    const hook: {\n      effect: Function;\n      prev: any[];\n      onRemove?: Function;\n      onCleanup?: Function;\n    } = { effect, prev: [] };\n    // on unmount\n    if (changes === null) {\n      hook.onRemove = effect;\n      return hook;\n    }\n\n    // on create\n    hook.prev = changes;\n    hook.onCleanup = hook.effect();\n    return hook;\n  },\n  onUpdate: (hook, effect, changes) => {\n    // on update\n    if (typeof changes === \"undefined\") {\n      hook.prev = changes;\n      if (typeof hook.onCleanup === \"function\") {\n        hook.onCleanup();\n      }\n      hook.onCleanup = hook.effect();\n      return;\n    }\n\n    if (Array.isArray(changes) && changes.length === 0) {\n      // Si las dependencias son un array vacío, no se debe volver a ejecutar.\n      return;\n    }\n\n    // on update if there are changes\n    if (Array.isArray(changes) && hasChanged(hook.prev, changes)) {\n      hook.prev = changes;\n      if (typeof hook.onCleanup === \"function\") {\n        hook.onCleanup();\n      }\n      hook.onCleanup = hook.effect();\n    }\n  },\n  onRemove: (hook) => {\n    if (typeof hook.onCleanup === \"function\") {\n      hook.onCleanup();\n    }\n    if (typeof hook.onRemove === \"function\") {\n      hook.onRemove();\n    }\n  }\n});\n\nexport const useRef = createHook({\n  onCreate: (initialValue) => {\n    directive(\"ref\", (ref, vnode) => {\n      ref.current = vnode.dom;\n    });\n    return { current: initialValue };\n  }\n});\n\nexport const useCallback = createHook({\n  onCreate: (callback, changes) => {\n    return { callback, changes };\n  },\n  onUpdate: (hook, callback, changes) => {\n    if (hasChanged(hook.changes, changes)) {\n      hook.changes = changes;\n      hook.callback = callback;\n    }\n  },\n  returnValue: (hook) => hook.callback\n});\n\nexport const useMemo = createHook({\n  onCreate: (callback, changes) => {\n    return { callback, changes, value: callback() };\n  },\n  onUpdate: (hook, callback, changes) => {\n    if (hasChanged(hook.changes, changes)) {\n      hook.changes = changes;\n      hook.value = callback();\n    }\n  },\n  returnValue: (hook) => hook.value\n});\n"],"mappings":"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"}
|
|
1
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["hooks_exports","__export","createHook","useCallback","useEffect","useMemo","useRef","useState","__EXPORTS__","import_valyrian","require","import_utils","componentToHooksWeakMap","WeakMap","onCreate","onUpdate","onUpdateHook","onCleanup","onCleanupHook","onRemove","returnValue","args","component","current","HookCalls","get","hooks","hook_calls","set","onUnmount","delete","hook","push","value","state","newValue","event","defaultPrevented","preventDefault","resolvedValue","hasChanged","debouncedUpdate","effect","changes","prev","Array","isArray","length","initialValue","directive","ref","vnode","dom","callback"],"sources":["../../lib/hooks/index.ts"],"sourcesContent":["import { Component, POJOComponent, current, directive, onCleanup, onUnmount, debouncedUpdate } from \"valyrian.js\";\nimport { hasChanged } from \"valyrian.js/utils\";\n\nexport type Hook = any;\n\nexport interface HookDefinition {\n  // eslint-disable-next-line no-unused-vars\n  onCreate: (...args: any[]) => any;\n  // eslint-disable-next-line no-unused-vars\n  onUpdate?: (hook: Hook, ...args: any[]) => any;\n  // eslint-disable-next-line no-unused-vars\n  onCleanup?: (hook: Hook) => any;\n  // eslint-disable-next-line no-unused-vars\n  onRemove?: (hook: Hook) => any;\n  // eslint-disable-next-line no-unused-vars\n  returnValue?: (hook: Hook) => any;\n}\n\nexport interface CreateHook {\n  // eslint-disable-next-line no-unused-vars\n  (HookDefinition: HookDefinition): (...args: any[]) => any;\n}\n\ntype HookCalls = {\n  hooks: Hook[];\n  hook_calls: number;\n};\n\nconst componentToHooksWeakMap = new WeakMap<Component | POJOComponent, HookCalls>();\n\nexport const createHook = function createHook({\n  onCreate,\n  onUpdate: onUpdateHook,\n  onCleanup: onCleanupHook,\n  onRemove,\n  returnValue\n}: HookDefinition): Hook {\n  return (...args: any[]) => {\n    const component = current.component as Component | POJOComponent;\n    let HookCalls = componentToHooksWeakMap.get(component);\n\n    if (!HookCalls) {\n      HookCalls = { hooks: [], hook_calls: -1 } as HookCalls;\n      componentToHooksWeakMap.set(component, HookCalls);\n      onUnmount(() => {\n        componentToHooksWeakMap.delete(component);\n      });\n    }\n\n    onCleanup(() => ((HookCalls as HookCalls).hook_calls = -1));\n\n    let hook = HookCalls.hooks[++HookCalls.hook_calls];\n    if (hook) {\n      onUpdateHook?.(hook, ...args);\n    } else {\n      hook = onCreate(...args);\n      HookCalls.hooks.push(hook);\n      onRemove && onUnmount(() => onRemove(hook));\n    }\n\n    onCleanupHook && onCleanup(() => onCleanupHook(hook));\n    return returnValue ? returnValue(hook) : hook;\n  };\n} as unknown as CreateHook;\n\n// Use state hook\nexport const useState = createHook({\n  onCreate: (value) => {\n    let state = value;\n    function get() {\n      return state;\n    }\n\n    function set(newValue: any) {\n      if (current.event && !current.event.defaultPrevented) {\n        current.event.preventDefault();\n      }\n\n      const resolvedValue = typeof newValue === \"function\" ? newValue(state) : newValue;\n\n      if (hasChanged(state, resolvedValue)) {\n        state = resolvedValue;\n        debouncedUpdate();\n      }\n    }\n\n    return [get, set];\n  }\n});\n\nexport const useEffect = createHook({\n  onCreate: (effect: Function, changes: any[]) => {\n    const hook: {\n      effect: Function;\n      prev: any[];\n      onRemove?: Function;\n      onCleanup?: Function;\n    } = { effect, prev: [] };\n    // on unmount\n    if (changes === null) {\n      hook.onRemove = effect;\n      return hook;\n    }\n\n    // on create\n    hook.prev = changes;\n    hook.onCleanup = hook.effect();\n    return hook;\n  },\n  onUpdate: (hook, effect, changes) => {\n    // on update\n    if (typeof changes === \"undefined\") {\n      hook.prev = changes;\n      if (typeof hook.onCleanup === \"function\") {\n        hook.onCleanup();\n      }\n      hook.onCleanup = hook.effect();\n      return;\n    }\n\n    if (Array.isArray(changes) && changes.length === 0) {\n      // Si las dependencias son un array vacío, no se debe volver a ejecutar.\n      return;\n    }\n\n    // on update if there are changes\n    if (Array.isArray(changes) && hasChanged(hook.prev, changes)) {\n      hook.prev = changes;\n      if (typeof hook.onCleanup === \"function\") {\n        hook.onCleanup();\n      }\n      hook.onCleanup = hook.effect();\n    }\n  },\n  onRemove: (hook) => {\n    if (typeof hook.onCleanup === \"function\") {\n      hook.onCleanup();\n    }\n    if (typeof hook.onRemove === \"function\") {\n      hook.onRemove();\n    }\n  }\n});\n\nexport const useRef = createHook({\n  onCreate: (initialValue) => {\n    directive(\"ref\", (ref, vnode) => {\n      ref.current = vnode.dom;\n    });\n    return { current: initialValue };\n  }\n});\n\nexport const useCallback = createHook({\n  onCreate: (callback, changes) => {\n    return { callback, changes };\n  },\n  onUpdate: (hook, callback, changes) => {\n    if (hasChanged(hook.changes, changes)) {\n      hook.changes = changes;\n      hook.callback = callback;\n    }\n  },\n  returnValue: (hook) => hook.callback\n});\n\nexport const useMemo = createHook({\n  onCreate: (callback, changes) => {\n    return { callback, changes, value: callback() };\n  },\n  onUpdate: (hook, callback, changes) => {\n    if (hasChanged(hook.changes, changes)) {\n      hook.changes = changes;\n      hook.value = callback();\n    }\n  },\n  returnValue: (hook) => hook.value\n});\n"],"mappings":"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"}
|
package/dist/hooks/index.mjs
CHANGED
|
@@ -15,7 +15,9 @@ var createHook = function createHook2({
|
|
|
15
15
|
if (!HookCalls) {
|
|
16
16
|
HookCalls = { hooks: [], hook_calls: -1 };
|
|
17
17
|
componentToHooksWeakMap.set(component, HookCalls);
|
|
18
|
-
onUnmount(() =>
|
|
18
|
+
onUnmount(() => {
|
|
19
|
+
componentToHooksWeakMap.delete(component);
|
|
20
|
+
});
|
|
19
21
|
}
|
|
20
22
|
onCleanup(() => HookCalls.hook_calls = -1);
|
|
21
23
|
let hook = HookCalls.hooks[++HookCalls.hook_calls];
|
package/dist/hooks/index.mjs.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../lib/hooks/index.ts"],
|
|
4
|
-
"sourcesContent": ["import { Component, POJOComponent, current, directive, onCleanup, onUnmount, debouncedUpdate } from \"valyrian.js\";\nimport { hasChanged } from \"valyrian.js/utils\";\n\nexport type Hook = any;\n\nexport interface HookDefinition {\n // eslint-disable-next-line no-unused-vars\n onCreate: (...args: any[]) => any;\n // eslint-disable-next-line no-unused-vars\n onUpdate?: (hook: Hook, ...args: any[]) => any;\n // eslint-disable-next-line no-unused-vars\n onCleanup?: (hook: Hook) => any;\n // eslint-disable-next-line no-unused-vars\n onRemove?: (hook: Hook) => any;\n // eslint-disable-next-line no-unused-vars\n returnValue?: (hook: Hook) => any;\n}\n\nexport interface CreateHook {\n // eslint-disable-next-line no-unused-vars\n (HookDefinition: HookDefinition): (...args: any[]) => any;\n}\n\ntype HookCalls = {\n hooks: Hook[];\n hook_calls: number;\n};\n\nconst componentToHooksWeakMap = new WeakMap<Component | POJOComponent, HookCalls>();\n\nexport const createHook = function createHook({\n onCreate,\n onUpdate: onUpdateHook,\n onCleanup: onCleanupHook,\n onRemove,\n returnValue\n}: HookDefinition): Hook {\n return (...args: any[]) => {\n const component = current.component as Component | POJOComponent;\n let HookCalls = componentToHooksWeakMap.get(component);\n\n if (!HookCalls) {\n HookCalls = { hooks: [], hook_calls: -1 };\n componentToHooksWeakMap.set(component, HookCalls);\n onUnmount(() => componentToHooksWeakMap.delete(component));\n }\n\n onCleanup(() => ((HookCalls as HookCalls).hook_calls = -1));\n\n let hook = HookCalls.hooks[++HookCalls.hook_calls];\n if (hook) {\n onUpdateHook?.(hook, ...args);\n } else {\n hook = onCreate(...args);\n HookCalls.hooks.push(hook);\n onRemove && onUnmount(() => onRemove(hook));\n }\n\n onCleanupHook && onCleanup(() => onCleanupHook(hook));\n return returnValue ? returnValue(hook) : hook;\n };\n} as unknown as CreateHook;\n\n// Use state hook\nexport const useState = createHook({\n onCreate: (value) => {\n let state = value;\n function get() {\n return state;\n }\n\n function set(newValue: any) {\n if (current.event && !current.event.defaultPrevented) {\n current.event.preventDefault();\n }\n\n const resolvedValue = typeof newValue === \"function\" ? newValue(state) : newValue;\n\n if (hasChanged(state, resolvedValue)) {\n state = resolvedValue;\n debouncedUpdate();\n }\n }\n\n return [get, set];\n }\n});\n\nexport const useEffect = createHook({\n onCreate: (effect: Function, changes: any[]) => {\n const hook: {\n effect: Function;\n prev: any[];\n onRemove?: Function;\n onCleanup?: Function;\n } = { effect, prev: [] };\n // on unmount\n if (changes === null) {\n hook.onRemove = effect;\n return hook;\n }\n\n // on create\n hook.prev = changes;\n hook.onCleanup = hook.effect();\n return hook;\n },\n onUpdate: (hook, effect, changes) => {\n // on update\n if (typeof changes === \"undefined\") {\n hook.prev = changes;\n if (typeof hook.onCleanup === \"function\") {\n hook.onCleanup();\n }\n hook.onCleanup = hook.effect();\n return;\n }\n\n if (Array.isArray(changes) && changes.length === 0) {\n // Si las dependencias son un array vac\u00EDo, no se debe volver a ejecutar.\n return;\n }\n\n // on update if there are changes\n if (Array.isArray(changes) && hasChanged(hook.prev, changes)) {\n hook.prev = changes;\n if (typeof hook.onCleanup === \"function\") {\n hook.onCleanup();\n }\n hook.onCleanup = hook.effect();\n }\n },\n onRemove: (hook) => {\n if (typeof hook.onCleanup === \"function\") {\n hook.onCleanup();\n }\n if (typeof hook.onRemove === \"function\") {\n hook.onRemove();\n }\n }\n});\n\nexport const useRef = createHook({\n onCreate: (initialValue) => {\n directive(\"ref\", (ref, vnode) => {\n ref.current = vnode.dom;\n });\n return { current: initialValue };\n }\n});\n\nexport const useCallback = createHook({\n onCreate: (callback, changes) => {\n return { callback, changes };\n },\n onUpdate: (hook, callback, changes) => {\n if (hasChanged(hook.changes, changes)) {\n hook.changes = changes;\n hook.callback = callback;\n }\n },\n returnValue: (hook) => hook.callback\n});\n\nexport const useMemo = createHook({\n onCreate: (callback, changes) => {\n return { callback, changes, value: callback() };\n },\n onUpdate: (hook, callback, changes) => {\n if (hasChanged(hook.changes, changes)) {\n hook.changes = changes;\n hook.value = callback();\n }\n },\n returnValue: (hook) => hook.value\n});\n"],
|
|
5
|
-
"mappings": ";AAAA,SAAmC,SAAS,WAAW,WAAW,WAAW,uBAAuB;AACpG,SAAS,kBAAkB;AA2B3B,IAAM,0BAA0B,oBAAI,QAA8C;AAE3E,IAAM,aAAa,SAASA,YAAW;AAAA,EAC5C;AAAA,EACA,UAAU;AAAA,EACV,WAAW;AAAA,EACX;AAAA,EACA;AACF,GAAyB;AACvB,SAAO,IAAI,SAAgB;AACzB,UAAM,YAAY,QAAQ;AAC1B,QAAI,YAAY,wBAAwB,IAAI,SAAS;AAErD,QAAI,CAAC,WAAW;AACd,kBAAY,EAAE,OAAO,CAAC,GAAG,YAAY,GAAG;AACxC,8BAAwB,IAAI,WAAW,SAAS;AAChD,gBAAU,MAAM,
|
|
4
|
+
"sourcesContent": ["import { Component, POJOComponent, current, directive, onCleanup, onUnmount, debouncedUpdate } from \"valyrian.js\";\nimport { hasChanged } from \"valyrian.js/utils\";\n\nexport type Hook = any;\n\nexport interface HookDefinition {\n // eslint-disable-next-line no-unused-vars\n onCreate: (...args: any[]) => any;\n // eslint-disable-next-line no-unused-vars\n onUpdate?: (hook: Hook, ...args: any[]) => any;\n // eslint-disable-next-line no-unused-vars\n onCleanup?: (hook: Hook) => any;\n // eslint-disable-next-line no-unused-vars\n onRemove?: (hook: Hook) => any;\n // eslint-disable-next-line no-unused-vars\n returnValue?: (hook: Hook) => any;\n}\n\nexport interface CreateHook {\n // eslint-disable-next-line no-unused-vars\n (HookDefinition: HookDefinition): (...args: any[]) => any;\n}\n\ntype HookCalls = {\n hooks: Hook[];\n hook_calls: number;\n};\n\nconst componentToHooksWeakMap = new WeakMap<Component | POJOComponent, HookCalls>();\n\nexport const createHook = function createHook({\n onCreate,\n onUpdate: onUpdateHook,\n onCleanup: onCleanupHook,\n onRemove,\n returnValue\n}: HookDefinition): Hook {\n return (...args: any[]) => {\n const component = current.component as Component | POJOComponent;\n let HookCalls = componentToHooksWeakMap.get(component);\n\n if (!HookCalls) {\n HookCalls = { hooks: [], hook_calls: -1 } as HookCalls;\n componentToHooksWeakMap.set(component, HookCalls);\n onUnmount(() => {\n componentToHooksWeakMap.delete(component);\n });\n }\n\n onCleanup(() => ((HookCalls as HookCalls).hook_calls = -1));\n\n let hook = HookCalls.hooks[++HookCalls.hook_calls];\n if (hook) {\n onUpdateHook?.(hook, ...args);\n } else {\n hook = onCreate(...args);\n HookCalls.hooks.push(hook);\n onRemove && onUnmount(() => onRemove(hook));\n }\n\n onCleanupHook && onCleanup(() => onCleanupHook(hook));\n return returnValue ? returnValue(hook) : hook;\n };\n} as unknown as CreateHook;\n\n// Use state hook\nexport const useState = createHook({\n onCreate: (value) => {\n let state = value;\n function get() {\n return state;\n }\n\n function set(newValue: any) {\n if (current.event && !current.event.defaultPrevented) {\n current.event.preventDefault();\n }\n\n const resolvedValue = typeof newValue === \"function\" ? newValue(state) : newValue;\n\n if (hasChanged(state, resolvedValue)) {\n state = resolvedValue;\n debouncedUpdate();\n }\n }\n\n return [get, set];\n }\n});\n\nexport const useEffect = createHook({\n onCreate: (effect: Function, changes: any[]) => {\n const hook: {\n effect: Function;\n prev: any[];\n onRemove?: Function;\n onCleanup?: Function;\n } = { effect, prev: [] };\n // on unmount\n if (changes === null) {\n hook.onRemove = effect;\n return hook;\n }\n\n // on create\n hook.prev = changes;\n hook.onCleanup = hook.effect();\n return hook;\n },\n onUpdate: (hook, effect, changes) => {\n // on update\n if (typeof changes === \"undefined\") {\n hook.prev = changes;\n if (typeof hook.onCleanup === \"function\") {\n hook.onCleanup();\n }\n hook.onCleanup = hook.effect();\n return;\n }\n\n if (Array.isArray(changes) && changes.length === 0) {\n // Si las dependencias son un array vac\u00EDo, no se debe volver a ejecutar.\n return;\n }\n\n // on update if there are changes\n if (Array.isArray(changes) && hasChanged(hook.prev, changes)) {\n hook.prev = changes;\n if (typeof hook.onCleanup === \"function\") {\n hook.onCleanup();\n }\n hook.onCleanup = hook.effect();\n }\n },\n onRemove: (hook) => {\n if (typeof hook.onCleanup === \"function\") {\n hook.onCleanup();\n }\n if (typeof hook.onRemove === \"function\") {\n hook.onRemove();\n }\n }\n});\n\nexport const useRef = createHook({\n onCreate: (initialValue) => {\n directive(\"ref\", (ref, vnode) => {\n ref.current = vnode.dom;\n });\n return { current: initialValue };\n }\n});\n\nexport const useCallback = createHook({\n onCreate: (callback, changes) => {\n return { callback, changes };\n },\n onUpdate: (hook, callback, changes) => {\n if (hasChanged(hook.changes, changes)) {\n hook.changes = changes;\n hook.callback = callback;\n }\n },\n returnValue: (hook) => hook.callback\n});\n\nexport const useMemo = createHook({\n onCreate: (callback, changes) => {\n return { callback, changes, value: callback() };\n },\n onUpdate: (hook, callback, changes) => {\n if (hasChanged(hook.changes, changes)) {\n hook.changes = changes;\n hook.value = callback();\n }\n },\n returnValue: (hook) => hook.value\n});\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["createHook"]
|
|
7
7
|
}
|
package/dist/index.js
CHANGED
|
@@ -608,6 +608,7 @@ function update() {
|
|
|
608
608
|
return mainVnode.dom.innerHTML;
|
|
609
609
|
}
|
|
610
610
|
}
|
|
611
|
+
return "";
|
|
611
612
|
}
|
|
612
613
|
var debouncedUpdateTimeout;
|
|
613
614
|
var clearDebouncedUpdateMethod = isNodeJs ? clearTimeout : cancelAnimationFrame;
|
|
@@ -633,6 +634,7 @@ function unmount() {
|
|
|
633
634
|
current.event = null;
|
|
634
635
|
return result;
|
|
635
636
|
}
|
|
637
|
+
return "";
|
|
636
638
|
}
|
|
637
639
|
function mount(dom, component) {
|
|
638
640
|
const container = typeof dom === "string" ? isNodeJs ? createElement(dom, dom === "svg") : document.querySelector(dom) : dom;
|