@studiometa/ui 0.2.1 → 0.2.4

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 (136) hide show
  1. package/atoms/AnchorScrollTo/AnchorScrollTo.cjs +47 -0
  2. package/atoms/AnchorScrollTo/AnchorScrollTo.d.ts +31 -0
  3. package/atoms/AnchorScrollTo/AnchorScrollTo.js +1 -0
  4. package/atoms/Cursor/Cursor.cjs +14 -22
  5. package/atoms/Cursor/Cursor.d.ts +2 -2
  6. package/atoms/Cursor/Cursor.js +1 -103
  7. package/atoms/Figure/Figure.cjs +9 -14
  8. package/atoms/Figure/Figure.d.ts +1 -1
  9. package/atoms/Figure/Figure.js +1 -27
  10. package/atoms/LargeText/LargeText.cjs +82 -0
  11. package/atoms/LargeText/LargeText.d.ts +94 -0
  12. package/atoms/LargeText/LargeText.js +1 -0
  13. package/atoms/LazyInclude/LazyInclude.cjs +67 -0
  14. package/atoms/LazyInclude/LazyInclude.d.ts +64 -0
  15. package/atoms/LazyInclude/LazyInclude.js +1 -0
  16. package/atoms/Prefetch/AbstractPrefetch.cjs +79 -0
  17. package/atoms/Prefetch/AbstractPrefetch.d.ts +52 -0
  18. package/atoms/Prefetch/AbstractPrefetch.js +1 -0
  19. package/atoms/Prefetch/PrefetchWhenOver.cjs +43 -0
  20. package/atoms/Prefetch/PrefetchWhenOver.d.ts +21 -0
  21. package/atoms/Prefetch/PrefetchWhenOver.js +1 -0
  22. package/atoms/Prefetch/PrefetchWhenVisible.cjs +44 -0
  23. package/atoms/Prefetch/PrefetchWhenVisible.d.ts +21 -0
  24. package/atoms/Prefetch/PrefetchWhenVisible.js +1 -0
  25. package/atoms/Prefetch/index.cjs +33 -0
  26. package/atoms/Prefetch/index.d.ts +3 -0
  27. package/atoms/Prefetch/index.js +1 -0
  28. package/atoms/index.cjs +19 -18
  29. package/atoms/index.d.ts +5 -1
  30. package/atoms/index.js +1 -6
  31. package/index.cjs +11 -15
  32. package/index.js +1 -3
  33. package/molecules/Accordion/Accordion.cjs +12 -34
  34. package/molecules/Accordion/Accordion.js +1 -35
  35. package/molecules/Accordion/AccordionCore.cjs +8 -13
  36. package/molecules/Accordion/AccordionCore.d.ts +2 -2
  37. package/molecules/Accordion/AccordionCore.js +1 -34
  38. package/molecules/Accordion/AccordionItem.cjs +70 -114
  39. package/molecules/Accordion/AccordionItem.d.ts +15 -16
  40. package/molecules/Accordion/AccordionItem.js +1 -178
  41. package/molecules/Menu/Menu.cjs +148 -0
  42. package/molecules/Menu/Menu.d.ts +140 -0
  43. package/molecules/Menu/Menu.js +1 -0
  44. package/molecules/Menu/MenuBtn.cjs +53 -0
  45. package/molecules/Menu/MenuBtn.d.ts +39 -0
  46. package/molecules/Menu/MenuBtn.js +1 -0
  47. package/molecules/Menu/MenuList.cjs +134 -0
  48. package/molecules/Menu/MenuList.d.ts +101 -0
  49. package/molecules/Menu/MenuList.js +1 -0
  50. package/molecules/Menu/index.cjs +33 -0
  51. package/molecules/Menu/index.d.ts +3 -0
  52. package/molecules/Menu/index.js +1 -0
  53. package/molecules/Modal/Modal.cjs +42 -72
  54. package/molecules/Modal/Modal.d.ts +11 -11
  55. package/molecules/Modal/Modal.js +1 -151
  56. package/molecules/Modal/ModalWithTransition.cjs +70 -0
  57. package/molecules/Modal/ModalWithTransition.d.ts +29 -0
  58. package/molecules/Modal/ModalWithTransition.js +1 -0
  59. package/molecules/Panel/Panel.cjs +114 -0
  60. package/molecules/Panel/Panel.d.ts +42 -0
  61. package/molecules/Panel/Panel.js +1 -0
  62. package/molecules/Slider/AbstractSliderChild.cjs +64 -0
  63. package/molecules/Slider/AbstractSliderChild.d.ts +59 -0
  64. package/molecules/Slider/AbstractSliderChild.js +1 -0
  65. package/molecules/Slider/Slider.cjs +230 -0
  66. package/molecules/Slider/Slider.d.ts +245 -0
  67. package/molecules/Slider/Slider.js +1 -0
  68. package/molecules/Slider/SliderBtn.cjs +58 -0
  69. package/molecules/Slider/SliderBtn.d.ts +31 -0
  70. package/molecules/Slider/SliderBtn.js +1 -0
  71. package/molecules/Slider/SliderCount.cjs +43 -0
  72. package/molecules/Slider/SliderCount.d.ts +21 -0
  73. package/molecules/Slider/SliderCount.js +1 -0
  74. package/molecules/Slider/SliderDots.cjs +48 -0
  75. package/molecules/Slider/SliderDots.d.ts +33 -0
  76. package/molecules/Slider/SliderDots.js +1 -0
  77. package/molecules/Slider/SliderDrag.cjs +40 -0
  78. package/molecules/Slider/SliderDrag.d.ts +16 -0
  79. package/molecules/Slider/SliderDrag.js +1 -0
  80. package/molecules/Slider/SliderItem.cjs +107 -0
  81. package/molecules/Slider/SliderItem.d.ts +106 -0
  82. package/molecules/Slider/SliderItem.js +1 -0
  83. package/molecules/Slider/SliderProgress.cjs +47 -0
  84. package/molecules/Slider/SliderProgress.d.ts +27 -0
  85. package/molecules/Slider/SliderProgress.js +1 -0
  86. package/molecules/Slider/index.cjs +43 -0
  87. package/molecules/Slider/index.d.ts +8 -0
  88. package/molecules/Slider/index.js +1 -0
  89. package/molecules/Sticky/Sticky.cjs +11 -19
  90. package/molecules/Sticky/Sticky.d.ts +8 -8
  91. package/molecules/Sticky/Sticky.js +1 -107
  92. package/molecules/TableOfContent/TableOfContent.cjs +66 -0
  93. package/molecules/TableOfContent/TableOfContent.d.ts +59 -0
  94. package/molecules/TableOfContent/TableOfContent.js +1 -0
  95. package/molecules/TableOfContent/TableOfContentAnchor.cjs +60 -0
  96. package/molecules/TableOfContent/TableOfContentAnchor.d.ts +36 -0
  97. package/molecules/TableOfContent/TableOfContentAnchor.js +1 -0
  98. package/molecules/TableOfContent/index.cjs +31 -0
  99. package/molecules/TableOfContent/index.d.ts +2 -0
  100. package/molecules/TableOfContent/index.js +1 -0
  101. package/molecules/Tabs/Tabs.cjs +54 -82
  102. package/molecules/Tabs/Tabs.d.ts +7 -8
  103. package/molecules/Tabs/Tabs.js +1 -126
  104. package/molecules/index.cjs +18 -17
  105. package/molecules/index.d.ts +6 -1
  106. package/molecules/index.js +1 -12
  107. package/organisms/Frame/Frame.cjs +171 -0
  108. package/organisms/Frame/Frame.d.ts +119 -0
  109. package/organisms/Frame/Frame.js +1 -0
  110. package/organisms/Frame/FrameAnchor.cjs +43 -0
  111. package/organisms/Frame/FrameAnchor.d.ts +35 -0
  112. package/organisms/Frame/FrameAnchor.js +1 -0
  113. package/organisms/Frame/FrameForm.cjs +43 -0
  114. package/organisms/Frame/FrameForm.d.ts +32 -0
  115. package/organisms/Frame/FrameForm.js +1 -0
  116. package/organisms/Frame/FrameTarget.cjs +92 -0
  117. package/organisms/Frame/FrameTarget.d.ts +47 -0
  118. package/organisms/Frame/FrameTarget.js +1 -0
  119. package/organisms/Frame/index.cjs +35 -0
  120. package/organisms/Frame/index.d.ts +4 -0
  121. package/organisms/Frame/index.js +1 -0
  122. package/organisms/index.cjs +9 -12
  123. package/organisms/index.d.ts +1 -1
  124. package/organisms/index.js +1 -0
  125. package/package.json +3 -4
  126. package/primitives/Draggable/Draggable.cjs +15 -28
  127. package/primitives/Draggable/Draggable.d.ts +0 -5
  128. package/primitives/Draggable/Draggable.js +1 -38
  129. package/primitives/Sentinel/Sentinel.cjs +8 -13
  130. package/primitives/Sentinel/Sentinel.js +1 -15
  131. package/primitives/Transition/Transition.cjs +66 -0
  132. package/primitives/Transition/Transition.d.ts +67 -0
  133. package/primitives/Transition/Transition.js +1 -0
  134. package/primitives/index.cjs +12 -17
  135. package/primitives/index.d.ts +1 -0
  136. package/primitives/index.js +1 -6
