@furystack/shades 6.1.4 → 7.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.
Files changed (67) hide show
  1. package/dist/component-factory.spec.js +6 -6
  2. package/dist/component-factory.spec.js.map +1 -1
  3. package/dist/components/lazy-load.js +17 -14
  4. package/dist/components/lazy-load.js.map +1 -1
  5. package/dist/components/route-link.js +7 -3
  6. package/dist/components/route-link.js.map +1 -1
  7. package/dist/components/route-link.spec.js +2 -2
  8. package/dist/components/route-link.spec.js.map +1 -1
  9. package/dist/components/router.js +25 -26
  10. package/dist/components/router.js.map +1 -1
  11. package/dist/components/router.spec.js +2 -2
  12. package/dist/components/router.spec.js.map +1 -1
  13. package/dist/models/render-options.js +23 -0
  14. package/dist/models/render-options.js.map +1 -1
  15. package/dist/services/location-service.js +16 -4
  16. package/dist/services/location-service.js.map +1 -1
  17. package/dist/services/location-service.spec.js +1 -1
  18. package/dist/services/location-service.spec.js.map +1 -1
  19. package/dist/services/resource-manager.js +48 -0
  20. package/dist/services/resource-manager.js.map +1 -0
  21. package/dist/services/resource-manager.spec.js +32 -0
  22. package/dist/services/resource-manager.spec.js.map +1 -0
  23. package/dist/shade-component.js +28 -14
  24. package/dist/shade-component.js.map +1 -1
  25. package/dist/shade-resources.integration.spec.js +7 -8
  26. package/dist/shade-resources.integration.spec.js.map +1 -1
  27. package/dist/shade.js +34 -75
  28. package/dist/shade.js.map +1 -1
  29. package/dist/shades.integration.spec.js +197 -187
  30. package/dist/shades.integration.spec.js.map +1 -1
  31. package/package.json +5 -5
  32. package/src/component-factory.spec.tsx +7 -7
  33. package/src/components/lazy-load.tsx +19 -15
  34. package/src/components/route-link.spec.tsx +2 -2
  35. package/src/components/route-link.tsx +11 -10
  36. package/src/components/router.spec.tsx +2 -2
  37. package/src/components/router.tsx +32 -32
  38. package/src/jsx.ts +3 -2
  39. package/src/models/render-options.ts +37 -9
  40. package/src/services/location-service.spec.ts +1 -1
  41. package/src/services/location-service.tsx +18 -4
  42. package/src/services/resource-manager.spec.ts +33 -0
  43. package/src/services/resource-manager.ts +60 -0
  44. package/src/shade-component.ts +35 -15
  45. package/src/shade-resources.integration.spec.tsx +8 -14
  46. package/src/shade.ts +35 -112
  47. package/src/shades.integration.spec.tsx +265 -252
  48. package/types/components/lazy-load.d.ts +1 -1
  49. package/types/components/lazy-load.d.ts.map +1 -1
  50. package/types/components/route-link.d.ts +1 -1
  51. package/types/components/route-link.d.ts.map +1 -1
  52. package/types/components/router.d.ts +6 -8
  53. package/types/components/router.d.ts.map +1 -1
  54. package/types/jsx.d.ts +3 -2
  55. package/types/jsx.d.ts.map +1 -1
  56. package/types/models/render-options.d.ts +7 -7
  57. package/types/models/render-options.d.ts.map +1 -1
  58. package/types/services/location-service.d.ts +12 -1
  59. package/types/services/location-service.d.ts.map +1 -1
  60. package/types/services/resource-manager.d.ts +16 -0
  61. package/types/services/resource-manager.d.ts.map +1 -0
  62. package/types/services/resource-manager.spec.d.ts +2 -0
  63. package/types/services/resource-manager.spec.d.ts.map +1 -0
  64. package/types/shade-component.d.ts +16 -5
  65. package/types/shade-component.d.ts.map +1 -1
  66. package/types/shade.d.ts +8 -27
  67. package/types/shade.d.ts.map +1 -1
@@ -1,6 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const inject_1 = require("@furystack/inject");
4
+ const utils_1 = require("@furystack/utils");
4
5
  const util_1 = require("util");
