valyrian.js 7.2.12 → 8.0.0
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/README.md +6 -6
- package/dist/flux-store/index.d.ts +32 -0
- package/dist/flux-store/index.d.ts.map +1 -0
- package/dist/flux-store/index.js +258 -0
- package/dist/flux-store/index.js.map +7 -0
- package/dist/flux-store/index.min.js +1 -0
- package/dist/flux-store/index.min.js.map +1 -0
- package/dist/flux-store/index.mjs +237 -0
- package/dist/flux-store/index.mjs.map +7 -0
- package/dist/hooks/index.d.ts.map +1 -1
- package/dist/hooks/index.js +32 -50
- package/dist/hooks/index.js.map +3 -3
- package/dist/hooks/index.min.js +1 -0
- package/dist/hooks/index.min.js.map +1 -0
- package/dist/hooks/index.mjs +33 -51
- package/dist/hooks/index.mjs.map +3 -3
- package/dist/index.d.ts +6 -4
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +105 -88
- package/dist/index.js.map +3 -3
- package/dist/index.min.js +1 -1
- package/dist/index.min.js.map +1 -1
- package/dist/index.mjs +105 -88
- package/dist/index.mjs.map +3 -3
- package/dist/native-store/index.d.ts +14 -0
- package/dist/native-store/index.d.ts.map +1 -0
- package/dist/native-store/index.js +103 -0
- package/dist/native-store/index.js.map +7 -0
- package/dist/native-store/index.min.js +1 -0
- package/dist/native-store/index.min.js.map +1 -0
- package/dist/native-store/index.mjs +82 -0
- package/dist/native-store/index.mjs.map +7 -0
- package/dist/node/index.d.ts.map +1 -1
- package/dist/node/index.js +124 -10
- package/dist/node/index.js.map +4 -4
- package/dist/node/index.mjs +124 -10
- package/dist/node/index.mjs.map +4 -4
- package/dist/node/node.sw.js +152 -0
- package/dist/node/utils/inline.d.ts.map +1 -1
- package/dist/node/utils/node.sw.js +152 -0
- package/dist/node/utils/session-storage.d.ts +22 -0
- package/dist/node/utils/session-storage.d.ts.map +1 -0
- package/dist/node/utils/sw.d.ts.map +1 -1
- package/dist/node/utils/tree-adapter.d.ts +4 -0
- package/dist/node/utils/tree-adapter.d.ts.map +1 -1
- package/dist/pulse-store/index.d.ts +13 -0
- package/dist/pulse-store/index.d.ts.map +1 -0
- package/dist/pulse-store/index.js +143 -0
- package/dist/pulse-store/index.js.map +7 -0
- package/dist/pulse-store/index.min.js +1 -0
- package/dist/pulse-store/index.min.js.map +1 -0
- package/dist/pulse-store/index.mjs +122 -0
- package/dist/pulse-store/index.mjs.map +7 -0
- package/dist/request/index.d.ts.map +1 -1
- package/dist/request/index.js +63 -84
- package/dist/request/index.js.map +2 -2
- package/dist/request/index.min.js +1 -0
- package/dist/request/index.min.js.map +1 -0
- package/dist/request/index.mjs +63 -84
- package/dist/request/index.mjs.map +2 -2
- package/dist/router/index.d.ts +32 -31
- package/dist/router/index.d.ts.map +1 -1
- package/dist/router/index.js +247 -96
- package/dist/router/index.js.map +3 -3
- package/dist/router/index.min.js +1 -0
- package/dist/router/index.min.js.map +1 -0
- package/dist/router/index.mjs +247 -96
- package/dist/router/index.mjs.map +3 -3
- package/dist/signals/index.d.ts +6 -0
- package/dist/signals/index.d.ts.map +1 -0
- package/dist/signals/index.js +92 -0
- package/dist/signals/index.js.map +7 -0
- package/dist/signals/index.min.js +1 -0
- package/dist/signals/index.min.js.map +1 -0
- package/dist/signals/index.mjs +71 -0
- package/dist/signals/index.mjs.map +7 -0
- package/dist/suspense/index.d.ts +6 -0
- package/dist/suspense/index.d.ts.map +1 -0
- package/dist/suspense/index.js +67 -0
- package/dist/suspense/index.js.map +7 -0
- package/dist/suspense/index.min.js +1 -0
- package/dist/suspense/index.min.js.map +1 -0
- package/dist/suspense/index.mjs +46 -0
- package/dist/suspense/index.mjs.map +7 -0
- package/dist/sw/index.min.js +1 -0
- package/dist/sw/index.min.js.map +1 -0
- package/dist/translate/index.d.ts +19 -0
- package/dist/translate/index.d.ts.map +1 -0
- package/dist/translate/index.js +150 -0
- package/dist/translate/index.js.map +7 -0
- package/dist/translate/index.min.js +1 -0
- package/dist/translate/index.min.js.map +1 -0
- package/dist/translate/index.mjs +129 -0
- package/dist/translate/index.mjs.map +7 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/dist/utils/deep-freeze.d.ts +3 -0
- package/dist/utils/deep-freeze.d.ts.map +1 -0
- package/dist/utils/getter-setter.d.ts +3 -0
- package/dist/utils/getter-setter.d.ts.map +1 -0
- package/dist/utils/has-changed.d.ts +2 -0
- package/dist/utils/has-changed.d.ts.map +1 -0
- package/dist/utils/index.d.ts +4 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +138 -0
- package/dist/utils/index.js.map +7 -0
- package/dist/utils/index.min.js +1 -0
- package/dist/utils/index.min.js.map +1 -0
- package/dist/utils/index.mjs +115 -0
- package/dist/utils/index.mjs.map +7 -0
- package/lib/flux-store/index.ts +301 -0
- package/lib/hooks/index.ts +36 -56
- package/lib/index.ts +120 -110
- package/lib/native-store/index.ts +106 -0
- package/lib/node/index.ts +3 -1
- package/lib/node/utils/node.sw.js +152 -0
- package/lib/node/utils/session-storage.ts +117 -0
- package/lib/node/utils/sw.ts +34 -10
- package/lib/node/utils/tree-adapter.ts +18 -0
- package/lib/pulse-store/index.ts +181 -0
- package/lib/request/index.ts +81 -111
- package/lib/router/index.ts +349 -162
- package/lib/signals/index.ts +98 -0
- package/lib/suspense/index.ts +57 -0
- package/lib/translate/index.ts +156 -0
- package/lib/utils/deep-freeze.ts +54 -0
- package/lib/utils/getter-setter.ts +40 -0
- package/lib/utils/has-changed.ts +43 -0
- package/lib/utils/index.ts +3 -0
- package/package.json +38 -57
- package/tsconfig.json +1 -1
- package/dist/dataset/index.d.ts +0 -24
- package/dist/dataset/index.d.ts.map +0 -1
- package/dist/dataset/index.js +0 -178
- package/dist/dataset/index.js.map +0 -7
- package/dist/dataset/index.mjs +0 -157
- package/dist/dataset/index.mjs.map +0 -7
- package/dist/node/node.sw.tpl +0 -133
- package/dist/node/utils/node.sw.tpl +0 -133
- package/dist/proxy-signal/index.d.ts +0 -23
- package/dist/proxy-signal/index.d.ts.map +0 -1
- package/dist/proxy-signal/index.js +0 -138
- package/dist/proxy-signal/index.js.map +0 -7
- package/dist/proxy-signal/index.mjs +0 -117
- package/dist/proxy-signal/index.mjs.map +0 -7
- package/dist/signal/index.d.ts +0 -9
- package/dist/signal/index.d.ts.map +0 -1
- package/dist/signal/index.js +0 -76
- package/dist/signal/index.js.map +0 -7
- package/dist/signal/index.mjs +0 -55
- package/dist/signal/index.mjs.map +0 -7
- package/dist/store/index.d.ts +0 -16
- package/dist/store/index.d.ts.map +0 -1
- package/dist/store/index.js +0 -93
- package/dist/store/index.js.map +0 -7
- package/dist/store/index.mjs +0 -72
- package/dist/store/index.mjs.map +0 -7
- package/lib/dataset/index.ts +0 -193
- package/lib/node/utils/node.sw.tpl +0 -133
- package/lib/proxy-signal/index.ts +0 -187
- package/lib/signal/index.ts +0 -86
- package/lib/store/index.ts +0 -101
package/README.md
CHANGED
|
@@ -36,9 +36,9 @@ Lightweight steel to forge PWAs. (Minimal Frontend Framework with server side re
|
|
|
36
36
|
|
|
37
37
|
## Table of Contents
|
|
38
38
|
|
|
39
|
-
*
|
|
40
|
-
*
|
|
41
|
-
*
|
|
39
|
+
* [Tests](#tests)
|
|
40
|
+
* [Contributing](#contributing)
|
|
41
|
+
* [Legal](#legal)
|
|
42
42
|
|
|
43
43
|
## Tests
|
|
44
44
|
|
|
@@ -48,9 +48,9 @@ For development use `yarn dev:test`
|
|
|
48
48
|
|
|
49
49
|
## Contributing
|
|
50
50
|
|
|
51
|
-
*
|
|
52
|
-
*
|
|
53
|
-
*
|
|
51
|
+
* Use prettify and eslint to lint your code.
|
|
52
|
+
* Add tests for any new or changed functionality.
|
|
53
|
+
* Update the readme with an example if you add or change any functionality.
|
|
54
54
|
|
|
55
55
|
## Legal
|
|
56
56
|
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
interface StoreOptions {
|
|
2
|
+
state?: Record<string, any> | (() => Record<string, any>);
|
|
3
|
+
mutations?: Record<string, (state: Record<string, any>, ...args: any[]) => void>;
|
|
4
|
+
actions?: Record<string, (store: FluxStore, ...args: any[]) => any>;
|
|
5
|
+
getters?: Record<string, (state: Record<string, any>, getters: Record<string, any>, globalState?: any, globalGetters?: any) => any>;
|
|
6
|
+
modules?: Record<string, StoreOptions>;
|
|
7
|
+
shouldFreeze?: boolean;
|
|
8
|
+
namespace?: string;
|
|
9
|
+
rootStore?: FluxStore;
|
|
10
|
+
}
|
|
11
|
+
export declare class FluxStore {
|
|
12
|
+
state: Record<string, any>;
|
|
13
|
+
getters: Record<string, any>;
|
|
14
|
+
private init;
|
|
15
|
+
rootStore: FluxStore | null;
|
|
16
|
+
namespace: string | null;
|
|
17
|
+
constructor({ state, mutations, actions, getters, modules, shouldFreeze, namespace, rootStore }?: StoreOptions);
|
|
18
|
+
private keyExists;
|
|
19
|
+
private isFunction;
|
|
20
|
+
private getStore;
|
|
21
|
+
private isUnfrozen;
|
|
22
|
+
commit(mutation: string, ...args: any[]): void;
|
|
23
|
+
dispatch(action: string, ...args: any[]): Promise<any>;
|
|
24
|
+
trigger(event: string, ...args: any[]): void;
|
|
25
|
+
on(event: string, listener: Function): () => void;
|
|
26
|
+
off(event: string, listener: Function): void;
|
|
27
|
+
use(plugin: Function, ...options: any[]): void;
|
|
28
|
+
registerModule(namespace: string, module: StoreOptions): void;
|
|
29
|
+
unregisterModule(namespace: string): void;
|
|
30
|
+
}
|
|
31
|
+
export {};
|
|
32
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../lib/flux-store/index.ts"],"names":[],"mappings":"AAGA,UAAU,YAAY;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,CAAC,MAAM,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC;IAE1D,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,IAAI,CAAC,CAAC;IAEjF,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,SAAS,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,GAAG,CAAC,CAAC;IACpE,OAAO,CAAC,EAAE,MAAM,CACd,MAAM,EAEN,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,WAAW,CAAC,EAAE,GAAG,EAAE,aAAa,CAAC,EAAE,GAAG,KAAK,GAAG,CAC1G,CAAC;IACF,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC;IACvC,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB,SAAS,CAAC,EAAE,SAAS,CAAC;CACvB;AAGD,qBAAa,SAAS;IACb,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC3B,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACpC,OAAO,CAAC,IAAI,CAUV;IAEK,SAAS,EAAE,SAAS,GAAG,IAAI,CAAC;IAC5B,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;gBAGpB,EACV,KAAU,EACV,SAAc,EACd,OAAY,EACZ,OAAY,EACZ,OAAY,EACZ,YAAmB,EACnB,SAAS,EACT,SAAS,EACV,GAAE,YAAiB;IAsHpB,OAAO,CAAC,SAAS;IAMjB,OAAO,CAAC,UAAU;IAOlB,OAAO,CAAC,QAAQ;IAehB,OAAO,CAAC,UAAU;IAOX,MAAM,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE;IAcjC,QAAQ,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC;IAc5D,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE;IAKrC,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ;IAWpC,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ;IAWrC,GAAG,CAAC,MAAM,EAAE,QAAQ,EAAE,GAAG,OAAO,EAAE,GAAG,EAAE;IAUvC,cAAc,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,YAAY;IAiBtD,gBAAgB,CAAC,SAAS,EAAE,MAAM;CAe1C"}
|
|
@@ -0,0 +1,258 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// lib/flux-store/index.ts
|
|
21
|
+
var flux_store_exports = {};
|
|
22
|
+
__export(flux_store_exports, {
|
|
23
|
+
FluxStore: () => FluxStore
|
|
24
|
+
});
|
|
25
|
+
module.exports = __toCommonJS(flux_store_exports);
|
|
26
|
+
var import_valyrian = require("valyrian.js");
|
|
27
|
+
var import_utils = require("valyrian.js/utils");
|
|
28
|
+
var FluxStore = class _FluxStore {
|
|
29
|
+
state;
|
|
30
|
+
getters;
|
|
31
|
+
init;
|
|
32
|
+
// eslint-disable-next-line no-use-before-define
|
|
33
|
+
rootStore;
|
|
34
|
+
namespace;
|
|
35
|
+
// eslint-disable-next-line sonarjs/cognitive-complexity
|
|
36
|
+
constructor({
|
|
37
|
+
state = {},
|
|
38
|
+
mutations = {},
|
|
39
|
+
actions = {},
|
|
40
|
+
getters = {},
|
|
41
|
+
modules = {},
|
|
42
|
+
shouldFreeze = true,
|
|
43
|
+
namespace,
|
|
44
|
+
rootStore
|
|
45
|
+
} = {}) {
|
|
46
|
+
const localState = typeof state === "function" ? state() : state;
|
|
47
|
+
this.state = new Proxy(localState || {}, {
|
|
48
|
+
// Every time we try to access a property from the state we try to deep freeze the property
|
|
49
|
+
// to prevent direct modifications to the state
|
|
50
|
+
get: (state2, prop) => {
|
|
51
|
+
if ((this.rootStore || this).init.modules[prop]) {
|
|
52
|
+
return state2[prop];
|
|
53
|
+
}
|
|
54
|
+
if (shouldFreeze) {
|
|
55
|
+
if (this.init.frozen) {
|
|
56
|
+
return (0, import_utils.deepFreeze)(state2[prop]);
|
|
57
|
+
}
|
|
58
|
+
const newState = (0, import_utils.deepCloneUnfreeze)(state2);
|
|
59
|
+
for (const key of Reflect.ownKeys(newState)) {
|
|
60
|
+
localState[key] = newState[key];
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
return state2[prop];
|
|
64
|
+
},
|
|
65
|
+
// If the user tries to set directly it will throw an error, only if we have unfrozen the state via commit
|
|
66
|
+
// this will proceed to set the value
|
|
67
|
+
set: (state2, prop, value) => {
|
|
68
|
+
this.isUnfrozen();
|
|
69
|
+
const old = state2[prop];
|
|
70
|
+
state2[prop] = value;
|
|
71
|
+
if (this.namespace) {
|
|
72
|
+
prop = `${this.namespace}.${prop}`;
|
|
73
|
+
}
|
|
74
|
+
(this.rootStore || this).trigger("set", prop, value, old);
|
|
75
|
+
return true;
|
|
76
|
+
},
|
|
77
|
+
// If the user tries to delete directly it will throw an error, only if we have unfrozen the state via commit
|
|
78
|
+
// this will proceed to delete the property
|
|
79
|
+
deleteProperty: (state2, prop) => {
|
|
80
|
+
this.isUnfrozen();
|
|
81
|
+
const old = state2[prop];
|
|
82
|
+
Reflect.deleteProperty(state2, prop);
|
|
83
|
+
if (this.namespace) {
|
|
84
|
+
prop = `${this.namespace}.${prop}`;
|
|
85
|
+
}
|
|
86
|
+
(this.rootStore || this).trigger("delete", prop, old);
|
|
87
|
+
return true;
|
|
88
|
+
}
|
|
89
|
+
});
|
|
90
|
+
this.rootStore = rootStore || null;
|
|
91
|
+
this.namespace = namespace || null;
|
|
92
|
+
this.init = {
|
|
93
|
+
frozen: true,
|
|
94
|
+
plugins: [],
|
|
95
|
+
modules: {},
|
|
96
|
+
childModuleNamespaces: Object.keys(modules || {}),
|
|
97
|
+
listeners: {
|
|
98
|
+
set: [],
|
|
99
|
+
delete: [],
|
|
100
|
+
beforecommit: [],
|
|
101
|
+
commit: [],
|
|
102
|
+
beforedispatch: [],
|
|
103
|
+
dispatch: [],
|
|
104
|
+
getter: [],
|
|
105
|
+
addlistener: [],
|
|
106
|
+
removelistener: [],
|
|
107
|
+
plugin: [],
|
|
108
|
+
registerModule: [],
|
|
109
|
+
unregisterModule: []
|
|
110
|
+
},
|
|
111
|
+
getters: getters || {},
|
|
112
|
+
mutations: mutations || {},
|
|
113
|
+
actions: actions || {}
|
|
114
|
+
};
|
|
115
|
+
this.getters = new Proxy(getters || {}, {
|
|
116
|
+
// When we try to get a property of the getter we will call the original
|
|
117
|
+
// getter method passing the state as first argument and the other getters as second
|
|
118
|
+
// if we try to get a non existent getter it will fail silently as if
|
|
119
|
+
// we were trying to get an undefined property
|
|
120
|
+
get: (getters2, getter) => {
|
|
121
|
+
try {
|
|
122
|
+
const { store, key } = this.getStore(this, getter);
|
|
123
|
+
if (store instanceof _FluxStore && store.init.getters[key]) {
|
|
124
|
+
const value = store.init.getters[key](store.state, store.getters, this.state, this.getters);
|
|
125
|
+
if (this.namespace) {
|
|
126
|
+
getter = `${this.namespace}.${getter}`;
|
|
127
|
+
}
|
|
128
|
+
(this.rootStore || this).trigger("getter", getter, value);
|
|
129
|
+
return value;
|
|
130
|
+
}
|
|
131
|
+
} catch (error) {
|
|
132
|
+
return;
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
});
|
|
136
|
+
if (modules) {
|
|
137
|
+
Object.keys(modules).forEach((namespace2) => {
|
|
138
|
+
const n = this.namespace ? `${this.namespace}.${namespace2}` : namespace2;
|
|
139
|
+
(this.rootStore || this).registerModule(n, modules[namespace2]);
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
keyExists(objectname, object, key) {
|
|
144
|
+
if (!object[key]) {
|
|
145
|
+
throw new Error(`The ${objectname} "${key}" does not exists.`);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
isFunction(type, callback) {
|
|
149
|
+
if (typeof callback !== "function") {
|
|
150
|
+
throw new Error(`You need to provide a valid function as ${type}.`);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
// Giving a dot based namespace this method will be used to find the module to be called
|
|
154
|
+
getStore(store, namespace) {
|
|
155
|
+
let key = namespace;
|
|
156
|
+
if (key.indexOf(".") > -1) {
|
|
157
|
+
const parts = key.split(".");
|
|
158
|
+
key = parts.pop();
|
|
159
|
+
const moduleName = parts.join(".");
|
|
160
|
+
this.keyExists("module", store.init.modules, moduleName);
|
|
161
|
+
store = store.init.modules[moduleName];
|
|
162
|
+
}
|
|
163
|
+
return {
|
|
164
|
+
store,
|
|
165
|
+
key
|
|
166
|
+
};
|
|
167
|
+
}
|
|
168
|
+
isUnfrozen() {
|
|
169
|
+
if (this.init.frozen) {
|
|
170
|
+
throw new Error("You need to commit a mutation to change the state");
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
// This method unfroze the state and process a mutation
|
|
174
|
+
commit(mutation, ...args) {
|
|
175
|
+
const { store, key } = this.getStore(this, mutation);
|
|
176
|
+
this.keyExists("mutation", store.init.mutations, key);
|
|
177
|
+
store.init.frozen = false;
|
|
178
|
+
this.trigger("beforecommit", mutation, ...args);
|
|
179
|
+
store.init.mutations[key](store.state, ...args);
|
|
180
|
+
this.trigger("commit", mutation, ...args);
|
|
181
|
+
store.init.frozen = true;
|
|
182
|
+
(0, import_valyrian.debouncedUpdate)();
|
|
183
|
+
}
|
|
184
|
+
// This method will dispatch an action
|
|
185
|
+
async dispatch(action, ...args) {
|
|
186
|
+
const { store, key } = this.getStore(this, action);
|
|
187
|
+
this.keyExists("action", store.init.actions, key);
|
|
188
|
+
this.trigger("beforedispatch", action, ...args);
|
|
189
|
+
try {
|
|
190
|
+
const result = await store.init.actions[key](store, ...args);
|
|
191
|
+
this.trigger("dispatch", action, ...args);
|
|
192
|
+
return result;
|
|
193
|
+
} finally {
|
|
194
|
+
(0, import_valyrian.debouncedUpdate)();
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
// This method will trigger an event
|
|
198
|
+
trigger(event, ...args) {
|
|
199
|
+
this.init.listeners[event].forEach((callback) => callback(this, ...args));
|
|
200
|
+
}
|
|
201
|
+
// This method will add a listener to the store
|
|
202
|
+
on(event, listener) {
|
|
203
|
+
this.isFunction("listener", listener);
|
|
204
|
+
this.keyExists("event", this.init.listeners, event);
|
|
205
|
+
if (this.init.listeners[event].indexOf(listener) === -1) {
|
|
206
|
+
this.init.listeners[event].push(listener);
|
|
207
|
+
this.trigger("addlistener", event, listener);
|
|
208
|
+
}
|
|
209
|
+
return () => this.off(event, listener);
|
|
210
|
+
}
|
|
211
|
+
// Remove a listener from the store
|
|
212
|
+
off(event, listener) {
|
|
213
|
+
this.isFunction("listener", listener);
|
|
214
|
+
this.keyExists("event", this.init.listeners, event);
|
|
215
|
+
const index = this.init.listeners[event].indexOf(listener);
|
|
216
|
+
if (index > -1) {
|
|
217
|
+
this.init.listeners[event].splice(index, 1);
|
|
218
|
+
this.trigger("removelistener", event, listener);
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
// This method will add a plugin to the store
|
|
222
|
+
use(plugin, ...options) {
|
|
223
|
+
this.isFunction("plugin", plugin);
|
|
224
|
+
if (this.init.plugins.indexOf(plugin) === -1) {
|
|
225
|
+
plugin(this, ...options);
|
|
226
|
+
this.init.plugins.push(plugin);
|
|
227
|
+
this.trigger("plugin", plugin, ...options);
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
// This method will register a module to the store
|
|
231
|
+
registerModule(namespace, module2) {
|
|
232
|
+
const rootStore = this;
|
|
233
|
+
if (rootStore.init.modules[namespace]) {
|
|
234
|
+
throw new Error(`A module with the namespace "${namespace}" is already registered.`);
|
|
235
|
+
}
|
|
236
|
+
const newStore = new _FluxStore({ ...module2, rootStore, namespace });
|
|
237
|
+
rootStore.init.frozen = false;
|
|
238
|
+
rootStore.init.modules[namespace] = newStore;
|
|
239
|
+
rootStore.state[namespace] = newStore.state;
|
|
240
|
+
rootStore.init.frozen = true;
|
|
241
|
+
rootStore.trigger("registerModule", namespace, module2, newStore);
|
|
242
|
+
(0, import_valyrian.debouncedUpdate)();
|
|
243
|
+
}
|
|
244
|
+
// This method will unregister a module from the store
|
|
245
|
+
unregisterModule(namespace) {
|
|
246
|
+
const rootStore = this;
|
|
247
|
+
const store = rootStore.init.modules[namespace];
|
|
248
|
+
if (store) {
|
|
249
|
+
store.init.childModuleNamespaces.forEach((n) => rootStore.unregisterModule(`${namespace}.${n}`));
|
|
250
|
+
rootStore.init.frozen = false;
|
|
251
|
+
Reflect.deleteProperty(rootStore.init.modules, namespace);
|
|
252
|
+
Reflect.deleteProperty(rootStore.state, namespace);
|
|
253
|
+
rootStore.init.frozen = true;
|
|
254
|
+
rootStore.trigger("unregisterModule", namespace, store);
|
|
255
|
+
(0, import_valyrian.debouncedUpdate)();
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 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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",
|
|
6
|
+
"names": ["state", "getters", "namespace", "module"]
|
|
7
|
+
}
|
|
@@ -0,0 +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:()=>h});var n,o=(n=r,((r,n,o,a)=>{if(n&&"object"==typeof n||"function"==typeof n)for(let c of i(n))s.call(r,c)||c===o||e(r,c,{get:()=>n[c],enumerable:!(a=t(n,c))||a.enumerable});return r})(e({},"__esModule",{value:!0}),n)),a=require("valyrian.js"),c=require("valyrian.js/utils"),h=class e{state;getters;init;rootStore;namespace;constructor({state:t={},mutations:i={},actions:s={},getters:r={},modules:n={},shouldFreeze:o=!0,namespace:a,rootStore:h}={}){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,c.deepFreeze)(e[t]);const i=(0,c.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=h||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){return this.isFunction("listener",t),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
|
|
@@ -0,0 +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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"}
|
|
@@ -0,0 +1,237 @@
|
|
|
1
|
+
// lib/flux-store/index.ts
|
|
2
|
+
import { debouncedUpdate } from "valyrian.js";
|
|
3
|
+
import { deepCloneUnfreeze, deepFreeze } from "valyrian.js/utils";
|
|
4
|
+
var FluxStore = class _FluxStore {
|
|
5
|
+
state;
|
|
6
|
+
getters;
|
|
7
|
+
init;
|
|
8
|
+
// eslint-disable-next-line no-use-before-define
|
|
9
|
+
rootStore;
|
|
10
|
+
namespace;
|
|
11
|
+
// eslint-disable-next-line sonarjs/cognitive-complexity
|
|
12
|
+
constructor({
|
|
13
|
+
state = {},
|
|
14
|
+
mutations = {},
|
|
15
|
+
actions = {},
|
|
16
|
+
getters = {},
|
|
17
|
+
modules = {},
|
|
18
|
+
shouldFreeze = true,
|
|
19
|
+
namespace,
|
|
20
|
+
rootStore
|
|
21
|
+
} = {}) {
|
|
22
|
+
const localState = typeof state === "function" ? state() : state;
|
|
23
|
+
this.state = new Proxy(localState || {}, {
|
|
24
|
+
// Every time we try to access a property from the state we try to deep freeze the property
|
|
25
|
+
// to prevent direct modifications to the state
|
|
26
|
+
get: (state2, prop) => {
|
|
27
|
+
if ((this.rootStore || this).init.modules[prop]) {
|
|
28
|
+
return state2[prop];
|
|
29
|
+
}
|
|
30
|
+
if (shouldFreeze) {
|
|
31
|
+
if (this.init.frozen) {
|
|
32
|
+
return deepFreeze(state2[prop]);
|
|
33
|
+
}
|
|
34
|
+
const newState = deepCloneUnfreeze(state2);
|
|
35
|
+
for (const key of Reflect.ownKeys(newState)) {
|
|
36
|
+
localState[key] = newState[key];
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
return state2[prop];
|
|
40
|
+
},
|
|
41
|
+
// If the user tries to set directly it will throw an error, only if we have unfrozen the state via commit
|
|
42
|
+
// this will proceed to set the value
|
|
43
|
+
set: (state2, prop, value) => {
|
|
44
|
+
this.isUnfrozen();
|
|
45
|
+
const old = state2[prop];
|
|
46
|
+
state2[prop] = value;
|
|
47
|
+
if (this.namespace) {
|
|
48
|
+
prop = `${this.namespace}.${prop}`;
|
|
49
|
+
}
|
|
50
|
+
(this.rootStore || this).trigger("set", prop, value, old);
|
|
51
|
+
return true;
|
|
52
|
+
},
|
|
53
|
+
// If the user tries to delete directly it will throw an error, only if we have unfrozen the state via commit
|
|
54
|
+
// this will proceed to delete the property
|
|
55
|
+
deleteProperty: (state2, prop) => {
|
|
56
|
+
this.isUnfrozen();
|
|
57
|
+
const old = state2[prop];
|
|
58
|
+
Reflect.deleteProperty(state2, prop);
|
|
59
|
+
if (this.namespace) {
|
|
60
|
+
prop = `${this.namespace}.${prop}`;
|
|
61
|
+
}
|
|
62
|
+
(this.rootStore || this).trigger("delete", prop, old);
|
|
63
|
+
return true;
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
this.rootStore = rootStore || null;
|
|
67
|
+
this.namespace = namespace || null;
|
|
68
|
+
this.init = {
|
|
69
|
+
frozen: true,
|
|
70
|
+
plugins: [],
|
|
71
|
+
modules: {},
|
|
72
|
+
childModuleNamespaces: Object.keys(modules || {}),
|
|
73
|
+
listeners: {
|
|
74
|
+
set: [],
|
|
75
|
+
delete: [],
|
|
76
|
+
beforecommit: [],
|
|
77
|
+
commit: [],
|
|
78
|
+
beforedispatch: [],
|
|
79
|
+
dispatch: [],
|
|
80
|
+
getter: [],
|
|
81
|
+
addlistener: [],
|
|
82
|
+
removelistener: [],
|
|
83
|
+
plugin: [],
|
|
84
|
+
registerModule: [],
|
|
85
|
+
unregisterModule: []
|
|
86
|
+
},
|
|
87
|
+
getters: getters || {},
|
|
88
|
+
mutations: mutations || {},
|
|
89
|
+
actions: actions || {}
|
|
90
|
+
};
|
|
91
|
+
this.getters = new Proxy(getters || {}, {
|
|
92
|
+
// When we try to get a property of the getter we will call the original
|
|
93
|
+
// getter method passing the state as first argument and the other getters as second
|
|
94
|
+
// if we try to get a non existent getter it will fail silently as if
|
|
95
|
+
// we were trying to get an undefined property
|
|
96
|
+
get: (getters2, getter) => {
|
|
97
|
+
try {
|
|
98
|
+
const { store, key } = this.getStore(this, getter);
|
|
99
|
+
if (store instanceof _FluxStore && store.init.getters[key]) {
|
|
100
|
+
const value = store.init.getters[key](store.state, store.getters, this.state, this.getters);
|
|
101
|
+
if (this.namespace) {
|
|
102
|
+
getter = `${this.namespace}.${getter}`;
|
|
103
|
+
}
|
|
104
|
+
(this.rootStore || this).trigger("getter", getter, value);
|
|
105
|
+
return value;
|
|
106
|
+
}
|
|
107
|
+
} catch (error) {
|
|
108
|
+
return;
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
if (modules) {
|
|
113
|
+
Object.keys(modules).forEach((namespace2) => {
|
|
114
|
+
const n = this.namespace ? `${this.namespace}.${namespace2}` : namespace2;
|
|
115
|
+
(this.rootStore || this).registerModule(n, modules[namespace2]);
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
keyExists(objectname, object, key) {
|
|
120
|
+
if (!object[key]) {
|
|
121
|
+
throw new Error(`The ${objectname} "${key}" does not exists.`);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
isFunction(type, callback) {
|
|
125
|
+
if (typeof callback !== "function") {
|
|
126
|
+
throw new Error(`You need to provide a valid function as ${type}.`);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
// Giving a dot based namespace this method will be used to find the module to be called
|
|
130
|
+
getStore(store, namespace) {
|
|
131
|
+
let key = namespace;
|
|
132
|
+
if (key.indexOf(".") > -1) {
|
|
133
|
+
const parts = key.split(".");
|
|
134
|
+
key = parts.pop();
|
|
135
|
+
const moduleName = parts.join(".");
|
|
136
|
+
this.keyExists("module", store.init.modules, moduleName);
|
|
137
|
+
store = store.init.modules[moduleName];
|
|
138
|
+
}
|
|
139
|
+
return {
|
|
140
|
+
store,
|
|
141
|
+
key
|
|
142
|
+
};
|
|
143
|
+
}
|
|
144
|
+
isUnfrozen() {
|
|
145
|
+
if (this.init.frozen) {
|
|
146
|
+
throw new Error("You need to commit a mutation to change the state");
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
// This method unfroze the state and process a mutation
|
|
150
|
+
commit(mutation, ...args) {
|
|
151
|
+
const { store, key } = this.getStore(this, mutation);
|
|
152
|
+
this.keyExists("mutation", store.init.mutations, key);
|
|
153
|
+
store.init.frozen = false;
|
|
154
|
+
this.trigger("beforecommit", mutation, ...args);
|
|
155
|
+
store.init.mutations[key](store.state, ...args);
|
|
156
|
+
this.trigger("commit", mutation, ...args);
|
|
157
|
+
store.init.frozen = true;
|
|
158
|
+
debouncedUpdate();
|
|
159
|
+
}
|
|
160
|
+
// This method will dispatch an action
|
|
161
|
+
async dispatch(action, ...args) {
|
|
162
|
+
const { store, key } = this.getStore(this, action);
|
|
163
|
+
this.keyExists("action", store.init.actions, key);
|
|
164
|
+
this.trigger("beforedispatch", action, ...args);
|
|
165
|
+
try {
|
|
166
|
+
const result = await store.init.actions[key](store, ...args);
|
|
167
|
+
this.trigger("dispatch", action, ...args);
|
|
168
|
+
return result;
|
|
169
|
+
} finally {
|
|
170
|
+
debouncedUpdate();
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
// This method will trigger an event
|
|
174
|
+
trigger(event, ...args) {
|
|
175
|
+
this.init.listeners[event].forEach((callback) => callback(this, ...args));
|
|
176
|
+
}
|
|
177
|
+
// This method will add a listener to the store
|
|
178
|
+
on(event, listener) {
|
|
179
|
+
this.isFunction("listener", listener);
|
|
180
|
+
this.keyExists("event", this.init.listeners, event);
|
|
181
|
+
if (this.init.listeners[event].indexOf(listener) === -1) {
|
|
182
|
+
this.init.listeners[event].push(listener);
|
|
183
|
+
this.trigger("addlistener", event, listener);
|
|
184
|
+
}
|
|
185
|
+
return () => this.off(event, listener);
|
|
186
|
+
}
|
|
187
|
+
// Remove a listener from the store
|
|
188
|
+
off(event, listener) {
|
|
189
|
+
this.isFunction("listener", listener);
|
|
190
|
+
this.keyExists("event", this.init.listeners, event);
|
|
191
|
+
const index = this.init.listeners[event].indexOf(listener);
|
|
192
|
+
if (index > -1) {
|
|
193
|
+
this.init.listeners[event].splice(index, 1);
|
|
194
|
+
this.trigger("removelistener", event, listener);
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
// This method will add a plugin to the store
|
|
198
|
+
use(plugin, ...options) {
|
|
199
|
+
this.isFunction("plugin", plugin);
|
|
200
|
+
if (this.init.plugins.indexOf(plugin) === -1) {
|
|
201
|
+
plugin(this, ...options);
|
|
202
|
+
this.init.plugins.push(plugin);
|
|
203
|
+
this.trigger("plugin", plugin, ...options);
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
// This method will register a module to the store
|
|
207
|
+
registerModule(namespace, module) {
|
|
208
|
+
const rootStore = this;
|
|
209
|
+
if (rootStore.init.modules[namespace]) {
|
|
210
|
+
throw new Error(`A module with the namespace "${namespace}" is already registered.`);
|
|
211
|
+
}
|
|
212
|
+
const newStore = new _FluxStore({ ...module, rootStore, namespace });
|
|
213
|
+
rootStore.init.frozen = false;
|
|
214
|
+
rootStore.init.modules[namespace] = newStore;
|
|
215
|
+
rootStore.state[namespace] = newStore.state;
|
|
216
|
+
rootStore.init.frozen = true;
|
|
217
|
+
rootStore.trigger("registerModule", namespace, module, newStore);
|
|
218
|
+
debouncedUpdate();
|
|
219
|
+
}
|
|
220
|
+
// This method will unregister a module from the store
|
|
221
|
+
unregisterModule(namespace) {
|
|
222
|
+
const rootStore = this;
|
|
223
|
+
const store = rootStore.init.modules[namespace];
|
|
224
|
+
if (store) {
|
|
225
|
+
store.init.childModuleNamespaces.forEach((n) => rootStore.unregisterModule(`${namespace}.${n}`));
|
|
226
|
+
rootStore.init.frozen = false;
|
|
227
|
+
Reflect.deleteProperty(rootStore.init.modules, namespace);
|
|
228
|
+
Reflect.deleteProperty(rootStore.state, namespace);
|
|
229
|
+
rootStore.init.frozen = true;
|
|
230
|
+
rootStore.trigger("unregisterModule", namespace, store);
|
|
231
|
+
debouncedUpdate();
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
};
|
|
235
|
+
export {
|
|
236
|
+
FluxStore
|
|
237
|
+
};
|