@@ -0,0 +1,119 @@
1
+ /**
2
+ * @typedef {Object} FrameOptions
3
+ * @property {boolean} history
4
+ * @property {'replace'|'prepend'|'append'} position
5
+ * @property {string} target
6
+ */
7
+ /**
8
+ * @typedef {Frame & {
9
+ * $children: {
10
+ * FrameAnchor: FrameAnchor[],
11
+ * FrameForm: FrameForm[],
12
+ * FrameTarget: FrameTarget[],
13
+ * Frame: Frame[],
14
+ * }
15
+ * }} FrameInterface
16
+ */
17
+ /**
18
+ * Class.
19
+ */
20
+ export default class Frame extends Base {
21
+ /**
22
+ * Config.
23
+ */
24
+ static config: {
25
+ name: string;
26
+ emits: string[];
27
+ log: boolean;
28
+ components: {
29
+ FrameAnchor: typeof FrameAnchor;
30
+ FrameForm: typeof FrameForm;
31
+ FrameTarget: typeof FrameTarget;
32
+ Frame: typeof Frame;
33
+ };
34
+ options: {
35
+ history: BooleanConstructor;
36
+ };
37
+ };
38
+ /**
39
+ * Get uniq id.
40
+ * @returns {string}
41
+ */
42
+ get id(): string;
43
+ /**
44
+ * Get direct children.
45
+ *
46
+ * @this {FrameInterface}
47
+ * @param {string} name
48
+ * @returns {any[]}
49
+ */
50
+ getDirectChild(this: FrameInterface, name: string): any[];
51
+ /**
52
+ * Get direct `FrameAnchor` children.
53
+ * @returns {FrameAnchor[]}
54
+ */
55
+ get directChildFrameAnchor(): FrameAnchor[];
56
+ /**
57
+ * Get direct `FrameForm` children.
58
+ * @returns {FrameForm[]}
59
+ */
60
+ get directChildFrameForm(): FrameForm[];
61
+ /**
62
+ * Get direct `FrameTarget` children.
63
+ * @returns {FrameTarget[]}
64
+ */
65
+ get directChildFrameTarget(): FrameTarget[];
66
+ /**
67
+ * Prevent click on `FrameAnchor`.
68
+ *
69
+ * @this {FrameInterface}
70
+ * @param {MouseEvent} event
71
+ * @param {number} index
72
+ * @returns {void}
73
+ */
74
+ onFrameAnchorFrameClick(this: FrameInterface, event: MouseEvent, index: number): void;
75
+ /**
76
+ * Prevent submit on forms.
77
+ *
78
+ * @this {FrameInterface}
79
+ * @param {SubmitEvent} event
80
+ * @param {number} index
81
+ * @returns {void}
82
+ */
83
+ onFrameFormFrameSubmit(this: FrameInterface, event: SubmitEvent, index: number): void;
84
+ /**
85
+ * Parge an HTML string into a DOM object.
86
+ * @param {string} string
87
+ * @returns {Document}
88
+ */
89
+ parseHTML(string?: string): Document;
90
+ /**
91
+ * Go to the given url.
92
+ * @param {string} url
93
+ * @returns {Promise<void>}
94
+ */
95
+ goTo(url: string): Promise<void>;
96
+ /**
97
+ * Fetch the given url.
98
+ * @param {string} url
99
+ * @returns {Promise<string>}
100
+ */
101
+ fetch(url: string): Promise<string>;
102
+ }
103
+ export type FrameOptions = {
104
+ history: boolean;
105
+ position: 'replace' | 'prepend' | 'append';
106
+ target: string;
107
+ };
108
+ export type FrameInterface = Frame & {
109
+ $children: {
110
+ FrameAnchor: FrameAnchor[];
111
+ FrameForm: FrameForm[];
112
+ FrameTarget: FrameTarget[];
113
+ Frame: Frame[];
114
+ };
115
+ };
116
+ import { Base } from "@studiometa/js-toolkit";
117
+ import FrameAnchor from "./FrameAnchor.js";
118
+ import FrameForm from "./FrameForm.js";
119
+ import FrameTarget from "./FrameTarget.js";
@@ -0,0 +1 @@
1
+ import{Base as l}from"@studiometa/js-toolkit";import{nextFrame as c,historyPush as d}from"@studiometa/js-toolkit/utils";import f from"./FrameAnchor.js";import F from"./FrameForm.js";import g from"./FrameTarget.js";const n=new Map;class a extends l{static config={name:"Frame",emits:["before-fetch","after-fetch","before-leave","after-leave","before-content","after-content","before-enter","after-enter"],log:!0,components:{FrameAnchor:f,FrameForm:F,FrameTarget:g,Frame:a},options:{history:Boolean}};get id(){return this.$el.id}getDirectChild(e){return this.$children[e]?this.$children.Frame?this.$children[e].filter(t=>this.$children.Frame.every(r=>r.$children[e]?!r.$children[e].includes(t):!0)):this.$children[e]:[]}get directChildFrameAnchor(){return this.getDirectChild("FrameAnchor")}get directChildFrameForm(){return this.getDirectChild("form")}get directChildFrameTarget(){return this.getDirectChild("FrameTarget")}onFrameAnchorFrameClick(e,t){if(!this.directChildFrameAnchor.includes(this.$children.FrameAnchor[t]))return;this.$log("onAFrameClick",e,t),e.preventDefault();const r=this.$children.FrameAnchor[t];r.href!==window.location.href&&this.goTo(r.href)}onFrameFormFrameSubmit(e,t){if(!this.directChildFrameForm.includes(this.$children.FrameForm[t]))return;this.$log("onFrameFormFrameSubmit",e),e.preventDefault();const r=this.$children.FrameForm[t];this.goTo(r.action)}parseHTML(e=""){return new DOMParser().parseFromString(e,"text/html")}async goTo(e){this.$log("goTo",e);const t=new URL(e);if(t.origin!==window.location.origin)throw new Error("Cross origin request are not allowed.");this.$emit("before-fetch",e);const r=await this.fetch(e),i=this.parseHTML(r),h=i.querySelector(`#${this.id}`),s=new a(h);s.$children.registerAll(),this.$emit("after-fetch",e,r),this.$emit("before-leave"),await Promise.all(this.directChildFrameTarget.map(o=>o.leave())),this.$emit("after-leave"),this.$emit("before-content"),this.directChildFrameTarget.map((o,m)=>o.updateContent(s.directChildFrameTarget[m])),this.$options.history&&(document.title=i.title,d({path:t.pathname,search:t.searchParams})),await c(),this.$root.$update(),await c(),this.$emit("after-content"),this.$emit("before-enter"),await Promise.all(this.directChildFrameTarget.map(o=>o.enter())),this.$emit("after-enter")}async fetch(e){const t=n.get(e);if(t)return t.status==="pending"?t.promise:t.content;const r=fetch(e);try{n.set(e,{promise:r,status:"pending",content:void 0});const i=await r.then(h=>h.text());return n.set(e,{promise:r,status:"resolved",content:i}),i}catch(i){return n.set(e,{promise:r,status:"error",content:i}),i}}}export{a as default};
@@ -0,0 +1,43 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
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
+ var __publicField = (obj, key, value) => {
20
+ __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
21
+ return value;
22
+ };
23
+
24
+ // packages/ui/organisms/Frame/FrameAnchor.js
25
+ var FrameAnchor_exports = {};
26
+ __export(FrameAnchor_exports, {
27
+ default: () => FrameAnchor
28
+ });
29
+ module.exports = __toCommonJS(FrameAnchor_exports);
30
+ var import_js_toolkit = require("@studiometa/js-toolkit");
31
+ var FrameAnchor = class extends import_js_toolkit.Base {
32
+ get href() {
33
+ return this.$el.href;
34
+ }
35
+ onClick(event) {
36
+ this.$emit("frame-click", event);
37
+ }
38
+ };
39
+ __publicField(FrameAnchor, "config", {
40
+ name: "FrameAnchor",
41
+ emits: ["frame-click"]
42
+ });
43
+ if (module.exports.default) module.exports = module.exports.default;
@@ -0,0 +1,35 @@
1
+ /**
2
+ * @typedef {FrameAnchor & {
3
+ * $el: HTMLAnchorElement
4
+ * }} FrameAnchorInterface
5
+ */
6
+ /**
7
+ * FrameAnchor class.
8
+ */
9
+ export default class FrameAnchor extends Base {
10
+ /**
11
+ * Config.
12
+ */
13
+ static config: {
14
+ name: string;
15
+ emits: string[];
16
+ };
17
+ /**
18
+ * Get the URL.
19
+ *
20
+ * @this {FrameAnchorInterface}
21
+ * @returns {string}
22
+ */
23
+ get href(): string;
24
+ /**
25
+ * Dispatch the link click event.
26
+ *
27
+ * @param {MouseEvent} event
28
+ * @returns {void}
29
+ */
30
+ onClick(event: MouseEvent): void;
31
+ }
32
+ export type FrameAnchorInterface = FrameAnchor & {
33
+ $el: HTMLAnchorElement;
34
+ };
35
+ import { Base } from "@studiometa/js-toolkit";
@@ -0,0 +1 @@
1
+ import{Base as r}from"@studiometa/js-toolkit";class t extends r{static config={name:"FrameAnchor",emits:["frame-click"]};get href(){return this.$el.href}onClick(e){this.$emit("frame-click",e)}}export{t as default};
@@ -0,0 +1,43 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
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
+ var __publicField = (obj, key, value) => {
20
+ __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
21
+ return value;
22
+ };
23
+
24
+ // packages/ui/organisms/Frame/FrameForm.js
25
+ var FrameForm_exports = {};
26
+ __export(FrameForm_exports, {
27
+ default: () => FrameForm
28
+ });
29
+ module.exports = __toCommonJS(FrameForm_exports);
30
+ var import_js_toolkit = require("@studiometa/js-toolkit");
31
+ var FrameForm = class extends import_js_toolkit.Base {
32
+ get action() {
33
+ return this.$el.action;
34
+ }
35
+ onSubmit(event) {
36
+ this.$emit("frame-submit", event);
37
+ }
38
+ };
39
+ __publicField(FrameForm, "config", {
40
+ name: "FrameForm",
41
+ emits: ["frame-submit"]
42
+ });
43
+ if (module.exports.default) module.exports = module.exports.default;
@@ -0,0 +1,32 @@
1
+ /**
2
+ * @typedef {FrameForm & {
3
+ * $el: HTMLFormElement
4
+ * }} FrameFormInterface
5
+ */
6
+ /**
7
+ * FrameForm class.
8
+ */
9
+ export default class FrameForm extends Base {
10
+ static config: {
11
+ name: string;
12
+ emits: string[];
13
+ };
14
+ /**
15
+ * Get the form action.
16
+ *
17
+ * @this {FrameFormInterface}
18
+ * @returns {string}
19
+ */
20
+ get action(): string;
21
+ /**
22
+ * Dispatch the form `submit` event.
23
+ *
24
+ * @param {SubmitEvent} event
25
+ * @returns {void}
26
+ */
27
+ onSubmit(event: SubmitEvent): void;
28
+ }
29
+ export type FrameFormInterface = FrameForm & {
30
+ $el: HTMLFormElement;
31
+ };
32
+ import { Base } from "@studiometa/js-toolkit";
@@ -0,0 +1 @@
1
+ import{Base as e}from"@studiometa/js-toolkit";class m extends e{static config={name:"FrameForm",emits:["frame-submit"]};get action(){return this.$el.action}onSubmit(t){this.$emit("frame-submit",t)}}export{m as default};
@@ -0,0 +1,92 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
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
+ var __publicField = (obj, key, value) => {
20
+ __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
21
+ return value;
22
+ };
23
+
24
+ // packages/ui/organisms/Frame/FrameTarget.js
25
+ var FrameTarget_exports = {};
26
+ __export(FrameTarget_exports, {
27
+ default: () => FrameTarget
28
+ });
29
+ module.exports = __toCommonJS(FrameTarget_exports);
30
+ var import_utils = require("@studiometa/js-toolkit/utils");
31
+ var import_primitives = require("../../primitives/index.cjs");
32
+ var _FrameTarget = class extends import_primitives.Transition {
33
+ get $options() {
34
+ const options = super.$options;
35
+ options.leaveKeep = true;
36
+ return options;
37
+ }
38
+ get id() {
39
+ return this.$options.id ?? this.$el.id;
40
+ }
41
+ async enter() {
42
+ this.$log("enter");
43
+ const { enterFrom: from, enterActive: active, enterTo: to, leaveTo } = this.$options;
44
+ const transitionStyles = { from, active, to };
45
+ switch (this.$options.mode) {
46
+ case "append":
47
+ case "prepend":
48
+ await Promise.all(Array.from(this.$el.children).filter((child) => from.split(" ").every((className) => child.classList.contains(className))).map((child) => {
49
+ return (0, import_utils.transition)(child, transitionStyles);
50
+ }));
51
+ break;
52
+ case "replace":
53
+ default:
54
+ transitionStyles.from = Array.from(new Set([from, leaveTo].flat())).join(" ");
55
+ await (0, import_utils.transition)(this.$el, transitionStyles);
56
+ }
57
+ }
58
+ updateContent(newTarget) {
59
+ switch (this.$options.mode) {
60
+ case "prepend":
61
+ case "append":
62
+ Array.from(newTarget.$el.children).forEach((child) => {
63
+ child.classList.add(...this.$options.enterFrom.split(" "));
64
+ });
65
+ this.$el.insertAdjacentHTML(_FrameTarget.__INSERT_MODES[this.$options.mode], newTarget.$el.innerHTML);
66
+ break;
67
+ case "replace":
68
+ default:
69
+ this.$el.innerHTML = newTarget.$el.innerHTML;
70
+ break;
71
+ }
72
+ }
73
+ };
74
+ var FrameTarget = _FrameTarget;
75
+ __publicField(FrameTarget, "config", {
76
+ ...import_primitives.Transition.config,
77
+ name: "FrameTarget",
78
+ log: true,
79
+ options: {
80
+ ...import_primitives.Transition.config.options,
81
+ mode: {
82
+ type: String,
83
+ default: "replace"
84
+ },
85
+ id: String
86
+ }
87
+ });
88
+ __publicField(FrameTarget, "__INSERT_MODES", {
89
+ prepend: "afterbegin",
90
+ append: "beforeend"
91
+ });
92
+ if (module.exports.default) module.exports = module.exports.default;
@@ -0,0 +1,47 @@
1
+ /**
2
+ * FrameTarget class.
3
+ */
4
+ export default class FrameTarget extends Transition {
5
+ /**
6
+ * Config.
7
+ */
8
+ static config: {
9
+ name: string;
10
+ log: boolean;
11
+ options: {
12
+ mode: {
13
+ type: StringConstructor;
14
+ default: string;
15
+ };
16
+ id: StringConstructor;
17
+ enterFrom: StringConstructor;
18
+ enterActive: StringConstructor;
19
+ enterTo: StringConstructor;
20
+ enterKeep: BooleanConstructor;
21
+ leaveFrom: StringConstructor;
22
+ leaveActive: StringConstructor;
23
+ leaveTo: StringConstructor;
24
+ leaveKeep: BooleanConstructor;
25
+ };
26
+ };
27
+ /**
28
+ * Insert modes.
29
+ */
30
+ static __INSERT_MODES: {
31
+ prepend: string;
32
+ append: string;
33
+ };
34
+ /**
35
+ * Get uniq ID.
36
+ * @returns {string}
37
+ */
38
+ get id(): string;
39
+ /**
40
+ * Update the content from the new target.
41
+ *
42
+ * @param {FrameTarget} newTarget The instance of the new target.
43
+ * @returns {void}
44
+ */
45
+ updateContent(newTarget: FrameTarget): void;
46
+ }
47
+ import { Transition } from "../../primitives/index.js";
@@ -0,0 +1 @@
1
+ import{transition as s}from"@studiometa/js-toolkit/utils";import{Transition as r}from"../../primitives/index.js";class o extends r{static config={...r.config,name:"FrameTarget",log:!0,options:{...r.config.options,mode:{type:String,default:"replace"},id:String}};static __INSERT_MODES={prepend:"afterbegin",append:"beforeend"};get $options(){const e=super.$options;return e.leaveKeep=!0,e}get id(){return this.$options.id??this.$el.id}async enter(){this.$log("enter");const{enterFrom:e,enterActive:t,enterTo:a,leaveTo:p}=this.$options,i={from:e,active:t,to:a};switch(this.$options.mode){case"append":case"prepend":await Promise.all(Array.from(this.$el.children).filter(n=>e.split(" ").every(l=>n.classList.contains(l))).map(n=>s(n,i)));break;case"replace":default:i.from=Array.from(new Set([e,p].flat())).join(" "),await s(this.$el,i)}}updateContent(e){switch(this.$options.mode){case"prepend":case"append":Array.from(e.$el.children).forEach(t=>{t.classList.add(...this.$options.enterFrom.split(" "))}),this.$el.insertAdjacentHTML(o.__INSERT_MODES[this.$options.mode],e.$el.innerHTML);break;case"replace":default:this.$el.innerHTML=e.$el.innerHTML;break}}}export{o as default};
@@ -0,0 +1,35 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod));
20
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
21
+
22
+ // packages/ui/organisms/Frame/index.js
23
+ var Frame_exports = {};
24
+ __export(Frame_exports, {
25
+ Frame: () => import_Frame.default,
26
+ FrameAnchor: () => import_FrameAnchor.default,
27
+ FrameForm: () => import_FrameForm.default,
28
+ FrameTarget: () => import_FrameTarget.default
29
+ });
30
+ module.exports = __toCommonJS(Frame_exports);
31
+ var import_Frame = __toESM(require("./Frame.cjs"), 1);
32
+ var import_FrameAnchor = __toESM(require("./FrameAnchor.cjs"), 1);
33
+ var import_FrameForm = __toESM(require("./FrameForm.cjs"), 1);
34
+ var import_FrameTarget = __toESM(require("./FrameTarget.cjs"), 1);
35
+ if (module.exports.default) module.exports = module.exports.default;
@@ -0,0 +1,4 @@
1
+ export { default as Frame } from "./Frame.js";
2
+ export { default as FrameAnchor } from "./FrameAnchor.js";
3
+ export { default as FrameForm } from "./FrameForm.js";
4
+ export { default as FrameTarget } from "./FrameTarget.js";
@@ -0,0 +1 @@
1
+ import{default as e}from"./Frame.js";import{default as m}from"./FrameAnchor.js";import{default as f}from"./FrameForm.js";import{default as d}from"./FrameTarget.js";export{e as Frame,m as FrameAnchor,f as FrameForm,d as FrameTarget};
@@ -2,22 +2,19 @@ var __defProp = Object.defineProperty;
2
2
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
3
  var __getOwnPropNames = Object.getOwnPropertyNames;