5
6
  global.TextEncoder = util_1.TextEncoder;
6
7
  global.TextDecoder = util_1.TextDecoder;
@@ -32,210 +33,219 @@ describe('Shades integration tests', () => {
32
33
  });
33
34
  expect(document.body.innerHTML).toBe('<div id="root"><shades-string-render-result>Hello</shades-string-render-result></div>');
34
35
  });
35
- it('Should mount a custom component with null render result', () => {
36
- const injector = new inject_1.Injector();
37
- const rootElement = document.getElementById('root');
38
- const ExampleComponent = (0, shade_1.Shade)({ render: () => null, shadowDomName: 'shades-null-render-result' });
39
- (0, initialize_1.initializeShadeRoot)({
40
- injector,
41
- rootElement,
42
- jsxElement: (0, shade_component_1.createComponent)(ExampleComponent, null),
36
+ it('Should mount a custom component with null render result', async () => {
37
+ await (0, utils_1.usingAsync)(new inject_1.Injector(), async (injector) => {
38
+ const rootElement = document.getElementById('root');
39
+ const ExampleComponent = (0, shade_1.Shade)({ render: () => null, shadowDomName: 'shades-null-render-result' });
40
+ (0, initialize_1.initializeShadeRoot)({
41
+ injector,
42
+ rootElement,
43
+ jsxElement: (0, shade_component_1.createComponent)(ExampleComponent, null),
44
+ });
45
+ expect(document.body.innerHTML).toBe('<div id="root"><shades-null-render-result></shades-null-render-result></div>');
43
46
  });
44
- expect(document.body.innerHTML).toBe('<div id="root"><shades-null-render-result></shades-null-render-result></div>');
45
47
  });
46
- it('Should mount a custom component with a document fragment render result', () => {
47
- const injector = new inject_1.Injector();
48
- const rootElement = document.getElementById('root');
49
- const ExampleComponent = (0, shade_1.Shade)({
50
- render: () => ((0, shade_component_1.createComponent)(shade_component_1.createFragment, null,
51
- (0, shade_component_1.createComponent)("p", null, "1"),
52
- (0, shade_component_1.createComponent)("p", null, "2"))),
53
- shadowDomName: 'shades-fragment-render-result',
54
- });
55
- (0, initialize_1.initializeShadeRoot)({
56
- injector,
57
- rootElement,
58
- jsxElement: (0, shade_component_1.createComponent)(ExampleComponent, null),
59
- });
60
- expect(document.body.innerHTML).toBe('<div id="root"><shades-fragment-render-result><p>1</p><p>2</p></shades-fragment-render-result></div>');
61
- });
62
- it('Should mount a custom component with a nested document fragment render result', () => {
63
- const injector = new inject_1.Injector();
64
- const rootElement = document.getElementById('root');
65
- const ExampleComponent = (0, shade_1.Shade)({
66
- render: () => ((0, shade_component_1.createComponent)("p", null,
67
- (0, shade_component_1.createComponent)(shade_component_1.createFragment, null,
48
+ it('Should mount a custom component with a document fragment render result', async () => {
49
+ await (0, utils_1.usingAsync)(new inject_1.Injector(), async (injector) => {
50
+ const rootElement = document.getElementById('root');
51
+ const ExampleComponent = (0, shade_1.Shade)({
52
+ render: () => ((0, shade_component_1.createComponent)(shade_component_1.createComponent, null,
68
53
  (0, shade_component_1.createComponent)("p", null, "1"),
69
- (0, shade_component_1.createComponent)("p", null, "2")))),
70
- shadowDomName: 'shades-fragment-render-result-nested',
54
+ (0, shade_component_1.createComponent)("p", null, "2"))),
55
+ shadowDomName: 'shades-fragment-render-result',
56
+ });
57
+ (0, initialize_1.initializeShadeRoot)({
58
+ injector,
59
+ rootElement,
60
+ jsxElement: (0, shade_component_1.createComponent)(ExampleComponent, null),
61
+ });
62
+ expect(document.body.innerHTML).toBe('<div id="root"><shades-fragment-render-result><p>1</p><p>2</p></shades-fragment-render-result></div>');
71
63
  });
72
- (0, initialize_1.initializeShadeRoot)({
73
- injector,
74
- rootElement,
75
- jsxElement: (0, shade_component_1.createComponent)(ExampleComponent, null),
76
- });
77
- expect(document.body.innerHTML).toBe('<div id="root"><shades-fragment-render-result-nested><p><p>1</p><p>2</p></p></shades-fragment-render-result-nested></div>');
78
64
  });
79
- it('Should mount a custom component with a document fragment that contains custom components', () => {
80
- const injector = new inject_1.Injector();
81
- const rootElement = document.getElementById('root');
82
- const CustomComponent = (0, shade_1.Shade)({
83
- shadowDomName: 'shades-fragment-test-custom-component',
84
- render: () => (0, shade_component_1.createComponent)("p", null, "Hello"),
85
- });
86
- const ExampleComponent = (0, shade_1.Shade)({
87
- render: () => ((0, shade_component_1.createComponent)(shade_component_1.createFragment, null,
88
- (0, shade_component_1.createComponent)(CustomComponent, null),
89
- (0, shade_component_1.createComponent)(CustomComponent, null))),
90
- shadowDomName: 'shades-fragment-render-result-2',
65
+ it('Should mount a custom component with a nested document fragment render result', async () => {
66
+ await (0, utils_1.usingAsync)(new inject_1.Injector(), async (injector) => {
67
+ const rootElement = document.getElementById('root');
68
+ const ExampleComponent = (0, shade_1.Shade)({
69
+ render: () => ((0, shade_component_1.createComponent)("p", null,
70
+ (0, shade_component_1.createComponent)(shade_component_1.createComponent, null,
71
+ (0, shade_component_1.createComponent)("p", null, "1"),
72
+ (0, shade_component_1.createComponent)("p", null, "2")))),
73
+ shadowDomName: 'shades-fragment-render-result-nested',
74
+ });
75
+ (0, initialize_1.initializeShadeRoot)({
76
+ injector,
77
+ rootElement,
78
+ jsxElement: (0, shade_component_1.createComponent)(ExampleComponent, null),
79
+ });
80
+ expect(document.body.innerHTML).toBe('<div id="root"><shades-fragment-render-result-nested><p><p>1</p><p>2</p></p></shades-fragment-render-result-nested></div>');
91
81
  });
92
- (0, initialize_1.initializeShadeRoot)({
93
- injector,
94
- rootElement,
95
- jsxElement: (0, shade_component_1.createComponent)(ExampleComponent, null),
96
- });
97
- expect(document.body.innerHTML).toBe('<div id="root"><shades-fragment-render-result-2><shades-fragment-test-custom-component><p>Hello</p></shades-fragment-test-custom-component><shades-fragment-test-custom-component><p>Hello</p></shades-fragment-test-custom-component></shades-fragment-render-result-2></div>');
98
82
  });
99
- it('Should mount nested Shades components', () => {
100
- const injector = new inject_1.Injector();
101
- const rootElement = document.getElementById('root');
102
- const ExampleComponent = (0, shade_1.Shade)({
103
- render: ({ children }) => (0, shade_component_1.createComponent)("div", null, children),
104
- shadowDomName: 'shades-example-2',
105
- });
106
- const ExampleSubs = (0, shade_1.Shade)({
107
- render: ({ props }) => (0, shade_component_1.createComponent)("div", null, props.no),
108
- shadowDomName: 'shades-example-sub',
83
+ it('Should mount a custom component with a document fragment that contains custom components', async () => {
84
+ await (0, utils_1.usingAsync)(new inject_1.Injector(), async (injector) => {
85
+ const rootElement = document.getElementById('root');
86
+ const CustomComponent = (0, shade_1.Shade)({
87
+ shadowDomName: 'shades-fragment-test-custom-component',
88
+ render: () => (0, shade_component_1.createComponent)("p", null, "Hello"),
89
+ });
90
+ const ExampleComponent = (0, shade_1.Shade)({
91
+ render: () => ((0, shade_component_1.createComponent)(shade_component_1.createComponent, null,
92
+ (0, shade_component_1.createComponent)(CustomComponent, null),
93
+ (0, shade_component_1.createComponent)(CustomComponent, null))),
94
+ shadowDomName: 'shades-fragment-render-result-2',
95
+ });
96
+ (0, initialize_1.initializeShadeRoot)({
97
+ injector,
98
+ rootElement,
99
+ jsxElement: (0, shade_component_1.createComponent)(ExampleComponent, null),
100
+ });
101
+ expect(document.body.innerHTML).toBe('<div id="root"><shades-fragment-render-result-2><shades-fragment-test-custom-component><p>Hello</p></shades-fragment-test-custom-component><shades-fragment-test-custom-component><p>Hello</p></shades-fragment-test-custom-component></shades-fragment-render-result-2></div>');
109
102
  });
110
- (0, initialize_1.initializeShadeRoot)({
111
- injector,
112
- rootElement,
113
- jsxElement: ((0, shade_component_1.createComponent)(ExampleComponent, null,
114
- (0, shade_component_1.createComponent)(ExampleSubs, { no: 1 }),
115
- (0, shade_component_1.createComponent)(ExampleSubs, { no: 2 }),
116
- (0, shade_component_1.createComponent)(ExampleSubs, { no: 3 }))),
117
- });
118
- expect(document.body.innerHTML).toBe('<div id="root"><shades-example-2><div><shades-example-sub><div></div></shades-example-sub><shades-example-sub><div></div></shades-example-sub><shades-example-sub><div></div></shades-example-sub></div></shades-example-2></div>');
119
103
  });
120
- it("Should execute the constructed and constructed's cleanup callback", () => {
121
- const injector = new inject_1.Injector();
122
- const rootElement = document.getElementById('root');
123
- const cleanup = jest.fn();
124
- const constructed = jest.fn(() => cleanup);
125
- const ExampleComponent = (0, shade_1.Shade)({
126
- constructed,
127
- shadowDomName: 'example-component-1',
128
- render: () => (0, shade_component_1.createComponent)("div", null, "Hello"),
129
- });
130
- (0, initialize_1.initializeShadeRoot)({
131
- injector,
132
- rootElement,
133
- jsxElement: (0, shade_component_1.createComponent)(ExampleComponent, null),
104
+ it('Should mount nested Shades components', async () => {
105
+ await (0, utils_1.usingAsync)(new inject_1.Injector(), async (injector) => {
106
+ const rootElement = document.getElementById('root');
107
+ const ExampleComponent = (0, shade_1.Shade)({
108
+ render: ({ children }) => (0, shade_component_1.createComponent)("div", null, children),
109
+ shadowDomName: 'shades-example-2',
110
+ });
111
+ const ExampleSubs = (0, shade_1.Shade)({
112
+ render: ({ props }) => (0, shade_component_1.createComponent)("div", null, props.no),
113
+ shadowDomName: 'shades-example-sub',
114
+ });
115
+ (0, initialize_1.initializeShadeRoot)({
116
+ injector,
117
+ rootElement,
118
+ jsxElement: ((0, shade_component_1.createComponent)(ExampleComponent, null,
119
+ (0, shade_component_1.createComponent)(ExampleSubs, { no: 1 }),
120
+ (0, shade_component_1.createComponent)(ExampleSubs, { no: 2 }),
121
+ (0, shade_component_1.createComponent)(ExampleSubs, { no: 3 }))),
122
+ });
123
+ expect(document.body.innerHTML).toBe('<div id="root"><shades-example-2><div><shades-example-sub><div>1</div></shades-example-sub><shades-example-sub><div>2</div></shades-example-sub><shades-example-sub><div>3</div></shades-example-sub></div></shades-example-2></div>');
134
124
  });
135
- expect(constructed).toBeCalled();
136
- expect(cleanup).not.toBeCalled();
137
- document.body.innerHTML = '';
138
- expect(cleanup).toBeCalled();
139
125
  });
140
- it('Should execute the onAttach and onDetach callbacks', () => {
141
- const injector = new inject_1.Injector();
142
- const rootElement = document.getElementById('root');
143
- const onAttach = jest.fn();
144
- const onDetach = jest.fn();
145
- const ExampleComponent = (0, shade_1.Shade)({
146
- onAttach,
147
- onDetach,
148
- shadowDomName: 'example-component-2',
149
- render: () => (0, shade_component_1.createComponent)("div", null, "Hello"),
150
- });
151
- (0, initialize_1.initializeShadeRoot)({
152
- injector,
153
- rootElement,
154
- jsxElement: (0, shade_component_1.createComponent)(ExampleComponent, null),
126
+ it("Should execute the constructed and constructed's cleanup callback", async () => {
127
+ await (0, utils_1.usingAsync)(new inject_1.Injector(), async (injector) => {
128
+ const rootElement = document.getElementById('root');
129
+ const cleanup = jest.fn();
130
+ const constructed = jest.fn(() => cleanup);
131
+ const ExampleComponent = (0, shade_1.Shade)({
132
+ constructed,
133
+ shadowDomName: 'example-component-1',
134
+ render: () => (0, shade_component_1.createComponent)("div", null, "Hello"),
135
+ });
136
+ (0, initialize_1.initializeShadeRoot)({
137
+ injector,
138
+ rootElement,
139
+ jsxElement: (0, shade_component_1.createComponent)(ExampleComponent, null),
140
+ });
141
+ expect(constructed).toBeCalled();
142
+ expect(cleanup).not.toBeCalled();
143
+ document.body.innerHTML = '';
144
+ expect(cleanup).toBeCalled();
155
145
  });
156
- expect(onAttach).toBeCalled();
157
- expect(onDetach).not.toBeCalled();
158
- document.body.innerHTML = '';
159
- expect(onDetach).toBeCalled();
160
146
  });
161
- it('Should update state', () => {
162
- const injector = new inject_1.Injector();
163
- const rootElement = document.getElementById('root');
164
- const ExampleComponent = (0, shade_1.Shade)({
165
- shadowDomName: 'example-component-3',
166
- getInitialState: () => ({ count: 0 }),
167
- render: ({ getState, updateState }) => {
168
- const { count } = getState();
169
- return ((0, shade_component_1.createComponent)("div", null,
170
- "Count is ",
171
- getState().count.toString(),
172
- (0, shade_component_1.createComponent)("button", { id: "plus", onclick: () => updateState({ count: count + 1 }) }, "+"),
173
- (0, shade_component_1.createComponent)("button", { id: "minus", onclick: () => updateState({ count: count - 1 }) }, "-")));
174
- },
175
- });
176
- (0, initialize_1.initializeShadeRoot)({
177
- injector,
178
- rootElement,
179
- jsxElement: (0, shade_component_1.createComponent)(ExampleComponent, null),
147
+ it('Should execute the onAttach and onDetach callbacks', async () => {
148
+ await (0, utils_1.usingAsync)(new inject_1.Injector(), async (injector) => {
149
+ const rootElement = document.getElementById('root');
150
+ const onAttach = jest.fn();
151
+ const onDetach = jest.fn();
152
+ const ExampleComponent = (0, shade_1.Shade)({
153
+ onAttach,
154
+ onDetach,
155
+ shadowDomName: 'example-component-2',
156
+ render: () => (0, shade_component_1.createComponent)("div", null, "Hello"),
157
+ });
158
+ (0, initialize_1.initializeShadeRoot)({
159
+ injector,
160
+ rootElement,
161
+ jsxElement: (0, shade_component_1.createComponent)(ExampleComponent, null),
162
+ });
163
+ expect(onAttach).toBeCalled();
164
+ expect(onDetach).not.toBeCalled();
165
+ document.body.innerHTML = '';
166
+ expect(onDetach).toBeCalled();
180
167
  });
181
- const plus = () => document.getElementById('plus')?.click();
182
- const minus = () => document.getElementById('minus')?.click();
183
- const expectCount = (count) => expect(document.body.innerHTML).toContain(`Count is ${count}`);
184
- expectCount(0);
185
- plus();
186
- expectCount(1);
187
- plus();
188
- expectCount(2);
189
- minus();
190
- minus();
191
- expectCount(0);
192
168
  });
193
- it('Should allow children update after unmount and remount', () => {
194
- const injector = new inject_1.Injector();
195
- const rootElement = document.getElementById('root');
196
- const Parent = (0, shade_1.Shade)({
197
- shadowDomName: 'shade-remount-parent',
198
- getInitialState: () => ({ areChildrenVisible: true }),
199
- render: ({ children, getState, updateState }) => ((0, shade_component_1.createComponent)("div", null,
200
- (0, shade_component_1.createComponent)("button", { id: "showHideChildren", onclick: () => {
201
- updateState({ areChildrenVisible: !getState().areChildrenVisible });
202
- } }, "Toggle"),
203
- getState().areChildrenVisible ? children : (0, shade_component_1.createComponent)("div", null))),
204
- });
205
- const Child = (0, shade_1.Shade)({
206
- shadowDomName: 'example-remount-child',
207
- getInitialState: () => ({ count: 0 }),
208
- render: ({ getState, updateState }) => {
209
- const { count } = getState();
210
- return ((0, shade_component_1.createComponent)("div", null,
211
- "Count is ",
212
- getState().count.toString(),
213
- (0, shade_component_1.createComponent)("button", { id: "plus", onclick: () => updateState({ count: count + 1 }) }, "+"),
214
- (0, shade_component_1.createComponent)("button", { id: "minus", onclick: () => updateState({ count: count - 1 }) }, "-")));
215
- },
169
+ it('Should update state', async () => {
170
+ await (0, utils_1.usingAsync)(new inject_1.Injector(), async (injector) => {
171
+ const rootElement = document.getElementById('root');
172
+ const ExampleComponent = (0, shade_1.Shade)({
173
+ shadowDomName: 'example-component-3',
174
+ render: ({ useState }) => {
175
+ const [count, setCount] = useState('count', 0);
176
+ return ((0, shade_component_1.createComponent)("div", null,
177
+ "Count is ",
178
+ count,
179
+ (0, shade_component_1.createComponent)("button", { id: "plus", onclick: () => setCount(count + 1) }, "+"),
180
+ (0, shade_component_1.createComponent)("button", { id: "minus", onclick: () => setCount(count - 1) }, "-")));
181
+ },
182
+ });
183
+ (0, initialize_1.initializeShadeRoot)({
184
+ injector,
185
+ rootElement,
186
+ jsxElement: (0, shade_component_1.createComponent)(ExampleComponent, null),
187
+ });
188
+ const plus = () => document.getElementById('plus')?.click();
189
+ const minus = () => document.getElementById('minus')?.click();
190
+ const expectCount = (count) => expect(document.body.innerHTML).toContain(`Count is ${count}`);
191
+ expectCount(0);
192
+ plus();
193
+ expectCount(1);
194
+ plus();
195
+ expectCount(2);
196
+ minus();
197
+ minus();
198
+ expectCount(0);
216
199
  });
217
- (0, initialize_1.initializeShadeRoot)({
218
- injector,
219
- rootElement,
220
- jsxElement: ((0, shade_component_1.createComponent)(Parent, null,
221
- (0, shade_component_1.createComponent)(Child, null))),
200
+ });
201
+ it('Should allow children update after unmount and remount', async () => {
202
+ await (0, utils_1.usingAsync)(new inject_1.Injector(), async (injector) => {
203
+ const rootElement = document.getElementById('root');
204
+ const Parent = (0, shade_1.Shade)({
205
+ shadowDomName: 'shade-remount-parent',
206
+ render: ({ children, useState }) => {
207
+ const [areChildrenVisible, setAreChildrenVisible] = useState('areChildrenVisible', true);
208
+ return ((0, shade_component_1.createComponent)("div", null,
209
+ (0, shade_component_1.createComponent)("button", { id: "showHideChildren", onclick: () => {
210
+ setAreChildrenVisible(!areChildrenVisible);
211
+ } }, "Toggle"),
212
+ areChildrenVisible ? children : null));
213
+ },
214
+ });
215
+ const Child = (0, shade_1.Shade)({
216
+ shadowDomName: 'example-remount-child',
217
+ render: ({ useState }) => {
218
+ const [count, setCount] = useState('count', 0);
219
+ return ((0, shade_component_1.createComponent)("div", null,
220
+ "Count is ",
221
+ `${count}`,
222
+ (0, shade_component_1.createComponent)("button", { id: "plus", onclick: () => setCount(count + 1) }, "+"),
223
+ (0, shade_component_1.createComponent)("button", { id: "minus", onclick: () => setCount(count - 1) }, "-")));
224
+ },
225
+ });
226
+ (0, initialize_1.initializeShadeRoot)({
227
+ injector,
228
+ rootElement,
229
+ jsxElement: ((0, shade_component_1.createComponent)(Parent, null,
230
+ (0, shade_component_1.createComponent)(Child, null))),
231
+ });
232
+ const plus = () => document.getElementById('plus')?.click();
233
+ const minus = () => document.getElementById('minus')?.click();
234
+ const expectCount = (count) => expect(document.body.innerHTML).toContain(`Count is ${count}`);
235
+ const toggleChildren = () => document.getElementById('showHideChildren')?.click();
236
+ expectCount(0);
237
+ plus();
238
+ expectCount(1);
239
+ toggleChildren();
240
+ expect(document.getElementById('plus')).toBeNull();
241
+ toggleChildren();
242
+ expect(document.getElementById('plus')).toBeDefined();
243
+ expectCount(0);
244
+ plus();
245
+ expectCount(1);
246
+ minus();
247
+ expectCount(0);
222
248
  });
223
- const plus = () => document.getElementById('plus')?.click();
224
- const minus = () => document.getElementById('minus')?.click();
225
- const expectCount = (count) => expect(document.body.innerHTML).toContain(`Count is ${count}`);
226
- const toggleChildren = () => document.getElementById('showHideChildren')?.click();
227
- expectCount(0);
228
- plus();
229
- expectCount(1);
230
- toggleChildren();
231
- expect(document.getElementById('plus')).toBeNull();
232
- toggleChildren();
233
- expect(document.getElementById('plus')).toBeDefined();
234
- // expectCount(0)
235
- plus();
236
- expectCount(1);
237
- minus();
238
- expectCount(0);
239
249
  });
240
250
  });
241
251
  //# sourceMappingURL=shades.integration.spec.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"shades.integration.spec.js","sourceRoot":"","sources":["../src/shades.integration.spec.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"shades.integration.spec.js","sourceRoot":"","sources":["../src/shades.integration.spec.tsx"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@furystack/shades",
3
- "version": "6.1.4",
3
+ "version": "7.0.0",
4
4
  "description": "Google Authentication Provider for FuryStack",
5
5
  "main": "dist/index.js",
6
6
  "files": [
@@ -29,15 +29,15 @@
29
29
  },
30
30
  "homepage": "https://github.com/furystack/furystack",
31
31
  "devDependencies": {
32
- "@types/jest": "^29.2.5",
32
+ "@types/jest": "^29.2.6",
33
33
  "@types/jsdom": "^20.0.1",
34
34
  "@types/node": "^18.11.18",
35
35
  "jsdom": "^21.0.0"
36
36
  },
37
37
  "dependencies": {
38
- "@furystack/core": "^11.2.2",
39
- "@furystack/inject": "^7.1.4",
40
- "@furystack/utils": "^3.1.4",
38
+ "@furystack/core": "^11.2.3",
39
+ "@furystack/inject": "^7.1.5",
40
+ "@furystack/utils": "^3.1.5",
41
41
  "path-to-regexp": "^6.2.1",
42
42
  "semaphore-async-await": "^1.5.1"
43
43
  },
@@ -59,8 +59,7 @@ describe('Shades Component Factory', () => {
59
59
  )
60
60
 
61
61
  const shade = component.firstElementChild as JSX.Element
62
- expect(shade.props).toBe(null)
63
- expect(shade.state).toBe(undefined)
62
+ expect(shade.props).toEqual({})
64
63
  expect(shade.shadeChildren).toEqual([])
65
64
  })
66
65
 
@@ -81,17 +80,18 @@ describe('Shades Component Factory', () => {
81
80
  shade.callConstructed()
82
81
 
83
82
  expect(shade.props.foo).toEqual('example')
84
- expect(shade.state).toBe(undefined)
85
83
  expect(shade.shadeChildren).toEqual([])
86
84
 
87
85
  expect(shade.innerHTML).toBe('<div>example</div>')
88
86
  })
89
87
 
90
88
  it('Should render a component with state', () => {
91
- const Example = Shade<unknown, { foo: string }>({
92
- getInitialState: () => ({ foo: 'example' }),
89
+ const Example = Shade({
93
90
  shadowDomName: 'example-with-state',
94
- render: () => <div />,
91
+ render: ({ useState }) => {
92
+ useState('foo', 'example')
93
+ return <div />
94
+ },
95
95
  })
96
96
 
97
97
  const component = (
@@ -102,7 +102,7 @@ describe('Shades Component Factory', () => {
102
102
 
103
103
  const shade = component.firstElementChild as JSX.Element
104
104
  shade.callConstructed()
105
- expect(shade.state).toEqual({ foo: 'example' })
105
+ expect(shade.resourceManager.stateObservers.get('foo')?.getValue()).toEqual('example')
106
106
  expect(shade.shadeChildren).toEqual([])
107
107
  })
108
108
  })
@@ -11,36 +11,40 @@ export interface LazyLoadState {
11
11
  error?: unknown
12
12
  }
13
13
 
14
- export const LazyLoad = Shade<LazyLoadProps, LazyLoadState>({
15
- getInitialState: () => ({}),
14
+ export const LazyLoad = Shade<LazyLoadProps>({
16
15
  shadowDomName: 'lazy-load',
17
- constructed: async ({ props, updateState }) => {
16
+ constructed: async ({ props, useState }) => {
17
+ const [_component, setComponent] = useState<JSX.Element | undefined>('component', undefined)
18
+ const [_errorState, setErrorState] = useState<unknown | undefined>('error', undefined)
18
19
  try {
19
20
  const loaded = await props.component()
20
- updateState({ component: loaded })
21
+ setComponent(loaded)
21
22
  } catch (error) {
22
23
  if (props.error) {
23
- updateState({ error })
24
+ setErrorState(error)
24
25
  } else {
25
26
  throw error
26
27
  }
27
28
  }
28
29
  },
29
- render: ({ props, getState, updateState }) => {
30
- const currentState = getState()
31
- if (currentState.error && props.error) {
32
- return props.error(currentState.error, async () => {
30
+ render: ({ props, useState }) => {
31
+ const [error, setError] = useState<unknown | undefined>('error', undefined)
32
+ const [component, setComponent] = useState<JSX.Element | undefined>('component', undefined)
33
+
34
+ if (error && props.error) {
35
+ return props.error(error, async () => {
33
36
  try {
34
- updateState({ error: undefined, component: undefined })
37
+ setError(undefined)
38
+ setComponent(undefined)
35
39
  const loaded = await props.component()
36
- updateState({ component: loaded })
37
- } catch (error) {
38
- updateState({ error })
40
+ setComponent(loaded)
41
+ } catch (e) {
42
+ setError(e)
39
43
  }
40
44
  })
41
45
  }
42
- if (currentState.component) {
43
- return currentState.component
46
+ if (component) {
47
+ return component
44
48
  }
45
49
  return props.loader
46
50
  },
@@ -17,7 +17,7 @@ describe('RouteLink', () => {
17
17
 
18
18
  const onRouteChange = jest.fn()
19
19
 
20
- injector.getInstance(LocationService).onLocationChanged.subscribe(onRouteChange)
20
+ injector.getInstance(LocationService).onLocationPathChanged.subscribe(onRouteChange)
21
21
 
22
22
  initializeShadeRoot({
23
23
  injector,
@@ -29,7 +29,7 @@ describe('RouteLink', () => {
29
29
  ),
30
30
  })
31
31
  expect(document.body.innerHTML).toBe(
32
- '<div id="root"><route-link><a id="route" href="/subroute">Link</a></route-link></div>',
32
+ '<div id="root"><route-link id="route"><a href="/subroute" style="text-decoration: inherit;">Link</a></route-link></div>',
33
33
  )
34
34
  expect(onRouteChange).not.toBeCalled()
35
35
  document.getElementById('route')?.click()