@furystack/shades 6.1.5 → 7.1.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/dist/component-factory.spec.js +6 -6
- package/dist/component-factory.spec.js.map +1 -1
- package/dist/components/lazy-load.js +17 -14
- package/dist/components/lazy-load.js.map +1 -1
- package/dist/components/route-link.js +7 -3
- package/dist/components/route-link.js.map +1 -1
- package/dist/components/route-link.spec.js +2 -2
- package/dist/components/route-link.spec.js.map +1 -1
- package/dist/components/router.js +25 -26
- package/dist/components/router.js.map +1 -1
- package/dist/components/router.spec.js +2 -2
- package/dist/components/router.spec.js.map +1 -1
- package/dist/services/location-service.js +52 -4
- package/dist/services/location-service.js.map +1 -1
- package/dist/services/location-service.spec.js +63 -5
- package/dist/services/location-service.spec.js.map +1 -1
- package/dist/services/resource-manager.js +48 -0
- package/dist/services/resource-manager.js.map +1 -0
- package/dist/services/resource-manager.spec.js +32 -0
- package/dist/services/resource-manager.spec.js.map +1 -0
- package/dist/shade-component.js +28 -14
- package/dist/shade-component.js.map +1 -1
- package/dist/shade-resources.integration.spec.js +7 -8
- package/dist/shade-resources.integration.spec.js.map +1 -1
- package/dist/shade.js +79 -69
- package/dist/shade.js.map +1 -1
- package/dist/shades.integration.spec.js +197 -187
- package/dist/shades.integration.spec.js.map +1 -1
- package/package.json +6 -6
- package/src/component-factory.spec.tsx +7 -7
- package/src/components/lazy-load.tsx +19 -15
- package/src/components/route-link.spec.tsx +2 -2
- package/src/components/route-link.tsx +11 -10
- package/src/components/router.spec.tsx +2 -2
- package/src/components/router.tsx +32 -32
- package/src/jsx.ts +3 -2
- package/src/models/render-options.ts +59 -9
- package/src/services/location-service.spec.ts +75 -6
- package/src/services/location-service.tsx +58 -4
- package/src/services/resource-manager.spec.ts +33 -0
- package/src/services/resource-manager.ts +60 -0
- package/src/shade-component.ts +35 -15
- package/src/shade-resources.integration.spec.tsx +8 -14
- package/src/shade.ts +95 -104
- package/src/shades.integration.spec.tsx +265 -252
- package/types/components/lazy-load.d.ts +1 -1
- package/types/components/lazy-load.d.ts.map +1 -1
- package/types/components/route-link.d.ts +1 -1
- package/types/components/route-link.d.ts.map +1 -1
- package/types/components/router.d.ts +6 -8
- package/types/components/router.d.ts.map +1 -1
- package/types/jsx.d.ts +3 -2
- package/types/jsx.d.ts.map +1 -1
- package/types/models/render-options.d.ts +46 -7
- package/types/models/render-options.d.ts.map +1 -1
- package/types/services/location-service.d.ts +21 -1
- package/types/services/location-service.d.ts.map +1 -1
- package/types/services/resource-manager.d.ts +16 -0
- package/types/services/resource-manager.d.ts.map +1 -0
- package/types/services/resource-manager.spec.d.ts +2 -0
- package/types/services/resource-manager.spec.d.ts.map +1 -0
- package/types/shade-component.d.ts +16 -5
- package/types/shade-component.d.ts.map +1 -1
- package/types/shade.d.ts +8 -27
- package/types/shade.d.ts.map +1 -1
package/dist/shade-component.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.createComponent = exports.createFragmentInner = exports.createComponentInner = exports.attachProps = exports.attachDataAttributes = exports.attachStyles = exports.hasStyle = exports.appendChild = void 0;
|
|
4
4
|
const models_1 = require("./models");
|
|
5
5
|
/**
|
|
6
6
|
* Appends a list of items to a HTML element
|
|
@@ -10,7 +10,7 @@ const models_1 = require("./models");
|
|
|
10
10
|
*/
|
|
11
11
|
const appendChild = (el, children) => {
|
|
12
12
|
for (const child of children) {
|
|
13
|
-
if (typeof child === 'string') {
|
|
13
|
+
if (typeof child === 'string' || typeof child === 'number') {
|
|
14
14
|
el.appendChild(document.createTextNode(child));
|
|
15
15
|
}
|
|
16
16
|
else {
|
|
@@ -49,22 +49,29 @@ const attachDataAttributes = (el, props) => {
|
|
|
49
49
|
.forEach(([key, value]) => el.setAttribute(key, value || ''));
|
|
50
50
|
};
|
|
51
51
|
exports.attachDataAttributes = attachDataAttributes;
|
|
52
|
+
/**
|
|
53
|
+
*
|
|
54
|
+
* @param el The Target HTML Element
|
|
55
|
+
* @param props The Props to attach
|
|
56
|
+
*/
|
|
57
|
+
const attachProps = (el, props) => {
|
|
58
|
+
Object.assign(el, props);
|
|
59
|
+
if (props && props.style) {
|
|
60
|
+
(0, exports.attachStyles)(el, props);
|
|
61
|
+
}
|
|
62
|
+
(0, exports.attachDataAttributes)(el, props);
|
|
63
|
+
};
|
|
64
|
+
exports.attachProps = attachProps;
|
|
65
|
+
// eslint-disable-next-line jsdoc/require-param
|
|
52
66
|
/**
|
|
53
67
|
* Factory method that creates a component. This should be configured as a default JSX Factory in tsconfig.
|
|
54
68
|
*
|
|
55
|
-
* @param elementType The type of the element (component or stateless component factory method)
|
|
56
|
-
* @param props The props for the component
|
|
57
|
-
* @param children additional rest parameters will be parsed as children objects
|
|
58
69
|
* @returns the created JSX element
|
|
59
70
|
*/
|
|
60
|
-
const
|
|
71
|
+
const createComponentInner = (...[elementType, props, ...children]) => {
|
|
61
72
|
if (typeof elementType === 'string') {
|
|
62
73
|
const el = document.createElement(elementType);
|
|
63
|
-
|
|
64
|
-
if (props && props.style) {
|
|
65
|
-
(0, exports.attachStyles)(el, props);
|
|
66
|
-
}
|
|
67
|
-
(0, exports.attachDataAttributes)(el, props);
|
|
74
|
+
(0, exports.attachProps)(el, props);
|
|
68
75
|
if (children) {
|
|
69
76
|
(0, exports.appendChild)(el, children);
|
|
70
77
|
}
|
|
@@ -77,11 +84,18 @@ const createComponent = (elementType, props, ...children) => {
|
|
|
77
84
|
}
|
|
78
85
|
return undefined;
|
|
79
86
|
};
|
|
80
|
-
exports.
|
|
81
|
-
const
|
|
87
|
+
exports.createComponentInner = createComponentInner;
|
|
88
|
+
const createFragmentInner = (...[_props, ...children]) => {
|
|
82
89
|
const fragment = document.createDocumentFragment();
|
|
83
90
|
(0, exports.appendChild)(fragment, children);
|
|
84
91
|
return fragment;
|
|
85
92
|
};
|
|
86
|
-
exports.
|
|
93
|
+
exports.createFragmentInner = createFragmentInner;
|
|
94
|
+
const createComponent = (...args) => {
|
|
95
|
+
if (args[0] === null) {
|
|
96
|
+
return (0, exports.createFragmentInner)(...args);
|
|
97
|
+
}
|
|
98
|
+
return (0, exports.createComponentInner)(...args);
|
|
99
|
+
};
|
|
100
|
+
exports.createComponent = createComponent;
|
|
87
101
|
//# sourceMappingURL=shade-component.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shade-component.js","sourceRoot":"","sources":["../src/shade-component.ts"],"names":[],"mappings":";;;AACA,qCAA2C;AAE3C;;;;;GAKG;AACI,MAAM,WAAW,GAAG,CAAC,EAAkC,EAAE,QAAsB,EAAE,EAAE;IACxF,KAAK,MAAM,KAAK,IAAI,QAAQ,EAAE;QAC5B,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;
|
|
1
|
+
{"version":3,"file":"shade-component.js","sourceRoot":"","sources":["../src/shade-component.ts"],"names":[],"mappings":"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"}
|
|
@@ -18,15 +18,13 @@ describe('Shade Resources integration tests', () => {
|
|
|
18
18
|
const obs1 = new utils_1.ObservableValue(0);
|
|
19
19
|
const obs2 = new utils_1.ObservableValue('a');
|
|
20
20
|
const ExampleComponent = (0, shade_1.Shade)({
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
],
|
|
25
|
-
render: () => {
|
|
21
|
+
render: ({ useObservable }) => {
|
|
22
|
+
const [value1] = useObservable('obs1', obs1);
|
|
23
|
+
const [value2] = useObservable('obs2', obs2);
|
|
26
24
|
renderCounter();
|
|
27
25
|
return ((0, shade_component_1.createComponent)("div", null,
|
|
28
|
-
(0, shade_component_1.createComponent)("div", { id: "val1" }),
|
|
29
|
-
(0, shade_component_1.createComponent)("div", { id: "val2" })));
|
|
26
|
+
(0, shade_component_1.createComponent)("div", { id: "val1" }, value1),
|
|
27
|
+
(0, shade_component_1.createComponent)("div", { id: "val2" }, value2)));
|
|
30
28
|
},
|
|
31
29
|
shadowDomName: 'shades-example-resource',
|
|
32
30
|
});
|
|
@@ -43,12 +41,13 @@ describe('Shade Resources integration tests', () => {
|
|
|
43
41
|
expect(renderCounter).toBeCalledTimes(1);
|
|
44
42
|
obs1.setValue(1);
|
|
45
43
|
expect(document.body.innerHTML).toBe('<div id="root"><shades-example-resource><div><div id="val1">1</div><div id="val2">a</div></div></shades-example-resource></div>');
|
|
44
|
+
expect(renderCounter).toBeCalledTimes(2);
|
|
46
45
|
obs2.setValue('b');
|
|
47
46
|
expect(document.body.innerHTML).toBe('<div id="root"><shades-example-resource><div><div id="val1">1</div><div id="val2">b</div></div></shades-example-resource></div>');
|
|
48
47
|
document.body.innerHTML = '';
|
|
49
48
|
expect(obs1.getObservers().length).toBe(0);
|
|
50
49
|
expect(obs2.getObservers().length).toBe(0);
|
|
51
|
-
expect(renderCounter).toBeCalledTimes(
|
|
50
|
+
expect(renderCounter).toBeCalledTimes(3);
|
|
52
51
|
});
|
|
53
52
|
});
|
|
54
53
|
//# sourceMappingURL=shade-resources.integration.spec.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shade-resources.integration.spec.js","sourceRoot":"","sources":["../src/shade-resources.integration.spec.tsx"],"names":[],"mappings":";;AAAA,8CAA4C;AAE5C,+BAA+C;AAE/C,MAAM,CAAC,WAAW,GAAG,kBAAW,CAAA;AAChC,MAAM,CAAC,WAAW,GAAG,kBAAkB,CAAA;AAEvC,6CAAkD;AAClD,mCAA+B;AAC/B,uDAAmD;AACnD,4CAAkD;AAElD,QAAQ,CAAC,mCAAmC,EAAE,GAAG,EAAE;IACjD,UAAU,CAAC,GAAG,EAAE,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,GAAG,uBAAuB,CAAC,CAAC,CAAA;IACrE,SAAS,CAAC,GAAG,EAAE,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC,CAAC,CAAA;IAE/C,EAAE,CAAC,uEAAuE,EAAE,GAAG,EAAE;QAC/E,MAAM,QAAQ,GAAG,IAAI,iBAAQ,EAAE,CAAA;QAC/B,MAAM,WAAW,GAAG,QAAQ,CAAC,cAAc,CAAC,MAAM,CAAmB,CAAA;QAErE,MAAM,aAAa,GAAG,IAAI,CAAC,EAAE,EAAE,CAAA;QAE/B,MAAM,IAAI,GAAG,IAAI,uBAAe,CAAC,CAAC,CAAC,CAAA;QACnC,MAAM,IAAI,GAAG,IAAI,uBAAe,CAAC,GAAG,CAAC,CAAA;QAErC,MAAM,gBAAgB,GAAG,IAAA,aAAK,EAAC;YAC7B,
|
|
1
|
+
{"version":3,"file":"shade-resources.integration.spec.js","sourceRoot":"","sources":["../src/shade-resources.integration.spec.tsx"],"names":[],"mappings":"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"}
|
package/dist/shade.js
CHANGED
|
@@ -1,7 +1,10 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.Shade = void 0;
|
|
4
|
+
const utils_1 = require("@furystack/utils");
|
|
4
5
|
const inject_1 = require("@furystack/inject");
|
|
6
|
+
const resource_manager_1 = require("./services/resource-manager");
|
|
7
|
+
const services_1 = require("./services");
|
|
5
8
|
/**
|
|
6
9
|
* Factory method for creating Shade components
|
|
7
10
|
*
|
|
@@ -14,45 +17,107 @@ const Shade = (o) => {
|
|
|
14
17
|
const existing = customElements.get(customElementName);
|
|
15
18
|
if (!existing) {
|
|
16
19
|
customElements.define(customElementName, class extends HTMLElement {
|
|
20
|
+
constructor() {
|
|
21
|
+
super(...arguments);
|
|
22
|
+
this.resourceManager = new resource_manager_1.ResourceManager();
|
|
23
|
+
/**
|
|
24
|
+
* @param options Options for rendering the component
|
|
25
|
+
* @returns the JSX element
|
|
26
|
+
*/
|
|
27
|
+
this.render = (options) => o.render(options);
|
|
28
|
+
/**
|
|
29
|
+
* @returns values for the current render options
|
|
30
|
+
*/
|
|
31
|
+
this.getRenderOptions = () => {
|
|
32
|
+
const renderOptions = {
|
|
33
|
+
props: this.props,
|
|
34
|
+
injector: this.injector,
|
|
35
|
+
children: this.shadeChildren,
|
|
36
|
+
element: this,
|
|
37
|
+
useObservable: (key, obesrvable, callback, getLast) => this.resourceManager.useObservable(key, obesrvable, callback || (() => this.updateComponent()), getLast),
|
|
38
|
+
useState: (key, initialValue) => this.resourceManager.useState(key, initialValue, this.updateComponent.bind(this)),
|
|
39
|
+
useSearchState: (key, initialValue) => this.resourceManager.useObservable(`useSearchState-${key}`, this.injector.getInstance(services_1.LocationService).useSearchParam(key, initialValue), () => this.updateComponent()),
|
|
40
|
+
useStoredState: (key, initialValue, storageArea = localStorage) => {
|
|
41
|
+
const getFromStorage = () => {
|
|
42
|
+
const value = storageArea?.getItem(key);
|
|
43
|
+
return value ? JSON.parse(value) : initialValue;
|
|
44
|
+
};
|
|
45
|
+
const setToStorage = (value) => {
|
|
46
|
+
if (JSON.stringify(value) !== storageArea?.getItem(key)) {
|
|
47
|
+
const newValue = JSON.stringify(value);
|
|
48
|
+
storageArea?.setItem(key, newValue);
|
|
49
|
+
}
|
|
50
|
+
if (JSON.stringify(observable.getValue()) !== JSON.stringify(value)) {
|
|
51
|
+
observable.setValue(value);
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
const observable = this.resourceManager.useDisposable(`useStoredState-${key}`, () => new utils_1.ObservableValue(getFromStorage()));
|
|
55
|
+
const updateFromStorageEvent = (e) => {
|
|
56
|
+
e.key === key &&
|
|
57
|
+
e.storageArea === storageArea &&
|
|
58
|
+
setToStorage((e.newValue && JSON.parse(e.newValue)) || initialValue);
|
|
59
|
+
};
|
|
60
|
+
this.resourceManager.useDisposable(`useStoredState-${key}-storage-event`, () => {
|
|
61
|
+
window.addEventListener('storage', updateFromStorageEvent);
|
|
62
|
+
const channelName = `useStoredState-broadcast-channel`;
|
|
63
|
+
const messageChannel = new BroadcastChannel(channelName);
|
|
64
|
+
messageChannel.onmessage = (e) => {
|
|
65
|
+
if (e.data.key === key) {
|
|
66
|
+
setToStorage(e.data.value);
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
const subscription = observable.subscribe((value) => {
|
|
70
|
+
messageChannel.postMessage({ key, value });
|
|
71
|
+
});
|
|
72
|
+
return {
|
|
73
|
+
dispose: () => {
|
|
74
|
+
window.removeEventListener('storage', updateFromStorageEvent);
|
|
75
|
+
subscription.dispose();
|
|
76
|
+
messageChannel.close();
|
|
77
|
+
},
|
|
78
|
+
};
|
|
79
|
+
});
|
|
80
|
+
observable.subscribe(setToStorage);
|
|
81
|
+
return this.resourceManager.useObservable(`useStoredState-${key}`, observable, () => this.updateComponent());
|
|
82
|
+
},
|
|
83
|
+
useDisposable: this.resourceManager.useDisposable.bind(this.resourceManager),
|
|
84
|
+
};
|
|
85
|
+
return renderOptions;
|
|
86
|
+
};
|
|
87
|
+
this.cleanup = undefined;
|
|
88
|
+
}
|
|
17
89
|
connectedCallback() {
|
|
18
90
|
o.onAttach && o.onAttach(this.getRenderOptions());
|
|
19
91
|
this.callConstructed();
|
|
20
92
|
}
|
|
21
93
|
disconnectedCallback() {
|
|
22
94
|
o.onDetach && o.onDetach(this.getRenderOptions());
|
|
23
|
-
|
|
95
|
+
this.resourceManager.dispose();
|
|
24
96
|
this.cleanup && this.cleanup();
|
|
25
97
|
}
|
|
26
|
-
createResources() {
|
|
27
|
-
this.resources.push(...(o.resources?.(this.getRenderOptions()) || []));
|
|
28
|
-
}
|
|
29
98
|
/**
|
|
30
99
|
* Updates the component in the DOM.
|
|
31
100
|
*/
|
|
32
101
|
updateComponent() {
|
|
33
102
|
const renderResult = this.render(this.getRenderOptions());
|
|
34
|
-
if (renderResult === null) {
|
|
103
|
+
if (renderResult === null || renderResult === undefined) {
|
|
35
104
|
this.innerHTML = '';
|
|
36
105
|
}
|
|
37
|
-
if (typeof renderResult === 'string') {
|
|
106
|
+
if (typeof renderResult === 'string' || typeof renderResult === 'number') {
|
|
38
107
|
this.innerHTML = renderResult;
|
|
39
108
|
}
|
|
40
|
-
if (renderResult instanceof DocumentFragment) {
|
|
41
|
-
this.replaceChildren(...renderResult.children);
|
|
42
|
-
}
|
|
43
109
|
if (renderResult instanceof HTMLElement) {
|
|
44
110
|
this.replaceChildren(renderResult);
|
|
45
111
|
}
|
|
112
|
+
if (renderResult instanceof DocumentFragment) {
|
|
113
|
+
this.replaceChildren(renderResult);
|
|
114
|
+
}
|
|
46
115
|
}
|
|
47
116
|
/**
|
|
48
117
|
* Finialize the component initialization after it gets the Props. Called by the framework internally
|
|
49
118
|
*/
|
|
50
119
|
callConstructed() {
|
|
51
|
-
;
|
|
52
|
-
o.getInitialState &&
|
|
53
|
-
(this.state = o.getInitialState({ props: { ...this.props }, injector: this.injector }));
|
|
54
120
|
this.updateComponent();
|
|
55
|
-
this.createResources();
|
|
56
121
|
const cleanupResult = o.constructed && o.constructed(this.getRenderOptions());
|
|
57
122
|
if (cleanupResult instanceof Promise) {
|
|
58
123
|
cleanupResult.then((cleanup) => (this.cleanup = cleanup));
|
|
@@ -75,10 +140,6 @@ const Shade = (o) => {
|
|
|
75
140
|
if (this._injector) {
|
|
76
141
|
return this._injector;
|
|
77
142
|
}
|
|
78
|
-
const fromState = this.state?.injector;
|
|
79
|
-
if (fromState && fromState instanceof inject_1.Injector) {
|
|
80
|
-
return fromState;
|
|
81
|
-
}
|
|
82
143
|
const fromProps = this.props?.injector;
|
|
83
144
|
if (fromProps && fromProps instanceof inject_1.Injector) {
|
|
84
145
|
return fromProps;
|
|
@@ -94,57 +155,6 @@ const Shade = (o) => {
|
|
|
94
155
|
set injector(i) {
|
|
95
156
|
this._injector = i;
|
|
96
157
|
}
|
|
97
|
-
constructor(_props) {
|
|
98
|
-
super();
|
|
99
|
-
this.compareState = o.compareState ||
|
|
100
|
-
(({ oldState, newState }) => Object.entries(oldState).some(([key, value]) => value !== newState[key]) ||
|
|
101
|
-
Object.entries(newState).some(([key, value]) => value !== oldState[key]));
|
|
102
|
-
/**
|
|
103
|
-
* @param options Options for rendering the component
|
|
104
|
-
* @returns the JSX element
|
|
105
|
-
*/
|
|
106
|
-
this.render = (options) => o.render(options);
|
|
107
|
-
/**
|
|
108
|
-
* @returns values for the current render options
|
|
109
|
-
*/
|
|
110
|
-
this.getRenderOptions = () => {
|
|
111
|
-
const props = { ...this.props };
|
|
112
|
-
const getState = () => ({ ...this.state });
|
|
113
|
-
const updateState = (stateChanges, skipRender) => {
|
|
114
|
-
const oldState = { ...this.state };
|
|
115
|
-
const newState = { ...oldState, ...stateChanges };
|
|
116
|
-
this.state = newState;
|
|
117
|
-
if (!skipRender &&
|
|
118
|
-
this.compareState({
|
|
119
|
-
oldState,
|
|
120
|
-
newState,
|
|
121
|
-
props,
|
|
122
|
-
element: this,
|
|
123
|
-
injector: this.injector,
|
|
124
|
-
})) {
|
|
125
|
-
this.updateComponent();
|
|
126
|
-
}
|
|
127
|
-
};
|
|
128
|
-
const returnValue = {
|
|
129
|
-
...{
|
|
130
|
-
props,
|
|
131
|
-
injector: this.injector,
|
|
132
|
-
children: this.shadeChildren,
|
|
133
|
-
element: this,
|
|
134
|
-
},
|
|
135
|
-
...(o.getInitialState
|
|
136
|
-
? {
|
|
137
|
-
getState,
|
|
138
|
-
updateState,
|
|
139
|
-
}
|
|
140
|
-
: {}),
|
|
141
|
-
};
|
|
142
|
-
return returnValue;
|
|
143
|
-
};
|
|
144
|
-
this.cleanup = undefined;
|
|
145
|
-
this.resources = [];
|
|
146
|
-
this.props = _props;
|
|
147
|
-
}
|
|
148
158
|
});
|
|
149
159
|
}
|
|
150
160
|
else {
|
|
@@ -154,7 +164,7 @@ const Shade = (o) => {
|
|
|
154
164
|
const el = document.createElement(customElementName, {
|
|
155
165
|
...props,
|
|
156
166
|
});
|
|
157
|
-
el.props = props;
|
|
167
|
+
el.props = props || {};
|
|
158
168
|
el.shadeChildren = children;
|
|
159
169
|
return el;
|
|
160
170
|
};
|
package/dist/shade.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shade.js","sourceRoot":"","sources":["../src/shade.ts"],"names":[],"mappings":";;;AACA,8CAA4C;
|
|
1
|
+
{"version":3,"file":"shade.js","sourceRoot":"","sources":["../src/shade.ts"],"names":[],"mappings":";;;AACA,4CAAkD;AAClD,8CAA4C;AAE5C,kEAA6D;AAC7D,yCAA4C;AAoC5C;;;;;GAKG;AACI,MAAM,KAAK,GAAG,CAAS,CAAuB,EAAE,EAAE;IACvD,8BAA8B;IAC9B,MAAM,iBAAiB,GAAG,CAAC,CAAC,aAAa,CAAA;IAEzC,MAAM,QAAQ,GAAG,cAAc,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAA;IACtD,IAAI,CAAC,QAAQ,EAAE;QACb,cAAc,CAAC,MAAM,CACnB,iBAAiB,EACjB,KAAM,SAAQ,WAAW;YAAzB;;gBACS,oBAAe,GAAG,IAAI,kCAAe,EAAE,CAAA;gBAuB9C;;;mBAGG;gBACI,WAAM,GAAG,CAAC,OAA8B,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;gBAErE;;mBAEG;gBACK,qBAAgB,GAAG,GAA0B,EAAE;oBACrD,MAAM,aAAa,GAA0B;wBAC3C,KAAK,EAAE,IAAI,CAAC,KAAK;wBACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ;wBAEvB,QAAQ,EAAE,IAAI,CAAC,aAAa;wBAC5B,OAAO,EAAE,IAAI;wBACb,aAAa,EAAE,CAAC,GAAG,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,EAAE,CACpD,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,GAAG,EAAE,UAAU,EAAE,QAAQ,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,EAAE,OAAO,CAAC;wBAC1G,QAAQ,EAAE,CAAC,GAAG,EAAE,YAAY,EAAE,EAAE,CAC9B,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,GAAG,EAAE,YAAY,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;wBACnF,cAAc,EAAE,CAAC,GAAG,EAAE,YAAY,EAAE,EAAE,CACpC,IAAI,CAAC,eAAe,CAAC,aAAa,CAChC,kBAAkB,GAAG,EAAE,EACvB,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,0BAAe,CAAC,CAAC,cAAc,CAAC,GAAG,EAAE,YAAY,CAAC,EAC5E,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,EAAE,CAC7B;wBAEH,cAAc,EAAE,CAAI,GAAW,EAAE,YAAe,EAAE,WAAW,GAAG,YAAY,EAAE,EAAE;4BAC9E,MAAM,cAAc,GAAG,GAAG,EAAE;gCAC1B,MAAM,KAAK,GAAG,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,CAAA;gCACvC,OAAO,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,YAAY,CAAA;4BACjD,CAAC,CAAA;4BAED,MAAM,YAAY,GAAG,CAAC,KAAQ,EAAE,EAAE;gCAChC,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,EAAE;oCACvD,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAA;oCACtC,WAAW,EAAE,OAAO,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAA;iCACpC;gCACD,IAAI,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;oCACnE,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;iCAC3B;4BACH,CAAC,CAAA;4BAED,MAAM,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CACnD,kBAAkB,GAAG,EAAE,EACvB,GAAG,EAAE,CAAC,IAAI,uBAAe,CAAC,cAAc,EAAE,CAAC,CAC5C,CAAA;4BAED,MAAM,sBAAsB,GAAG,CAAC,CAAe,EAAE,EAAE;gCACjD,CAAC,CAAC,GAAG,KAAK,GAAG;oCACX,CAAC,CAAC,WAAW,KAAK,WAAW;oCAC7B,YAAY,CAAC,CAAC,CAAC,CAAC,QAAQ,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,IAAI,YAAY,CAAC,CAAA;4BACxE,CAAC,CAAA;4BAED,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,kBAAkB,GAAG,gBAAgB,EAAE,GAAG,EAAE;gCAC7E,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,sBAAsB,CAAC,CAAA;gCAC1D,MAAM,WAAW,GAAG,kCAAkC,CAAA;gCACtD,MAAM,cAAc,GAAG,IAAI,gBAAgB,CAAC,WAAW,CAAC,CAAA;gCACxD,cAAc,CAAC,SAAS,GAAG,CAAC,CAAC,EAAE,EAAE;oCAC/B,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,KAAK,GAAG,EAAE;wCACtB,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;qCAC3B;gCACH,CAAC,CAAA;gCACD,MAAM,YAAY,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;oCAClD,cAAc,CAAC,WAAW,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,CAAA;gCAC5C,CAAC,CAAC,CAAA;gCAEF,OAAO;oCACL,OAAO,EAAE,GAAG,EAAE;wCACZ,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,sBAAsB,CAAC,CAAA;wCAC7D,YAAY,CAAC,OAAO,EAAE,CAAA;wCACtB,cAAc,CAAC,KAAK,EAAE,CAAA;oCACxB,CAAC;iCACF,CAAA;4BACH,CAAC,CAAC,CAAA;4BAEF,UAAU,CAAC,SAAS,CAAC,YAAY,CAAC,CAAA;4BAElC,OAAO,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,kBAAkB,GAAG,EAAE,EAAE,UAAU,EAAE,GAAG,EAAE,CAClF,IAAI,CAAC,eAAe,EAAE,CACvB,CAAA;wBACH,CAAC;wBACD,aAAa,EAAE,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC;qBAC7E,CAAA;oBAED,OAAO,aAAsC,CAAA;gBAC/C,CAAC,CAAA;gBAsCO,YAAO,GAAwB,SAAS,CAAA;YAoClD,CAAC;YArLQ,iBAAiB;gBACtB,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAA;gBACjD,IAAI,CAAC,eAAe,EAAE,CAAA;YACxB,CAAC;YAEM,oBAAoB;gBACzB,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAA;gBACjD,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAA;gBAC9B,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,EAAE,CAAA;YAChC,CAAC;YAoGD;;eAEG;YACI,eAAe;gBACpB,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAA;gBAEzD,IAAI,YAAY,KAAK,IAAI,IAAI,YAAY,KAAK,SAAS,EAAE;oBACvD,IAAI,CAAC,SAAS,GAAG,EAAE,CAAA;iBACpB;gBAED,IAAI,OAAO,YAAY,KAAK,QAAQ,IAAI,OAAO,YAAY,KAAK,QAAQ,EAAE;oBACxE,IAAI,CAAC,SAAS,GAAG,YAAY,CAAA;iBAC9B;gBAED,IAAI,YAAY,YAAY,WAAW,EAAE;oBACvC,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,CAAA;iBACnC;gBACD,IAAI,YAAY,YAAY,gBAAgB,EAAE;oBAC5C,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,CAAA;iBACnC;YACH,CAAC;YAED;;eAEG;YACI,eAAe;gBACpB,IAAI,CAAC,eAAe,EAAE,CAAA;gBACtB,MAAM,aAAa,GAAG,CAAC,CAAC,WAAW,IAAI,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAA;gBAC7E,IAAI,aAAa,YAAY,OAAO,EAAE;oBACpC,aAAa,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,CAAC,CAAA;iBAC1D;qBAAM;oBACL,yBAAyB;oBACzB,IAAI,CAAC,OAAO,GAAG,aAAa,CAAA;iBAC7B;YACH,CAAC;YAMO,qBAAqB;gBAC3B,IAAI,MAAM,GAAG,IAAI,CAAC,aAAa,CAAA;gBAC/B,OAAO,MAAM,EAAE;oBACb,IAAK,MAAsB,CAAC,QAAQ,EAAE;wBACpC,OAAQ,MAAsB,CAAC,QAAQ,CAAA;qBACxC;oBACD,MAAM,GAAG,MAAM,CAAC,aAAa,CAAA;iBAC9B;YACH,CAAC;YAED,IAAW,QAAQ;gBACjB,IAAI,IAAI,CAAC,SAAS,EAAE;oBAClB,OAAO,IAAI,CAAC,SAAS,CAAA;iBACtB;gBAED,MAAM,SAAS,GAAI,IAAI,CAAC,KAAa,EAAE,QAAQ,CAAA;gBAC/C,IAAI,SAAS,IAAI,SAAS,YAAY,iBAAQ,EAAE;oBAC9C,OAAO,SAAS,CAAA;iBACjB;gBAED,MAAM,UAAU,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAA;gBAC/C,IAAI,UAAU,EAAE;oBACd,IAAI,CAAC,SAAS,GAAG,UAAU,CAAA;oBAC3B,OAAO,UAAU,CAAA;iBAClB;gBACD,wDAAwD;gBACxD,OAAO,IAAI,iBAAQ,EAAE,CAAA;YACvB,CAAC;YAED,IAAW,QAAQ,CAAC,CAAW;gBAC7B,IAAI,CAAC,SAAS,GAAG,CAAC,CAAA;YACpB,CAAC;SACF,CACF,CAAA;KACF;SAAM;QACL,MAAM,KAAK,CAAC,wCAAwC,CAAC,CAAC,aAAa,gCAAgC,CAAC,CAAA;KACrG;IAED,OAAO,CAAC,KAAa,EAAE,QAAsB,EAAE,EAAE;QAC/C,MAAM,EAAE,GAAG,QAAQ,CAAC,aAAa,CAAC,iBAAiB,EAAE;YACnD,GAAI,KAAyC;SAC9C,CAAwB,CAAA;QACzB,EAAE,CAAC,KAAK,GAAG,KAAK,IAAK,EAAa,CAAA;QAClC,EAAE,CAAC,aAAa,GAAG,QAAQ,CAAA;QAC3B,OAAO,EAAiB,CAAA;IAC1B,CAAC,CAAA;AACH,CAAC,CAAA;AA9MY,QAAA,KAAK,SA8MjB"}
|