4
4
  var __hasOwnProp = Object.prototype.hasOwnProperty;
5
- var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
6
- var __reExport = (target, module2, copyDefault, desc) => {
7
- if (module2 && typeof module2 === "object" || typeof module2 === "function") {
8
- for (let key of __getOwnPropNames(module2))
9
- if (!__hasOwnProp.call(target, key) && (copyDefault || key !== "default"))
10
- __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
5
+ var __copyProps = (to, from, except, desc) => {
6
+ if (from && typeof from === "object" || typeof from === "function") {
7
+ for (let key of __getOwnPropNames(from))
8
+ if (!__hasOwnProp.call(to, key) && key !== except)
9
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
11
10
  }
12
- return target;
11
+ return to;
13
12
  };
14
- var __toCommonJS = /* @__PURE__ */ ((cache) => {
15
- return (module2, temp) => {
16
- return cache && cache.get(module2) || (temp = __reExport(__markAsModule({}), module2, 1), cache && cache.set(module2, temp), temp);
17
- };
18
- })(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0);
13
+ var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
14
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
15
 
20
16
  // packages/ui/organisms/index.js
21
17
  var organisms_exports = {};
22
18
  module.exports = __toCommonJS(organisms_exports);
19
+ __reExport(organisms_exports, require("./Frame/index.cjs"), module.exports);
23
20
  if (module.exports.default) module.exports = module.exports.default;
@@ -1 +1 @@
1
- export {};
1
+ export * from "./Frame/index.js";
@@ -0,0 +1 @@
1
+ export*from"./Frame/index.js";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@studiometa/ui",
3
- "version": "0.2.1",
3
+ "version": "0.2.4",
4
4
  "description": "A set of opiniated, unstyled and accessible components",
5
5
  "publishConfig": {
6
6
  "access": "public"
@@ -29,8 +29,7 @@
29
29
  },
30
30
  "homepage": "https://github.com/studiometa/ui#readme",
31
31
  "dependencies": {
32
- "@studiometa/js-toolkit": "^2.0.0-beta.15",
33
- "deepmerge": "^4.2.2",
34
- "motion": "^10.5.0"
32
+ "@studiometa/js-toolkit": "^2.0.0-rc.2",
33
+ "deepmerge": "^4.2.2"
35
34
  }
36
35
  }
@@ -3,24 +3,19 @@ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
3
  var __getOwnPropNames = Object.getOwnPropertyNames;
4
4
  var __hasOwnProp = Object.prototype.hasOwnProperty;
5
5
  var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
6
- var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
7
6
  var __export = (target, all) => {
8
7
  for (var name in all)
9
8
  __defProp(target, name, { get: all[name], enumerable: true });
10
9
  };
11
- var __reExport = (target, module2, copyDefault, desc) => {
12
- if (module2 && typeof module2 === "object" || typeof module2 === "function") {
13
- for (let key of __getOwnPropNames(module2))
14
- if (!__hasOwnProp.call(target, key) && (copyDefault || key !== "default"))
15
- __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
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 });
16
15
  }
