@furystack/shades 3.6.3
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/LICENSE +339 -0
- package/README.md +42 -0
- package/dist/component-factory.spec.d.ts +2 -0
- package/dist/component-factory.spec.d.ts.map +1 -0
- package/dist/component-factory.spec.js +20 -0
- package/dist/component-factory.spec.js.map +1 -0
- package/dist/components/index.d.ts +4 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +7 -0
- package/dist/components/index.js.map +1 -0
- package/dist/components/lazy-load.d.ts +11 -0
- package/dist/components/lazy-load.d.ts.map +1 -0
- package/dist/components/lazy-load.js +42 -0
- package/dist/components/lazy-load.js.map +1 -0
- package/dist/components/route-link.d.ts +3 -0
- package/dist/components/route-link.d.ts.map +1 -0
- package/dist/components/route-link.js +17 -0
- package/dist/components/route-link.js.map +1 -0
- package/dist/components/router.d.ts +24 -0
- package/dist/components/router.d.ts.map +1 -0
- package/dist/components/router.js +50 -0
- package/dist/components/router.js.map +1 -0
- package/dist/index.d.ts +8 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +11 -0
- package/dist/index.js.map +1 -0
- package/dist/initialize.d.ts +8 -0
- package/dist/initialize.d.ts.map +1 -0
- package/dist/initialize.js +9 -0
- package/dist/initialize.js.map +1 -0
- package/dist/is-jsx-element.spec.d.ts +2 -0
- package/dist/is-jsx-element.spec.d.ts.map +1 -0
- package/dist/is-jsx-element.spec.js +18 -0
- package/dist/is-jsx-element.spec.js.map +1 -0
- package/dist/jsx.d.ts +528 -0
- package/dist/jsx.d.ts.map +1 -0
- package/dist/jsx.js +9 -0
- package/dist/jsx.js.map +1 -0
- package/dist/models/children-list.d.ts +2 -0
- package/dist/models/children-list.d.ts.map +1 -0
- package/dist/models/children-list.js +3 -0
- package/dist/models/children-list.js.map +1 -0
- package/dist/models/index.d.ts +6 -0
- package/dist/models/index.d.ts.map +1 -0
- package/dist/models/index.js +9 -0
- package/dist/models/index.js.map +1 -0
- package/dist/models/partial-element.d.ts +6 -0
- package/dist/models/partial-element.d.ts.map +1 -0
- package/dist/models/partial-element.js +3 -0
- package/dist/models/partial-element.js.map +1 -0
- package/dist/models/render-options.d.ts +13 -0
- package/dist/models/render-options.d.ts.map +1 -0
- package/dist/models/render-options.js +3 -0
- package/dist/models/render-options.js.map +1 -0
- package/dist/models/selection-state.d.ts +10 -0
- package/dist/models/selection-state.d.ts.map +1 -0
- package/dist/models/selection-state.js +3 -0
- package/dist/models/selection-state.js.map +1 -0
- package/dist/models/shade-component.d.ts +13 -0
- package/dist/models/shade-component.d.ts.map +1 -0
- package/dist/models/shade-component.js +14 -0
- package/dist/models/shade-component.js.map +1 -0
- package/dist/services/index.d.ts +3 -0
- package/dist/services/index.d.ts.map +1 -0
- package/dist/services/index.js +6 -0
- package/dist/services/index.js.map +1 -0
- package/dist/services/location-service.d.ts +10 -0
- package/dist/services/location-service.d.ts.map +1 -0
- package/dist/services/location-service.js +41 -0
- package/dist/services/location-service.js.map +1 -0
- package/dist/services/location-service.spec.d.ts +2 -0
- package/dist/services/location-service.spec.d.ts.map +1 -0
- package/dist/services/location-service.spec.js +18 -0
- package/dist/services/location-service.spec.js.map +1 -0
- package/dist/services/screen-service.d.ts +28 -0
- package/dist/services/screen-service.d.ts.map +1 -0
- package/dist/services/screen-service.js +52 -0
- package/dist/services/screen-service.js.map +1 -0
- package/dist/shade-component.d.ts +26 -0
- package/dist/shade-component.d.ts.map +1 -0
- package/dist/shade-component.js +72 -0
- package/dist/shade-component.js.map +1 -0
- package/dist/shade.d.ts +40 -0
- package/dist/shade.d.ts.map +1 -0
- package/dist/shade.js +138 -0
- package/dist/shade.js.map +1 -0
- package/package.json +41 -0
- package/src/component-factory.spec.tsx +22 -0
- package/src/components/index.ts +3 -0
- package/src/components/lazy-load.tsx +47 -0
- package/src/components/route-link.tsx +21 -0
- package/src/components/router.tsx +66 -0
- package/src/index.ts +7 -0
- package/src/initialize.ts +11 -0
- package/src/is-jsx-element.spec.ts +18 -0
- package/src/jsx.ts +528 -0
- package/src/models/children-list.ts +1 -0
- package/src/models/index.ts +5 -0
- package/src/models/partial-element.ts +3 -0
- package/src/models/render-options.ts +16 -0
- package/src/models/selection-state.ts +9 -0
- package/src/models/shade-component.ts +16 -0
- package/src/services/index.ts +2 -0
- package/src/services/location-service.spec.ts +16 -0
- package/src/services/location-service.tsx +40 -0
- package/src/services/screen-service.ts +59 -0
- package/src/shade-component.ts +69 -0
- package/src/shade.ts +201 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jsx.d.ts","sourceRoot":"","sources":["../src/jsx.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAA;AAClD,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC5C,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,UAAU,CAAA;AAEvD,OAAO,CAAC,MAAM,CAAC;IAEb,MAAM,WAAW,GAAG,CAAC;QACnB,UAAU,OAAO,CAAC,MAAM,GAAG,GAAG,EAAE,MAAM,GAAG,GAAG,CAAE,SAAQ,WAAW;YAC/D,QAAQ,EAAE,QAAQ,CAAA;YAClB,KAAK,EAAE,eAAe,CAAC,MAAM,CAAC,CAAA;YAC9B,KAAK,EAAE,eAAe,CAAC,MAAM,CAAC,CAAA;YAC9B,eAAe,EAAE,MAAM,IAAI,CAAA;YAC3B,aAAa,EAAE,eAAe,CAAC,YAAY,CAAC,CAAA;YAC5C,eAAe,EAAE,MAAM,IAAI,CAAA;SAC5B;QAED,UAAU,iBAAiB;YACzB;;eAEG;YACH,CAAC,EAAE,cAAc,CAAC,iBAAiB,CAAC,CAAA;YACpC;;eAEG;YACH,IAAI,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YACjC;;;;eAIG;YACH,OAAO,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YACpC;;;eAGG;YACH,IAAI,EAAE,cAAc,CAAC,eAAe,CAAC,CAAA;YACrC;;;eAGG;YACH,OAAO,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YACpC;;;eAGG;YACH,KAAK,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAClC;;eAEG;YACH,KAAK,EAAE,cAAc,CAAC,gBAAgB,CAAC,CAAA;YACvC;;eAEG;YACH,CAAC,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAC9B;;eAEG;YACH,UAAU,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YACvC;;eAEG;YACH,EAAE,EAAE,cAAc,CAAC,aAAa,CAAC,CAAA;YACjC;;;eAGG;YACH,MAAM,EAAE,cAAc,CAAC,iBAAiB,CAAC,CAAA;YACzC;;eAEG;YACH,MAAM,EAAE,cAAc,CAAC,iBAAiB,CAAC,CAAA;YACzC;;eAEG;YACH,OAAO,EAAE,cAAc,CAAC,uBAAuB,CAAC,CAAA;YAChD;;eAEG;YACH,IAAI,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YACjC;;eAEG;YACH,IAAI,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YACjC;;;eAGG;YACH,GAAG,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAChC;;;eAGG;YACH,QAAQ,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YACrC;;;eAGG;YACH,IAAI,EAAE,cAAc,CAAC,eAAe,CAAC,CAAA;YACrC;;;;eAIG;YACH,QAAQ,EAAE,cAAc,CAAC,mBAAmB,CAAC,CAAA;YAC7C;;;;eAIG;YACH,EAAE,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAC/B;;;;eAIG;YACH,GAAG,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAChC;;;;eAIG;YACH,OAAO,EAAE,cAAc,CAAC,kBAAkB,CAAC,CAAA;YAC3C;;;;;eAKG;YACH,GAAG,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAChC;;;eAGG;YACH,MAAM,EAAE,cAAc,CAAC,iBAAiB,CAAC,CAAA;YACzC;;;eAGG;YACH,GAAG,EAAE,cAAc,CAAC,cAAc,CAAC,CAAA;YACnC;;;eAGG;YACH,EAAE,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAC/B;;;eAGG;YACH,EAAE,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAC/B;;;eAGG;YACH,EAAE,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAC/B;;eAEG;YACH,KAAK,EAAE,cAAc,CAAC,gBAAgB,CAAC,CAAA;YACvC;;;eAGG;YACH,QAAQ,EAAE,cAAc,CAAC,mBAAmB,CAAC,CAAA;YAC7C;;;eAGG;YACH,UAAU,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YACvC;;;eAGG;YACH,MAAM,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YACnC;;;eAGG;YACH,MAAM,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YACnC;;eAEG;YACH,IAAI,EAAE,cAAc,CAAC,WAAW,CAAC,GAAG;gBAAE,MAAM,CAAC,EAAE,CAAC,EAAE,EAAE,KAAK,KAAK,IAAI,GAAG,SAAS,GAAG,OAAO,CAAA;aAAE,CAAA;YAC1F;;;eAGG;YACH,EAAE,EAAE,cAAc,CAAC,kBAAkB,CAAC,CAAA;YACtC;;;eAGG;YACH,EAAE,EAAE,cAAc,CAAC,kBAAkB,CAAC,CAAA;YACtC;;;eAGG;YACH,EAAE,EAAE,cAAc,CAAC,kBAAkB,CAAC,CAAA;YACtC;;;eAGG;YACH,EAAE,EAAE,cAAc,CAAC,kBAAkB,CAAC,CAAA;YACtC;;;eAGG;YACH,EAAE,EAAE,cAAc,CAAC,kBAAkB,CAAC,CAAA;YACtC;;;eAGG;YACH,EAAE,EAAE,cAAc,CAAC,kBAAkB,CAAC,CAAA;YACtC;;eAEG;YACH,MAAM,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YACnC;;eAEG;YACH,EAAE,EAAE,cAAc,CAAC,aAAa,CAAC,CAAA;YACjC;;eAEG;YACH,CAAC,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAC9B;;;eAGG;YACH,MAAM,EAAE,cAAc,CAAC,iBAAiB,CAAC,CAAA;YACzC;;eAEG;YACH,GAAG,EAAE,cAAc,CAAC,gBAAgB,CAAC,GAAG;gBAAE,GAAG,EAAE,MAAM,CAAC;gBAAC,GAAG,EAAE,MAAM,CAAA;aAAE,CAAA;YACpE;;eAEG;YACH,KAAK,EAAE,cAAc,CAAC,gBAAgB,GAAG;gBAAE,SAAS,CAAC,EAAE,OAAO,CAAA;aAAE,CAAC,CAAA;YACjE;;eAEG;YACH,GAAG,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAChC;;eAEG;YACH,GAAG,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAChC;;eAEG;YACH,KAAK,EAAE,cAAc,CAAC,gBAAgB,CAAC,CAAA;YACvC;;eAEG;YACH,MAAM,EAAE,cAAc,CAAC,iBAAiB,CAAC,CAAA;YACzC;;eAEG;YACH,EAAE,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAC/B;;;;eAIG;YACH,IAAI,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YACjC;;;;eAIG;YACH,GAAG,EAAE,cAAc,CAAC,cAAc,CAAC,CAAA;YACnC;;;eAGG;YACH,IAAI,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YACjC;;;;;eAKG;YACH,KAAK,EAAE,cAAc,CAAC,gBAAgB,CAAC,CAAA;YACvC;;;;eAIG;YACH,GAAG,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAChC;;;;eAIG;YACH,MAAM,EAAE,cAAc,CAAC,iBAAiB,CAAC,CAAA;YACzC;;;eAGG;YACH,EAAE,EAAE,cAAc,CAAC,gBAAgB,CAAC,CAAA;YACpC;;;eAGG;YACH,QAAQ,EAAE,cAAc,CAAC,mBAAmB,CAAC,CAAA;YAC7C;;;eAGG;YACH,MAAM,EAAE,cAAc,CAAC,iBAAiB,CAAC,CAAA;YACzC;;eAEG;YACH,MAAM,EAAE,cAAc,CAAC,iBAAiB,CAAC,CAAA;YACzC;;eAEG;YACH,CAAC,EAAE,cAAc,CAAC,oBAAoB,CAAC,CAAA;YACvC;;;eAGG;YACH,KAAK,EAAE,cAAc,CAAC,gBAAgB,CAAC,CAAA;YACvC;;;;;;;;;;;;;;eAcG;YACH,OAAO,EAAE,cAAc,CAAC,kBAAkB,CAAC,CAAA;YAC3C;;;eAGG;YACH,GAAG,EAAE,cAAc,CAAC,cAAc,CAAC,CAAA;YACnC;;eAEG;YACH,QAAQ,EAAE,cAAc,CAAC,mBAAmB,CAAC,CAAA;YAC7C;;;eAGG;YACH,CAAC,EAAE,cAAc,CAAC,gBAAgB,CAAC,CAAA;YACnC;;;eAGG;YACH,EAAE,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAC/B;;;eAGG;YACH,EAAE,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAC/B;;;;eAIG;YACH,IAAI,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YACjC;;;eAGG;YACH,CAAC,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAC9B;;eAEG;YACH,IAAI,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YACjC;;eAEG;YACH,OAAO,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YACpC;;;eAGG;YACH,MAAM,EAAE,cAAc,CAAC,iBAAiB,CAAC,CAAA;YACzC;;eAEG;YACH,KAAK,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAClC;;;eAGG;YACH,MAAM,EAAE,cAAc,CAAC,iBAAiB,CAAC,CAAA;YACzC;;;;eAIG;YACH,IAAI,EAAE,cAAc,CAAC,eAAe,CAAC,CAAA;YACrC;;eAEG;YACH,MAAM,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YACnC;;eAEG;YACH,KAAK,EAAE,cAAc,CAAC,gBAAgB,CAAC,CAAA;YACvC;;eAEG;YACH,GAAG,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAChC;;eAEG;YACH,OAAO,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YACpC;;eAEG;YACH,GAAG,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAChC;;;eAGG;YACH,GAAG,EAAE,cAAc,CAAC,UAAU,CAAC,CAAA;YAC/B;;;;;eAKG;YACH,KAAK,EAAE,cAAc,CAAC,gBAAgB,CAAC,CAAA;YACvC;;;;;eAKG;YACH,KAAK,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAClC;;;;;;;eAOG;YACH,EAAE,EAAE,cAAc,CAAC,oBAAoB,CAAC,CAAA;YACxC;;;;;eAKG;YACH,QAAQ,EAAE,cAAc,CAAC,mBAAmB,CAAC,CAAA;YAC7C;;;;eAIG;YACH,QAAQ,EAAE,cAAc,CAAC,mBAAmB,CAAC,CAAA;YAC7C;;;;;eAKG;YACH,KAAK,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAElC;;;;;;;eAOG;YACH,EAAE,EAAE,cAAc,CAAC,0BAA0B,CAAC,CAAA;YAC9C;;;;eAIG;YACH,KAAK,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAClC;;eAEG;YACH,IAAI,EAAE,cAAc,CAAC,eAAe,CAAC,CAAA;YACrC;;;eAGG;YACH,EAAE,EAAE,cAAc,CAAC,mBAAmB,CAAC,CAAA;YACvC;;;eAGG;YACH,KAAK,EAAE,cAAc,CAAC,gBAAgB,CAAC,CAAA;YACvC;;eAEG;YACH,CAAC,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAC9B;;;eAGG;YACH,EAAE,EAAE,cAAc,CAAC,gBAAgB,CAAC,CAAA;YACpC;;eAEG;YACH,GAAG,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;YAChC;;eAEG;YACH,KAAK,EAAE,cAAc,CAAC,gBAAgB,CAAC,CAAA;YACvC;;;eAGG;YACH,GAAG,EAAE,cAAc,CAAC,WAAW,CAAC,CAAA;SACjC;KACF;CACF;AAED,eAAO,MAAM,YAAY,QAAS,GAAG,iCAGpC,CAAA"}
|
package/dist/jsx.js
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isJsxElement = void 0;
|
|
4
|
+
const isJsxElement = (obj) => {
|
|
5
|
+
const casted = obj;
|
|
6
|
+
return casted.props !== undefined && casted.state !== undefined;
|
|
7
|
+
};
|
|
8
|
+
exports.isJsxElement = isJsxElement;
|
|
9
|
+
//# sourceMappingURL=jsx.js.map
|
package/dist/jsx.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jsx.js","sourceRoot":"","sources":["../src/jsx.ts"],"names":[],"mappings":";;;AA4gBO,MAAM,YAAY,GAAG,CAAC,GAAQ,EAAsB,EAAE;IAC3D,MAAM,MAAM,GAAG,GAAkB,CAAA;IACjC,OAAO,MAAM,CAAC,KAAK,KAAK,SAAS,IAAI,MAAM,CAAC,KAAK,KAAK,SAAS,CAAA;AACjE,CAAC,CAAA;AAHY,QAAA,YAAY,gBAGxB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"children-list.d.ts","sourceRoot":"","sources":["../../src/models/children-list.ts"],"names":[],"mappings":"AAAA,oBAAY,YAAY,GAAG,KAAK,CAAC,MAAM,GAAG,WAAW,GAAG,GAAG,CAAC,OAAO,GAAG,MAAM,EAAE,GAAG,WAAW,EAAE,GAAG,GAAG,CAAC,OAAO,EAAE,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"children-list.js","sourceRoot":"","sources":["../../src/models/children-list.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/models/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAA;AAC/B,cAAc,mBAAmB,CAAA;AACjC,cAAc,kBAAkB,CAAA;AAChC,cAAc,mBAAmB,CAAA;AACjC,cAAc,mBAAmB,CAAA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
(0, tslib_1.__exportStar)(require("./children-list"), exports);
|
|
5
|
+
(0, tslib_1.__exportStar)(require("./partial-element"), exports);
|
|
6
|
+
(0, tslib_1.__exportStar)(require("./render-options"), exports);
|
|
7
|
+
(0, tslib_1.__exportStar)(require("./selection-state"), exports);
|
|
8
|
+
(0, tslib_1.__exportStar)(require("./shade-component"), exports);
|
|
9
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/models/index.ts"],"names":[],"mappings":";;;AAAA,+DAA+B;AAC/B,iEAAiC;AACjC,gEAAgC;AAChC,iEAAiC;AACjC,iEAAiC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"partial-element.d.ts","sourceRoot":"","sources":["../../src/models/partial-element.ts"],"names":[],"mappings":"AAAA,oBAAY,cAAc,CAAC,CAAC,SAAS;IAAE,KAAK,CAAC,EAAE,mBAAmB,CAAA;CAAE,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC,GAAG;IAClG,KAAK,CAAC,EAAE,OAAO,CAAC,mBAAmB,CAAC,CAAA;CACrC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"partial-element.js","sourceRoot":"","sources":["../../src/models/partial-element.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Injector } from '@furystack/inject';
|
|
2
|
+
import { PartialElement } from './partial-element';
|
|
3
|
+
import { ChildrenList } from './children-list';
|
|
4
|
+
export declare type RenderOptions<TProps, TState> = {
|
|
5
|
+
readonly props: TProps;
|
|
6
|
+
injector: Injector;
|
|
7
|
+
children: ChildrenList;
|
|
8
|
+
element: JSX.Element<TProps, TState>;
|
|
9
|
+
} & (unknown extends TState ? {} : {
|
|
10
|
+
getState: () => TState;
|
|
11
|
+
updateState: (newState: PartialElement<TState>, skipRender?: boolean) => void;
|
|
12
|
+
});
|
|
13
|
+
//# sourceMappingURL=render-options.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"render-options.d.ts","sourceRoot":"","sources":["../../src/models/render-options.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAA;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAE9C,oBAAY,aAAa,CAAC,MAAM,EAAE,MAAM,IAAI;IAC1C,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAA;IAEtB,QAAQ,EAAE,QAAQ,CAAA;IAClB,QAAQ,EAAE,YAAY,CAAA;IACtB,OAAO,EAAE,GAAG,CAAC,OAAO,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;CACrC,GAAG,CAAC,OAAO,SAAS,MAAM,GACvB,EAAE,GACF;IACE,QAAQ,EAAE,MAAM,MAAM,CAAA;IACtB,WAAW,EAAE,CAAC,QAAQ,EAAE,cAAc,CAAC,MAAM,CAAC,EAAE,UAAU,CAAC,EAAE,OAAO,KAAK,IAAI,CAAA;CAC9E,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"render-options.js","sourceRoot":"","sources":["../../src/models/render-options.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"selection-state.d.ts","sourceRoot":"","sources":["../../src/models/selection-state.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,cAAc;IAC7B,WAAW,CAAC,EAAE,MAAM,EAAE,CAAA;IACtB,cAAc,CAAC,EAAE;QACf,WAAW,EAAE,MAAM,CAAA;QACnB,kBAAkB,EAAE,MAAM,EAAE,CAAA;QAC5B,SAAS,EAAE,MAAM,CAAA;QACjB,gBAAgB,EAAE,MAAM,EAAE,CAAA;KAC3B,CAAA;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"selection-state.js","sourceRoot":"","sources":["../../src/models/selection-state.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { ChildrenList } from './children-list';
|
|
2
|
+
/**
|
|
3
|
+
* Type definition for a Shade component
|
|
4
|
+
*/
|
|
5
|
+
export declare type ShadeComponent<TProps = {}> = (arg: TProps, children?: ChildrenList) => JSX.Element;
|
|
6
|
+
/**
|
|
7
|
+
* Type guard that checks if an object is a stateless component
|
|
8
|
+
*
|
|
9
|
+
* @param obj The object to check
|
|
10
|
+
* @returns a value that indicates if the object is a Shade component
|
|
11
|
+
*/
|
|
12
|
+
export declare const isShadeComponent: (obj: any) => obj is ShadeComponent<any>;
|
|
13
|
+
//# sourceMappingURL=shade-component.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shade-component.d.ts","sourceRoot":"","sources":["../../src/models/shade-component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAE9C;;GAEG;AACH,oBAAY,cAAc,CAAC,MAAM,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,YAAY,KAAK,GAAG,CAAC,OAAO,CAAA;AAE/F;;;;;GAKG;AACH,eAAO,MAAM,gBAAgB,QAAS,GAAG,+BAExC,CAAA"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isShadeComponent = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Type guard that checks if an object is a stateless component
|
|
6
|
+
*
|
|
7
|
+
* @param obj The object to check
|
|
8
|
+
* @returns a value that indicates if the object is a Shade component
|
|
9
|
+
*/
|
|
10
|
+
const isShadeComponent = (obj) => {
|
|
11
|
+
return typeof obj === 'function';
|
|
12
|
+
};
|
|
13
|
+
exports.isShadeComponent = isShadeComponent;
|
|
14
|
+
//# sourceMappingURL=shade-component.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shade-component.js","sourceRoot":"","sources":["../../src/models/shade-component.ts"],"names":[],"mappings":";;;AAOA;;;;;GAKG;AACI,MAAM,gBAAgB,GAAG,CAAC,GAAQ,EAA8B,EAAE;IACvE,OAAO,OAAO,GAAG,KAAK,UAAU,CAAA;AAClC,CAAC,CAAA;AAFY,QAAA,gBAAgB,oBAE5B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/services/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAA;AAClC,cAAc,kBAAkB,CAAA"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
(0, tslib_1.__exportStar)(require("./location-service"), exports);
|
|
5
|
+
(0, tslib_1.__exportStar)(require("./screen-service"), exports);
|
|
6
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/services/index.ts"],"names":[],"mappings":";;;AAAA,kEAAkC;AAClC,gEAAgC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Disposable, ObservableValue } from '@furystack/utils';
|
|
2
|
+
export declare class LocationService implements Disposable {
|
|
3
|
+
dispose(): void;
|
|
4
|
+
onLocationChanged: ObservableValue<URL>;
|
|
5
|
+
updateState(): void;
|
|
6
|
+
private pushStateTracer;
|
|
7
|
+
private replaceStateTracer;
|
|
8
|
+
constructor();
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=location-service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"location-service.d.ts","sourceRoot":"","sources":["../../src/services/location-service.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,eAAe,EAAS,MAAM,kBAAkB,CAAA;AAErE,qBACa,eAAgB,YAAW,UAAU;IACzC,OAAO;IAOP,iBAAiB,uBAAmD;IAEpE,WAAW;IAKlB,OAAO,CAAC,eAAe,CAAY;IACnC,OAAO,CAAC,kBAAkB,CAAY;;CAoBvC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.LocationService = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const utils_1 = require("@furystack/utils");
|
|
6
|
+
const inject_1 = require("@furystack/inject");
|
|
7
|
+
let LocationService = class LocationService {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.onLocationChanged = new utils_1.ObservableValue(new URL(location.href));
|
|
10
|
+
window.addEventListener('popstate', () => this.updateState());
|
|
11
|
+
window.addEventListener('hashchange', () => this.updateState());
|
|
12
|
+
this.pushStateTracer = utils_1.Trace.method({
|
|
13
|
+
object: history,
|
|
14
|
+
method: history.pushState,
|
|
15
|
+
isAsync: false,
|
|
16
|
+
onFinished: () => this.updateState(),
|
|
17
|
+
});
|
|
18
|
+
this.replaceStateTracer = utils_1.Trace.method({
|
|
19
|
+
object: history,
|
|
20
|
+
method: history.replaceState,
|
|
21
|
+
isAsync: false,
|
|
22
|
+
onFinished: () => this.updateState(),
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
dispose() {
|
|
26
|
+
window.removeEventListener('popstate', this.updateState);
|
|
27
|
+
window.removeEventListener('hashchange', this.updateState);
|
|
28
|
+
this.pushStateTracer.dispose();
|
|
29
|
+
this.replaceStateTracer.dispose();
|
|
30
|
+
}
|
|
31
|
+
updateState() {
|
|
32
|
+
const newUrl = new URL(location.href);
|
|
33
|
+
this.onLocationChanged.setValue(newUrl);
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
LocationService = (0, tslib_1.__decorate)([
|
|
37
|
+
(0, inject_1.Injectable)({ lifetime: 'singleton' }),
|
|
38
|
+
(0, tslib_1.__metadata)("design:paramtypes", [])
|
|
39
|
+
], LocationService);
|
|
40
|
+
exports.LocationService = LocationService;
|
|
41
|
+
//# sourceMappingURL=location-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"location-service.js","sourceRoot":"","sources":["../../src/services/location-service.tsx"],"names":[],"mappings":";;;;AAAA,4CAAqE;AACrE,8CAA8C;AAE9C,IAAa,eAAe,GAA5B,MAAa,eAAe;IAkB1B;QAVO,sBAAiB,GAAG,IAAI,uBAAe,CAAM,IAAI,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAA;QAWzE,MAAM,CAAC,gBAAgB,CAAC,UAAU,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAA;QAC7D,MAAM,CAAC,gBAAgB,CAAC,YAAY,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAA;QAE/D,IAAI,CAAC,eAAe,GAAG,aAAK,CAAC,MAAM,CAAC;YAClC,MAAM,EAAE,OAAO;YACf,MAAM,EAAE,OAAO,CAAC,SAAS;YACzB,OAAO,EAAE,KAAK;YACd,UAAU,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE;SACrC,CAAC,CAAA;QAEF,IAAI,CAAC,kBAAkB,GAAG,aAAK,CAAC,MAAM,CAAC;YACrC,MAAM,EAAE,OAAO;YACf,MAAM,EAAE,OAAO,CAAC,YAAY;YAC5B,OAAO,EAAE,KAAK;YACd,UAAU,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE;SACrC,CAAC,CAAA;IACJ,CAAC;IAlCM,OAAO;QACZ,MAAM,CAAC,mBAAmB,CAAC,UAAU,EAAE,IAAI,CAAC,WAAW,CAAC,CAAA;QACxD,MAAM,CAAC,mBAAmB,CAAC,YAAY,EAAE,IAAI,CAAC,WAAW,CAAC,CAAA;QAC1D,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAA;QAC9B,IAAI,CAAC,kBAAkB,CAAC,OAAO,EAAE,CAAA;IACnC,CAAC;IAIM,WAAW;QAChB,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;QACrC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAA;IACzC,CAAC;CAuBF,CAAA;AApCY,eAAe;IAD3B,IAAA,mBAAU,EAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,CAAC;;GACzB,eAAe,CAoC3B;AApCY,0CAAe"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"location-service.spec.d.ts","sourceRoot":"","sources":["../../src/services/location-service.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const inject_1 = require("@furystack/inject");
|
|
4
|
+
const utils_1 = require("@furystack/utils");
|
|
5
|
+
const _1 = require("./");
|
|
6
|
+
const jsdom_1 = require("jsdom");
|
|
7
|
+
describe('LocationService', () => {
|
|
8
|
+
it('Shuld be constructed', async () => {
|
|
9
|
+
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
10
|
+
const dom = new jsdom_1.JSDOM();
|
|
11
|
+
global.window = dom.window;
|
|
12
|
+
i.setExplicitInstance(dom.window, Window);
|
|
13
|
+
const s = i.getInstance(_1.LocationService);
|
|
14
|
+
expect(s).toBeInstanceOf(_1.LocationService);
|
|
15
|
+
});
|
|
16
|
+
});
|
|
17
|
+
});
|
|
18
|
+
//# sourceMappingURL=location-service.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"location-service.spec.js","sourceRoot":"","sources":["../../src/services/location-service.spec.ts"],"names":[],"mappings":";;AAAA,8CAA4C;AAC5C,4CAA6C;AAC7C,yBAAoC;AACpC,iCAA6B;AAE7B,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,EAAE,CAAC,sBAAsB,EAAE,KAAK,IAAI,EAAE;QACpC,MAAM,IAAA,kBAAU,EAAC,IAAI,iBAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YAC3C,MAAM,GAAG,GAAG,IAAI,aAAK,EAAE,CACtB;YAAC,MAAc,CAAC,MAAM,GAAG,GAAG,CAAC,MAAM,CAAA;YACpC,CAAC,CAAC,mBAAmB,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;YACzC,MAAM,CAAC,GAAG,CAAC,CAAC,WAAW,CAAC,kBAAe,CAAC,CAAA;YACxC,MAAM,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,kBAAe,CAAC,CAAA;QAC3C,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { Disposable, ObservableValue } from '@furystack/utils';
|
|
2
|
+
export declare const ScreenSizes: readonly ["xs", "sm", "md", "lg", "xl"];
|
|
3
|
+
export declare type ScreenSize = typeof ScreenSizes[number];
|
|
4
|
+
export declare type Breakpoint = {
|
|
5
|
+
name: ScreenSize;
|
|
6
|
+
minSize: number;
|
|
7
|
+
maxSize?: number;
|
|
8
|
+
};
|
|
9
|
+
export declare class Screen implements Disposable {
|
|
10
|
+
private getOrientation;
|
|
11
|
+
readonly breakpoints: {
|
|
12
|
+
[K in ScreenSize]: {
|
|
13
|
+
minSize: number;
|
|
14
|
+
};
|
|
15
|
+
};
|
|
16
|
+
dispose(): void;
|
|
17
|
+
readonly screenSize: {
|
|
18
|
+
atLeast: {
|
|
19
|
+
[K in ScreenSize]: ObservableValue<boolean>;
|
|
20
|
+
};
|
|
21
|
+
};
|
|
22
|
+
private screenSizeAtLeast;
|
|
23
|
+
orientation: ObservableValue<"landscape" | "portrait">;
|
|
24
|
+
private onResizeListener;
|
|
25
|
+
private refreshValues;
|
|
26
|
+
constructor();
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=screen-service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"screen-service.d.ts","sourceRoot":"","sources":["../../src/services/screen-service.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAA;AAE9D,eAAO,MAAM,WAAW,yCAA0C,CAAA;AAElE,oBAAY,UAAU,GAAG,OAAO,WAAW,CAAC,MAAM,CAAC,CAAA;AAEnD,oBAAY,UAAU,GAAG;IAAE,IAAI,EAAE,UAAU,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,OAAO,CAAC,EAAE,MAAM,CAAA;CAAE,CAAA;AAEhF,qBACa,MAAO,YAAW,UAAU;IACvC,OAAO,CAAC,cAAc,CAAyF;IAE/G,SAAgB,WAAW,EAAE;SAAG,CAAC,IAAI,UAAU,GAAG;YAAE,OAAO,EAAE,MAAM,CAAA;SAAE;KAAE,CAMtE;IAEM,OAAO;IAId,SAAgB,UAAU,EAAE;QAC1B,OAAO,EAAE;aAAG,CAAC,IAAI,UAAU,GAAG,eAAe,CAAC,OAAO,CAAC;SAAE,CAAA;KACzD,CAQA;IAED,OAAO,CAAC,iBAAiB;IAIlB,WAAW,4CAAuE;IAEzF,OAAO,CAAC,gBAAgB,CAEvB;IAED,OAAO,CAAC,aAAa;;CAWtB"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Screen = exports.ScreenSizes = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const inject_1 = require("@furystack/inject");
|
|
6
|
+
const utils_1 = require("@furystack/utils");
|
|
7
|
+
exports.ScreenSizes = ['xs', 'sm', 'md', 'lg', 'xl'];
|
|
8
|
+
let Screen = class Screen {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.getOrientation = () => (window.matchMedia('(orientation:landscape').matches ? 'landscape' : 'portrait');
|
|
11
|
+
this.breakpoints = {
|
|
12
|
+
xl: { minSize: 1920 },
|
|
13
|
+
lg: { minSize: 1280 },
|
|
14
|
+
md: { minSize: 960 },
|
|
15
|
+
sm: { minSize: 600 },
|
|
16
|
+
xs: { minSize: 0 },
|
|
17
|
+
};
|
|
18
|
+
this.screenSize = {
|
|
19
|
+
atLeast: {
|
|
20
|
+
xs: new utils_1.ObservableValue(this.screenSizeAtLeast('xs')),
|
|
21
|
+
sm: new utils_1.ObservableValue(this.screenSizeAtLeast('sm')),
|
|
22
|
+
md: new utils_1.ObservableValue(this.screenSizeAtLeast('md')),
|
|
23
|
+
lg: new utils_1.ObservableValue(this.screenSizeAtLeast('lg')),
|
|
24
|
+
xl: new utils_1.ObservableValue(this.screenSizeAtLeast('xl')),
|
|
25
|
+
},
|
|
26
|
+
};
|
|
27
|
+
this.orientation = new utils_1.ObservableValue(this.getOrientation());
|
|
28
|
+
this.onResizeListener = () => {
|
|
29
|
+
this.refreshValues();
|
|
30
|
+
};
|
|
31
|
+
window.addEventListener('resize', this.onResizeListener);
|
|
32
|
+
this.refreshValues();
|
|
33
|
+
}
|
|
34
|
+
dispose() {
|
|
35
|
+
window.removeEventListener('resize', this.onResizeListener);
|
|
36
|
+
}
|
|
37
|
+
screenSizeAtLeast(size) {
|
|
38
|
+
return window.innerWidth >= this.breakpoints[size].minSize;
|
|
39
|
+
}
|
|
40
|
+
refreshValues() {
|
|
41
|
+
this.orientation.setValue(this.getOrientation());
|
|
42
|
+
exports.ScreenSizes.forEach((size) => {
|
|
43
|
+
this.screenSize.atLeast[size].setValue(this.screenSizeAtLeast(size));
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
Screen = (0, tslib_1.__decorate)([
|
|
48
|
+
(0, inject_1.Injectable)({ lifetime: 'singleton' }),
|
|
49
|
+
(0, tslib_1.__metadata)("design:paramtypes", [])
|
|
50
|
+
], Screen);
|
|
51
|
+
exports.Screen = Screen;
|
|
52
|
+
//# sourceMappingURL=screen-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"screen-service.js","sourceRoot":"","sources":["../../src/services/screen-service.ts"],"names":[],"mappings":";;;;AAAA,8CAA8C;AAC9C,4CAA8D;AAEjD,QAAA,WAAW,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAU,CAAA;AAOlE,IAAa,MAAM,GAAnB,MAAa,MAAM;IA4CjB;QA3CQ,mBAAc,GAAG,GAAG,EAAE,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,wBAAwB,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,UAAU,CAAC,CAAA;QAE/F,gBAAW,GAA+C;YACxE,EAAE,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE;YACrB,EAAE,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE;YACrB,EAAE,EAAE,EAAE,OAAO,EAAE,GAAG,EAAE;YACpB,EAAE,EAAE,EAAE,OAAO,EAAE,GAAG,EAAE;YACpB,EAAE,EAAE,EAAE,OAAO,EAAE,CAAC,EAAE;SACnB,CAAA;QAMe,eAAU,GAEtB;YACF,OAAO,EAAE;gBACP,EAAE,EAAE,IAAI,uBAAe,CAAU,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;gBAC9D,EAAE,EAAE,IAAI,uBAAe,CAAU,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;gBAC9D,EAAE,EAAE,IAAI,uBAAe,CAAU,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;gBAC9D,EAAE,EAAE,IAAI,uBAAe,CAAU,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;gBAC9D,EAAE,EAAE,IAAI,uBAAe,CAAU,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;aAC/D;SACF,CAAA;QAMM,gBAAW,GAAG,IAAI,uBAAe,CAA2B,IAAI,CAAC,cAAc,EAAE,CAAC,CAAA;QAEjF,qBAAgB,GAAG,GAAG,EAAE;YAC9B,IAAI,CAAC,aAAa,EAAE,CAAA;QACtB,CAAC,CAAA;QAUC,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAA;QACxD,IAAI,CAAC,aAAa,EAAE,CAAA;IACtB,CAAC;IApCM,OAAO;QACZ,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAA;IAC7D,CAAC;IAcO,iBAAiB,CAAC,IAAgB;QACxC,OAAO,MAAM,CAAC,UAAU,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,OAAO,CAAA;IAC5D,CAAC;IAQO,aAAa;QACnB,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAA;QAChD,mBAAW,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC3B,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAA;QACtE,CAAC,CAAC,CAAA;IACJ,CAAC;CAMF,CAAA;AAhDY,MAAM;IADlB,IAAA,mBAAU,EAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,CAAC;;GACzB,MAAM,CAgDlB;AAhDY,wBAAM"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { ChildrenList, ShadeComponent } from './models';
|
|
2
|
+
/**
|
|
3
|
+
* Appends a list of items to a HTML element
|
|
4
|
+
*
|
|
5
|
+
* @param el the root element
|
|
6
|
+
* @param children array of items to append
|
|
7
|
+
*/
|
|
8
|
+
export declare const appendChild: (el: HTMLElement, children: ChildrenList) => void;
|
|
9
|
+
export declare const hasStyle: (props: any) => props is {
|
|
10
|
+
style: Partial<CSSStyleDeclaration>;
|
|
11
|
+
};
|
|
12
|
+
/**
|
|
13
|
+
* @param el The Target HTML Element
|
|
14
|
+
* @param props The Properties to fetch The Styles Object
|
|
15
|
+
*/
|
|
16
|
+
export declare const attachStyles: (el: HTMLElement, props: any) => void;
|
|
17
|
+
/**
|
|
18
|
+
* Factory method that creates a component. This should be configured as a default JSX Factory in tsconfig.
|
|
19
|
+
*
|
|
20
|
+
* @param elementType The type of the element (component or stateless component factory method)
|
|
21
|
+
* @param props The props for the component
|
|
22
|
+
* @param children additional rest parameters will be parsed as children objects
|
|
23
|
+
* @returns the created JSX element
|
|
24
|
+
*/
|
|
25
|
+
export declare const createComponent: <TProps>(elementType: string | ShadeComponent<TProps>, props: TProps, ...children: ChildrenList) => HTMLElement | undefined;
|
|
26
|
+
//# sourceMappingURL=shade-component.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shade-component.d.ts","sourceRoot":"","sources":["../src/shade-component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,cAAc,EAAoB,MAAM,UAAU,CAAA;AAEzE;;;;;GAKG;AACH,eAAO,MAAM,WAAW,OAAQ,WAAW,iCAY1C,CAAA;AAED,eAAO,MAAM,QAAQ,UAAW,GAAG;WAAqB,QAAQ,mBAAmB,CAAC;CAEnF,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,YAAY,OAAQ,WAAW,SAAS,GAAG,SAOvD,CAAA;AAED;;;;;;;GAOG;AACH,eAAO,MAAM,eAAe,6HAqB3B,CAAA"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createComponent = exports.attachStyles = exports.hasStyle = exports.appendChild = void 0;
|
|
4
|
+
const models_1 = require("./models");
|
|
5
|
+
/**
|
|
6
|
+
* Appends a list of items to a HTML element
|
|
7
|
+
*
|
|
8
|
+
* @param el the root element
|
|
9
|
+
* @param children array of items to append
|
|
10
|
+
*/
|
|
11
|
+
const appendChild = (el, children) => {
|
|
12
|
+
for (const child of children) {
|
|
13
|
+
if (typeof child === 'string') {
|
|
14
|
+
el.appendChild(document.createTextNode(child));
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
if (child instanceof HTMLElement) {
|
|
18
|
+
el.appendChild(child);
|
|
19
|
+
}
|
|
20
|
+
else if (child instanceof Array) {
|
|
21
|
+
(0, exports.appendChild)(el, child);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
exports.appendChild = appendChild;
|
|
27
|
+
const hasStyle = (props) => {
|
|
28
|
+
return (props === null || props === void 0 ? void 0 : props.style) !== undefined;
|
|
29
|
+
};
|
|
30
|
+
exports.hasStyle = hasStyle;
|
|
31
|
+
/**
|
|
32
|
+
* @param el The Target HTML Element
|
|
33
|
+
* @param props The Properties to fetch The Styles Object
|
|
34
|
+
*/
|
|
35
|
+
const attachStyles = (el, props) => {
|
|
36
|
+
if ((0, exports.hasStyle)(props))
|
|
37
|
+
for (const key in props.style) {
|
|
38
|
+
if (Object.prototype.hasOwnProperty.call(props.style, key)) {
|
|
39
|
+
;
|
|
40
|
+
el.style[key] = props.style[key];
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
exports.attachStyles = attachStyles;
|
|
45
|
+
/**
|
|
46
|
+
* Factory method that creates a component. This should be configured as a default JSX Factory in tsconfig.
|
|
47
|
+
*
|
|
48
|
+
* @param elementType The type of the element (component or stateless component factory method)
|
|
49
|
+
* @param props The props for the component
|
|
50
|
+
* @param children additional rest parameters will be parsed as children objects
|
|
51
|
+
* @returns the created JSX element
|
|
52
|
+
*/
|
|
53
|
+
const createComponent = (elementType, props, ...children) => {
|
|
54
|
+
if (typeof elementType === 'string') {
|
|
55
|
+
const el = document.createElement(elementType);
|
|
56
|
+
Object.assign(el, props);
|
|
57
|
+
if (props && props.style) {
|
|
58
|
+
(0, exports.attachStyles)(el, props);
|
|
59
|
+
}
|
|
60
|
+
if (children) {
|
|
61
|
+
(0, exports.appendChild)(el, children);
|
|
62
|
+
}
|
|
63
|
+
return el;
|
|
64
|
+
}
|
|
65
|
+
else if ((0, models_1.isShadeComponent)(elementType)) {
|
|
66
|
+
const el = elementType(props, children);
|
|
67
|
+
(0, exports.attachStyles)(el, props);
|
|
68
|
+
return el;
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
exports.createComponent = createComponent;
|
|
72
|
+
//# sourceMappingURL=shade-component.js.map
|