17
- return target;
16
+ return to;
18
17
  };
19
- var __toCommonJS = /* @__PURE__ */ ((cache) => {
20
- return (module2, temp) => {
21
- return cache && cache.get(module2) || (temp = __reExport(__markAsModule({}), module2, 1), cache && cache.set(module2, temp), temp);
22
- };
23
- })(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0);
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
24
19
  var __publicField = (obj, key, value) => {
25
20
  __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
26
21
  return value;
@@ -31,16 +26,14 @@ var Draggable_exports = {};
31
26
  __export(Draggable_exports, {
32
27
  default: () => Draggable
33
28
  });
34
- var import_motion = require("motion");
29
+ module.exports = __toCommonJS(Draggable_exports);
35
30
  var import_js_toolkit = require("@studiometa/js-toolkit");
36
- var _Draggable = class extends (0, import_js_toolkit.withDrag)(import_js_toolkit.Base) {
37
- constructor() {
38
- super(...arguments);
39
- __publicField(this, "x", 0);
40
- __publicField(this, "y", 0);
41
- __publicField(this, "originX", 0);
42
- __publicField(this, "originY", 0);
43
- }
31
+ var import_utils = require("@studiometa/js-toolkit/utils");
32
+ var Draggable = class extends (0, import_js_toolkit.withDrag)(import_js_toolkit.Base) {
33
+ x = 0;
34
+ y = 0;
35
+ originX = 0;
36
+ originY = 0;
44
37
  dragged(props) {
45
38
  if (props.mode === "start") {
46
39
  this.originX = this.x;
@@ -49,16 +42,10 @@ var _Draggable = class extends (0, import_js_toolkit.withDrag)(import_js_toolkit
49
42
  }
50
43
  this.x = this.originX + props.x - props.origin.x;
51
44
  this.y = this.originY + props.y - props.origin.y;
52
- (0, import_motion.animate)(this.$el, { x: this.x, y: this.y }, _Draggable.animateOptions);
45
+ this.$el.style.transform = (0, import_utils.matrix)({ translateX: this.x, translateY: this.y });
53
46
  }
54
47
  };
55
- var Draggable = _Draggable;
56
48
  __publicField(Draggable, "config", {
57
49
  name: "DraggableElement"
58
50
  });
59
- __publicField(Draggable, "animateOptions", {
60
- easing: "linear",
61
- duration: 0
62
- });
63
- module.exports = __toCommonJS(Draggable_exports);
64
51
  if (module.exports.default) module.exports = module.exports.default;
@@ -5,11 +5,6 @@ export default class Draggable extends Base {
5
5
  static config: {
6
6
  name: string;
7
7
  };
8
- /**
9
- * Options for the animate function.
10
- * @type {import('motion').AnimationListOptions}
11
- */
12
- static animateOptions: import('motion').AnimationListOptions;
13
8
  /**
14
9
  * Horizontal transformation.
15
10
  * @type {number}