ziko 0.0.14 → 0.0.16

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 (291) hide show
  1. package/dist/ziko.cjs +13435 -11825
  2. package/dist/ziko.js +13958 -12406
  3. package/dist/ziko.min.js +2 -2
  4. package/dist/ziko.mjs +13401 -11859
  5. package/package.json +2 -1
  6. package/src/__helpers__/index.js +61 -41
  7. package/src/app/index.js +21 -12
  8. package/src/app/json-style-sheet.js +64 -0
  9. package/src/app/params.js +40 -0
  10. package/src/app/routes.js +58 -0
  11. package/src/app/spa-file-based-routing.js +74 -0
  12. package/src/app/spa.js +55 -0
  13. package/src/app/ziko-app.js +39 -0
  14. package/src/data/api/fetchdom.js +13 -13
  15. package/src/data/api/index.js +3 -3
  16. package/src/data/api/preload.js +10 -10
  17. package/src/data/converter/adoc.js +130 -130
  18. package/src/data/converter/array.js +42 -42
  19. package/src/data/converter/canvas.js +24 -24
  20. package/src/data/converter/css.js +37 -0
  21. package/src/data/converter/csv.js +32 -32
  22. package/src/data/converter/idea.txt +9 -9
  23. package/src/data/converter/index.js +37 -34
  24. package/src/data/converter/json.js +80 -80
  25. package/src/data/converter/markdown.js +95 -95
  26. package/src/data/converter/object.js +69 -69
  27. package/src/data/converter/svg.js +10 -10
  28. package/src/data/index.js +16 -73
  29. package/src/data/parser/index.js +1 -0
  30. package/src/data/parser/xml.js +46 -46
  31. package/src/data/string/patterns.js +11 -11
  32. package/src/data/string/string.js +169 -169
  33. package/src/{app/app.js → global/app/index.js} +45 -45
  34. package/src/{app → global}/component/index.js +38 -38
  35. package/src/global/globals/index.js +20 -0
  36. package/src/global/index.js +12 -0
  37. package/src/{app → global}/params/index.js +39 -39
  38. package/src/{app → global}/router/index.js +66 -66
  39. package/src/{app → global}/seo/index.js +42 -42
  40. package/src/global/style/index.js +1 -0
  41. package/src/{app → global}/themes/dark.js +884 -884
  42. package/src/{app → global}/themes/index.js +10 -10
  43. package/src/{app → global}/themes/light.js +254 -254
  44. package/src/graphics/canvas/canvas.js +188 -188
  45. package/src/graphics/canvas/elements/Basic/arc.js +42 -42
  46. package/src/graphics/canvas/elements/Basic/line.js +25 -25
  47. package/src/graphics/canvas/elements/Basic/points.js +47 -47
  48. package/src/graphics/canvas/elements/Basic/polygon.js +6 -6
  49. package/src/graphics/canvas/elements/Basic/rect.js +45 -45
  50. package/src/graphics/canvas/elements/Chart/scatter.js +2 -2
  51. package/src/graphics/canvas/elements/Element.js +114 -114
  52. package/src/graphics/canvas/elements/index.js +12 -12
  53. package/src/graphics/canvas/index.js +14 -14
  54. package/src/graphics/canvas/utils/color.js +7 -7
  55. package/src/graphics/canvas/utils/floodFill.js +57 -57
  56. package/src/graphics/index.js +68 -68
  57. package/src/graphics/svg/Elements/Basic/circle.js +25 -25
  58. package/src/graphics/svg/Elements/Basic/ellipse.js +20 -20
  59. package/src/graphics/svg/Elements/Basic/foreignObject.js +32 -32
  60. package/src/graphics/svg/Elements/Basic/groupe.js +29 -29
  61. package/src/graphics/svg/Elements/Basic/image.js +32 -32
  62. package/src/graphics/svg/Elements/Basic/line.js +28 -28
  63. package/src/graphics/svg/Elements/Basic/link.js +30 -30
  64. package/src/graphics/svg/Elements/Basic/path.js +58 -58
  65. package/src/graphics/svg/Elements/Basic/polygon.js +31 -31
  66. package/src/graphics/svg/Elements/Basic/polyline.js +3 -3
  67. package/src/graphics/svg/Elements/Basic/rect.js +42 -42
  68. package/src/graphics/svg/Elements/Basic/text.js +25 -25
  69. package/src/graphics/svg/Elements/Derived/grid.js +8 -8
  70. package/src/graphics/svg/Elements/ZikoSvgElement.js +46 -46
  71. package/src/graphics/svg/Elements/index.js +14 -14
  72. package/src/graphics/svg/index.js +1 -1
  73. package/src/graphics/svg/svg.js +114 -114
  74. package/src/index.js +84 -88
  75. package/src/math/calculus/derivation/index.js +7 -0
  76. package/src/math/calculus/index.js +2 -1
  77. package/src/math/calculus/special-functions/bessel.js +30 -30
  78. package/src/math/calculus/special-functions/beta.js +37 -37
  79. package/src/math/calculus/special-functions/gamma.js +29 -29
  80. package/src/math/calculus/special-functions/index.js +4 -4
  81. package/src/math/complex/index.js +202 -202
  82. package/src/math/const.js +2 -2
  83. package/src/math/discret/Combinaison/index.js +33 -33
  84. package/src/math/discret/Conversion/index.js +85 -85
  85. package/src/math/discret/Logic/index.js +45 -45
  86. package/src/math/discret/Permutation/index.js +30 -30
  87. package/src/math/discret/Set/index.js +1 -1
  88. package/src/math/discret/Set/power-set.js +14 -14
  89. package/src/math/discret/Set/sub-set.js +10 -10
  90. package/src/math/discret/index.js +12 -23
  91. package/src/math/functions/helper.js +20 -0
  92. package/src/math/functions/index.js +161 -181
  93. package/src/math/index.js +32 -189
  94. package/src/math/matrix/Decomposition.js +90 -90
  95. package/src/math/matrix/LinearSystem.js +9 -9
  96. package/src/math/matrix/Matrix.js +716 -716
  97. package/src/math/matrix/index.js +2 -2
  98. package/src/math/random/index.js +172 -172
  99. package/src/math/signal/__np.py.txt +39 -39
  100. package/src/math/signal/conv.js +174 -174
  101. package/src/math/signal/fft.js +54 -54
  102. package/src/math/signal/filter.js +38 -38
  103. package/src/math/signal/functions.js +145 -145
  104. package/src/math/signal/index.js +109 -109
  105. package/src/math/statistics/Functions/index.js +99 -99
  106. package/src/math/statistics/index.js +15 -15
  107. package/src/math/utils/arithmetic.js +138 -138
  108. package/src/math/utils/checkers.js +29 -29
  109. package/src/math/utils/conversions.js +19 -19
  110. package/src/math/utils/discret.js +51 -51
  111. package/src/math/utils/index.js +101 -101
  112. package/src/math/utils/mapfun.js +49 -49
  113. package/src/reactivity/events/{Partiel/Input.js → Input.js} +62 -59
  114. package/src/reactivity/events/{Global/Pointer.js → Pointer.js} +232 -234
  115. package/src/reactivity/events/ZikoEvent.js +90 -90
  116. package/src/reactivity/events/{Global/Click.js → click.js} +60 -56
  117. package/src/reactivity/events/{Global/Clipboard.js → clipboard.js} +88 -84
  118. package/src/reactivity/events/{Global/CustomEvent.js → custom-event.js} +57 -53
  119. package/src/reactivity/events/{Global/Drag.js → drag.js} +136 -136
  120. package/src/reactivity/events/{Global/Focus.js → focus.js} +59 -56
  121. package/src/reactivity/events/{Partiel/Hash.js → hash.js} +47 -44
  122. package/src/reactivity/events/index.js +62 -62
  123. package/src/reactivity/events/{Global/Key.js → key.js} +102 -104
  124. package/src/reactivity/events/{Global/Mouse.js → mouse.js} +233 -230
  125. package/src/reactivity/events/{Global/Swipe.js → swipe.js} +149 -147
  126. package/src/reactivity/events/{Global/Wheel.js → wheel.js} +47 -44
  127. package/src/reactivity/hooks/{Contexte → contexte}/useSuccesifKeys.js +13 -13
  128. package/src/reactivity/hooks/{Decorators → decorators}/index.js +6 -6
  129. package/src/reactivity/hooks/{Decorators → decorators}/time.js +16 -16
  130. package/src/reactivity/hooks/{Decorators → decorators}/type.js +87 -87
  131. package/src/reactivity/hooks/head/index.js +5 -0
  132. package/src/reactivity/hooks/{UI → head}/useCssText.js +21 -21
  133. package/src/reactivity/hooks/{UI → head}/useFavIcon.js +37 -37
  134. package/src/reactivity/hooks/head/useHead.js +28 -0
  135. package/src/reactivity/hooks/head/useMeta.js +52 -0
  136. package/src/reactivity/hooks/{UI → head}/useTitle.js +29 -29
  137. package/src/reactivity/hooks/index.js +91 -85
  138. package/src/reactivity/hooks/{Interactions → interactions}/index.js +3 -3
  139. package/src/reactivity/hooks/{Interactions → interactions}/useBluetooth.js +47 -47
  140. package/src/reactivity/hooks/{Interactions → interactions}/useChannel.js +49 -49
  141. package/src/reactivity/hooks/{Interactions → interactions}/useEventEmmiter.js +63 -63
  142. package/src/reactivity/hooks/{Interactions → interactions}/useThread.js +43 -43
  143. package/src/reactivity/hooks/sensors/index.js +2 -0
  144. package/src/reactivity/hooks/{Sensors → sensors}/useBattery.js +35 -35
  145. package/src/reactivity/hooks/{Sensors → sensors}/useGeolocation.js +16 -16
  146. package/src/reactivity/hooks/{Storage → storage}/useStorage.js +72 -72
  147. package/src/reactivity/hooks/todo.md +26 -26
  148. package/src/reactivity/hooks/ui/index.js +5 -0
  149. package/src/reactivity/hooks/{UI → ui}/useMediaQuery.js +43 -43
  150. package/src/reactivity/hooks/{UI → ui}/useStyle.js +79 -79
  151. package/src/reactivity/hooks/{UI → ui}/useTheme.js +61 -61
  152. package/src/reactivity/idea +1 -1
  153. package/src/reactivity/index.js +11 -21
  154. package/src/reactivity/observer/attributes.js +28 -28
  155. package/src/reactivity/observer/children.js +36 -36
  156. package/src/reactivity/observer/index.js +6 -44
  157. package/src/reactivity/observer/intersection.js +43 -43
  158. package/src/reactivity/observer/mutation.js +112 -112
  159. package/src/reactivity/observer/resize.js +46 -46
  160. package/src/reactivity/observer/screen.js +44 -44
  161. package/src/reactivity/observer/screen.js.txt +83 -83
  162. package/src/reactivity/observer/screen.txt +12 -12
  163. package/src/time/animation.js +75 -75
  164. package/src/time/index.js +12 -54
  165. package/src/time/loop.js +87 -87
  166. package/src/time/utils/decorators.js +16 -16
  167. package/src/time/utils/ease.js +143 -143
  168. package/src/time/utils/index.js +17 -17
  169. package/src/time/utils/performance.js +15 -15
  170. package/src/time/utils/ui.js +25 -25
  171. package/src/types.js +73 -71
  172. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/accordion/accordion.js +42 -45
  173. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/accordion/collapsible.js +82 -82
  174. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/accordion/index.js +1 -1
  175. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/alert/alert.js +80 -80
  176. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/alert/palette.js +51 -51
  177. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/carousel/index.js +50 -50
  178. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/code-note/SubElements.js.txt +104 -104
  179. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/code-note/code-cell.js +194 -194
  180. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/code-note/code-note.js +71 -71
  181. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/code-note/index.js +1 -1
  182. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/code-note/sub-elements.js +66 -66
  183. package/src/{user-interface → ui}/elements/derived/elements/Swipper.js +3 -3
  184. package/src/{user-interface → ui}/elements/derived/elements/index.js +9 -9
  185. package/src/{user-interface/elements/derived/Flex.js → ui/elements/derived/flex/index.js} +102 -102
  186. package/src/{user-interface/elements/derived/Grid.js → ui/elements/derived/grid/index.js} +32 -32
  187. package/src/ui/elements/derived/index.js +12 -0
  188. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/menu/menu3d.js +259 -259
  189. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/modal/index.js +91 -91
  190. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/pagination/breadcrumbs.js +53 -53
  191. package/src/ui/elements/derived/slider/__ZikoUISlider__.js +112 -0
  192. package/src/ui/elements/derived/slider/hSlider.js +34 -0
  193. package/src/ui/elements/derived/slider/index.js +12 -0
  194. package/src/ui/elements/derived/slider/vSlider.js +27 -0
  195. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/splitter/__ZikoUISplitter__.js +61 -61
  196. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/splitter/hsplitter.js +39 -39
  197. package/src/ui/elements/derived/splitter/index.js +12 -0
  198. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/splitter/vsplitter.js +39 -39
  199. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/tabs/index.js +179 -179
  200. package/src/{user-interface → ui}/elements/primitives/ZikoUIContainerElement.js +126 -126
  201. package/src/{user-interface → ui}/elements/primitives/ZikoUIElement.js +492 -480
  202. package/src/{user-interface → ui}/elements/primitives/embaded/html.js +19 -20
  203. package/src/{user-interface → ui}/elements/primitives/embaded/index.js +3 -3
  204. package/src/{user-interface → ui}/elements/primitives/embaded/pdf.js +16 -17
  205. package/src/{user-interface → ui}/elements/primitives/embaded/youtube.js +23 -25
  206. package/src/{user-interface → ui}/elements/primitives/index.js +7 -7
  207. package/src/{user-interface → ui}/elements/primitives/io/Form/index.js +41 -41
  208. package/src/{user-interface → ui}/elements/primitives/io/Form/index.js.txt +104 -104
  209. package/src/{user-interface → ui}/elements/primitives/io/Inputs/__helpers__.js +51 -51
  210. package/src/{user-interface → ui}/elements/primitives/io/Inputs/index.js +12 -12
  211. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input/index.js +98 -98
  212. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-camera/index.js +26 -26
  213. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-checkbox/index.js +25 -25
  214. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-color/index.js +15 -15
  215. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-date-time/index.js +2 -2
  216. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-date-time/input-date-time.js +13 -13
  217. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-date-time/input-date.js +13 -13
  218. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-date-time/input-time.js +13 -13
  219. package/src/ui/elements/primitives/io/Inputs/input-email-password/index.js +2 -0
  220. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-email-password/input-email.js +14 -14
  221. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-email-password/input-password.js +13 -13
  222. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-file/input-image.js +42 -42
  223. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-number/index.js +36 -36
  224. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-radio/index.js +25 -25
  225. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-search/index.js +45 -45
  226. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-slider/index.js +34 -34
  227. package/src/{user-interface → ui}/elements/primitives/io/Select/index.js +19 -19
  228. package/src/{user-interface → ui}/elements/primitives/io/Textarea/index.js +17 -17
  229. package/src/{user-interface → ui}/elements/primitives/io/index.js +3 -3
  230. package/src/{user-interface → ui}/elements/primitives/list/index.js +138 -138
  231. package/src/{user-interface → ui}/elements/primitives/media/Audio/index.js +16 -16
  232. package/src/{user-interface → ui}/elements/primitives/media/Image/figure.js +18 -18
  233. package/src/{user-interface → ui}/elements/primitives/media/Image/image.js +36 -36
  234. package/src/ui/elements/primitives/media/Image/index.js +2 -0
  235. package/src/{user-interface → ui}/elements/primitives/media/Video/index.js +26 -26
  236. package/src/{user-interface → ui}/elements/primitives/media/__ZikoUIDynamicMediaELement__.js +46 -46
  237. package/src/{user-interface → ui}/elements/primitives/media/index.js +2 -2
  238. package/src/{user-interface → ui}/elements/primitives/misc/index.js +101 -100
  239. package/src/ui/elements/primitives/misc/xml-wrapper.js +37 -0
  240. package/src/{user-interface → ui}/elements/primitives/semantic/index.js +81 -81
  241. package/src/{user-interface → ui}/elements/primitives/table/elements.js +93 -93
  242. package/src/ui/elements/primitives/table/index.js +3 -0
  243. package/src/{user-interface → ui}/elements/primitives/table/table.js +115 -115
  244. package/src/{user-interface → ui}/elements/primitives/table/utils.js +11 -11
  245. package/src/{user-interface → ui}/elements/primitives/text/__ZikoUIText__.js +71 -71
  246. package/src/{user-interface → ui}/elements/primitives/text/heading.js +35 -35
  247. package/src/{user-interface → ui}/elements/primitives/text/index.js +2 -2
  248. package/src/{user-interface → ui}/elements/primitives/text/p.js +26 -26
  249. package/src/{user-interface → ui}/elements/primitives/text/text.js +80 -80
  250. package/src/ui/index.js +29 -0
  251. package/src/{user-interface → ui}/style/index.js +515 -509
  252. package/src/{user-interface → ui}/utils/index.js +69 -69
  253. package/src/reactivity/events/Global/Touch.js +0 -0
  254. package/src/reactivity/hooks/Sensors/index.js +0 -2
  255. package/src/reactivity/hooks/UI/index.js +0 -5
  256. package/src/user-interface/elements/derived/elements/splitter/index.js +0 -2
  257. package/src/user-interface/elements/derived/index.js +0 -3
  258. package/src/user-interface/elements/primitives/io/Inputs/input-email-password/index.js +0 -2
  259. package/src/user-interface/elements/primitives/media/Image/index.js +0 -2
  260. package/src/user-interface/elements/primitives/table/index.js +0 -3
  261. package/src/user-interface/index.js +0 -190
  262. /package/src/app/{globals/index.js → globals.js} +0 -0
  263. /package/src/reactivity/events/{Partiel/Media.js → media.js} +0 -0
  264. /package/src/{app/accessibility/index.js → reactivity/events/touch.js} +0 -0
  265. /package/src/reactivity/hooks/{Contexte → contexte}/index.js +0 -0
  266. /package/src/reactivity/hooks/{Interactions → interactions}/useSerial.js +0 -0
  267. /package/src/reactivity/hooks/{Interactions → interactions}/useUsb.js +0 -0
  268. /package/src/reactivity/hooks/{Sensors → sensors}/useCamera.js +0 -0
  269. /package/src/reactivity/hooks/{Sensors → sensors}/useMicro.js +0 -0
  270. /package/src/reactivity/hooks/{Sensors → sensors}/useOrientation.js +0 -0
  271. /package/src/reactivity/hooks/{Storage → storage}/index.js +0 -0
  272. /package/src/reactivity/hooks/{Storage → storage}/useCookie.js +0 -0
  273. /package/src/reactivity/hooks/{Storage → storage}/useIndexedDb.js +0 -0
  274. /package/src/reactivity/hooks/{UI → ui}/useCssLink.js +0 -0
  275. /package/src/reactivity/hooks/{UI → ui}/useLinearGradient.js +0 -0
  276. /package/src/reactivity/hooks/{UI → ui}/useRadialGradient.js +0 -0
  277. /package/src/{user-interface/elements/derived/elements → ui/elements/derived}/alert/index.js +0 -0
  278. /package/src/{user-interface → ui}/elements/derived/elements/Notification.js +0 -0
  279. /package/src/{user-interface → ui}/elements/derived/elements/Popover.js +0 -0
  280. /package/src/{user-interface → ui}/elements/derived/elements/Popup.js +0 -0
  281. /package/src/{user-interface → ui}/elements/derived/elements/Timeline.js +0 -0
  282. /package/src/{user-interface → ui}/elements/derived/elements/Toast.js +0 -0
  283. /package/src/{user-interface → ui}/elements/derived/elements/Treeview.js +0 -0
  284. /package/src/{user-interface → ui}/elements/derived/elements/columns.js +0 -0
  285. /package/src/{user-interface → ui}/elements/derived/elements/fab.js +0 -0
  286. /package/src/{user-interface/elements/derived/elements → ui/elements/derived}/menu/index.js +0 -0
  287. /package/src/{user-interface/elements/derived/elements → ui/elements/derived}/pagination/index.js +0 -0
  288. /package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-file/index.js +0 -0
  289. /package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-file/input-file.js +0 -0
  290. /package/src/{user-interface → ui}/elements/primitives/list/elements.js +0 -0
  291. /package/src/{user-interface → ui}/elements/primitives/text/pre.js +0 -0
@@ -1,92 +1,92 @@
1
- import ZikoUIContainerElement from "../../../primitives/ZikoUIContainerElement.js";
2
- class ZikoUIModal extends ZikoUIContainerElement{
3
- constructor(...UIElements){
4
- super("dialog", "modal")
5
- this.append(...UIElements);
6
- Object.assign(this.cache,{
7
- config:{
8
- mode:"modal",
9
- useTransition:true
10
- }
11
- });
12
- this.style({
13
- display:"flex",
14
- justifyContent:"center",
15
- alignItems:"center",
16
- position: "absolute",
17
- top: "50%",
18
- left: "50%",
19
- transform: "translate(-50%, -50%)",
20
- padding: "20px",
21
- border: "none",
22
- backgroundCcolor: "#f5f5f5",
23
- boxShadow: "0px 4px 10px rgba(0, 0, 0, 0.1)",
24
- borderRadius: "8px"
25
- });
26
- this.close()
27
- }
28
- open(){
29
- if(!this.element.open){
30
- switch(this.cache.config.mode){
31
- case "modal": this.element.showModal(); break;
32
- case "dialog": this.element.show(); break;
33
- default : this.element.show(); break;
34
- }
35
- // this.style({
36
- // display : "flex",
37
- // })
38
- this.st.fadeIn(1000)
39
- this.emit("modal:opened");
40
- }
41
- return this;
42
- }
43
- close(){
44
- // this.style({
45
- // display : "none"
46
- // })
47
- this.st.fadeOut(1000)
48
- if(this.element.open){
49
- this.element.close();
50
- }
51
- this.emit("modal:closed");
52
- return this;
53
- }
54
- closeAfter(t = 1000){
55
- globalThis?.setTimeout(()=>this.close(), t);
56
- return this;
57
- }
58
- onOpen(callback){
59
- this.on("modal:opened",callback.bind(this));
60
- return this;
61
- }
62
- onClose(callback){
63
- this.on("modal:closed",callback.bind(this));
64
- return this;
65
- }
66
- useModal(){
67
- this.cache.config.mode = "modal";
68
- return this;
69
- }
70
- useDialog(){
71
- this.cache.config.mode = "dialog";
72
- return this;
73
- }
74
- useTransition(enabled = true){
75
- this.cache.config.useTransition = enabled;
76
- return this;
77
- }
78
- }
79
-
80
- const Modal=(...UIElements)=>new ZikoUIModal(...UIElements);
81
- export{
82
- Modal,
83
- ZikoUIModal
84
- }
85
-
86
- /*
87
- a=Modal(text("Hello")).style({
88
- width:"100%",
89
- height:"100%"
90
- })
91
- Flex(a).size("400px","400px").style({border:"1px red solid"})
1
+ import ZikoUIContainerElement from "../../primitives/ZikoUIContainerElement.js";
2
+ class ZikoUIModal extends ZikoUIContainerElement{
3
+ constructor(...UIElements){
4
+ super("dialog", "modal")
5
+ this.append(...UIElements);
6
+ Object.assign(this.cache,{
7
+ config:{
8
+ mode:"modal",
9
+ useTransition:true
10
+ }
11
+ });
12
+ this.style({
13
+ display:"flex",
14
+ justifyContent:"center",
15
+ alignItems:"center",
16
+ position: "absolute",
17
+ top: "50%",
18
+ left: "50%",
19
+ transform: "translate(-50%, -50%)",
20
+ padding: "20px",
21
+ border: "none",
22
+ backgroundCcolor: "#f5f5f5",
23
+ boxShadow: "0px 4px 10px rgba(0, 0, 0, 0.1)",
24
+ borderRadius: "8px"
25
+ });
26
+ this.close()
27
+ }
28
+ open(){
29
+ if(!this.element.open){
30
+ switch(this.cache.config.mode){
31
+ case "modal": this.element.showModal(); break;
32
+ case "dialog": this.element.show(); break;
33
+ default : this.element.show(); break;
34
+ }
35
+ // this.style({
36
+ // display : "flex",
37
+ // })
38
+ this.st.fadeIn(1000)
39
+ this.emit("modal:opened");
40
+ }
41
+ return this;
42
+ }
43
+ close(){
44
+ // this.style({
45
+ // display : "none"
46
+ // })
47
+ this.st.fadeOut(1000)
48
+ if(this.element.open){
49
+ this.element.close();
50
+ }
51
+ this.emit("modal:closed");
52
+ return this;
53
+ }
54
+ closeAfter(t = 1000){
55
+ globalThis?.setTimeout(()=>this.close(), t);
56
+ return this;
57
+ }
58
+ onOpen(callback){
59
+ this.on("modal:opened",callback.bind(this));
60
+ return this;
61
+ }
62
+ onClose(callback){
63
+ this.on("modal:closed",callback.bind(this));
64
+ return this;
65
+ }
66
+ useModal(){
67
+ this.cache.config.mode = "modal";
68
+ return this;
69
+ }
70
+ useDialog(){
71
+ this.cache.config.mode = "dialog";
72
+ return this;
73
+ }
74
+ useTransition(enabled = true){
75
+ this.cache.config.useTransition = enabled;
76
+ return this;
77
+ }
78
+ }
79
+
80
+ const Modal=(...UIElements)=>new ZikoUIModal(...UIElements);
81
+ export{
82
+ Modal,
83
+ ZikoUIModal
84
+ }
85
+
86
+ /*
87
+ a=Modal(text("Hello")).style({
88
+ width:"100%",
89
+ height:"100%"
90
+ })
91
+ Flex(a).size("400px","400px").style({border:"1px red solid"})
92
92
  */
@@ -1,54 +1,54 @@
1
- import ZikoUIElement from "../../../primitives/ZikoUIElement.js";
2
- import { html } from "../../../primitives/misc/index.js";
3
- import { text } from "../../../primitives/text/index.js";
4
- class ZikoUIBreadcrumbs extends ZikoUIElement{
5
- constructor(...items){
6
- super("ul", "Breadcrumbs")
7
- Object.assign(this.cache,{
8
- separatorTextContent:"/"
9
- })
10
- this.style({
11
- listStyle: "none",
12
- display: "flex",
13
- flexWrap: "wrap"
14
- })
15
- this.list=html('li').style({
16
- display: "flex",
17
- flexWrap: "wrap"
18
- });
19
- this.append(...items);
20
- }
21
- #addItem(item){
22
- if(["string","number","boolean"].includes(typeof item))item = text(item);
23
- const li = html("li", item).style({
24
- display: "flex",
25
- alignItems: "center"
26
- });
27
- if(this.element.children.length>0){
28
- const separator = text(this.cache.separatorTextContent).style({
29
- padding: "0 4px"
30
- });
31
- this.element?.append(separator.element);
32
- }
33
- this.element?.append(li.element);
34
- }
35
- append(...items){
36
- items.forEach(n=>this.#addItem(n));
37
- return this;
38
- }
39
- configSeparator(separatorTextContent = this.cache.separator, style = {}){
40
- this.cache.separatorTextContent = separatorTextContent;
41
- const separators = [...this.element.children].filter(n=>n.tagName==="SPAN");
42
- separators.forEach(node=>{
43
- node.textContent = separatorTextContent;
44
- Object.assign(node.style, style);
45
- }
46
- );
47
- return this;
48
- }
49
- }
50
- const Breadcrumbs=(...items)=>new ZikoUIBreadcrumbs(...items);
51
- export{
52
- Breadcrumbs,
53
- ZikoUIBreadcrumbs
1
+ import ZikoUIElement from "../../primitives/ZikoUIElement.js";
2
+ import { html } from "../../primitives/misc/index.js";
3
+ import { text } from "../../primitives/text/index.js";
4
+ class ZikoUIBreadcrumbs extends ZikoUIElement{
5
+ constructor(...items){
6
+ super("ul", "Breadcrumbs")
7
+ Object.assign(this.cache,{
8
+ separatorTextContent:"/"
9
+ })
10
+ this.style({
11
+ listStyle: "none",
12
+ display: "flex",
13
+ flexWrap: "wrap"
14
+ })
15
+ this.list=html('li').style({
16
+ display: "flex",
17
+ flexWrap: "wrap"
18
+ });
19
+ this.append(...items);
20
+ }
21
+ #addItem(item){
22
+ if(["string","number","boolean"].includes(typeof item))item = text(item);
23
+ const li = html("li", item).style({
24
+ display: "flex",
25
+ alignItems: "center"
26
+ });
27
+ if(this.element.children.length>0){
28
+ const separator = text(this.cache.separatorTextContent).style({
29
+ padding: "0 4px"
30
+ });
31
+ this.element?.append(separator.element);
32
+ }
33
+ this.element?.append(li.element);
34
+ }
35
+ append(...items){
36
+ items.forEach(n=>this.#addItem(n));
37
+ return this;
38
+ }
39
+ configSeparator(separatorTextContent = this.cache.separator, style = {}){
40
+ this.cache.separatorTextContent = separatorTextContent;
41
+ const separators = [...this.element.children].filter(n=>n.tagName==="SPAN");
42
+ separators.forEach(node=>{
43
+ node.textContent = separatorTextContent;
44
+ Object.assign(node.style, style);
45
+ }
46
+ );
47
+ return this;
48
+ }
49
+ }
50
+ const Breadcrumbs=(...items)=>new ZikoUIBreadcrumbs(...items);
51
+ export{
52
+ Breadcrumbs,
53
+ ZikoUIBreadcrumbs
54
54
  }
@@ -0,0 +1,112 @@
1
+ import ZikoUIContainerElement from "../../primitives/ZikoUIContainerElement";
2
+ import { Section } from "../../primitives/semantic";
3
+ import { text } from "../../primitives/text";
4
+ import { ZikoUIFlex,Flex } from "../Flex";
5
+ import { ZikoUISection } from "../../primitives/semantic";
6
+ class __ZikoUISlider__ extends ZikoUISection{
7
+ constructor(){
8
+ super("section","");
9
+ Object.assign(this.cache,{
10
+ currentIndex : 0,
11
+ slideBuilder : null,
12
+ })
13
+ this.container = Flex().size("100%","100%").vertical(0,0).style({
14
+ // width:"100%",
15
+ overflow:"hidden"
16
+ });
17
+ // this.style({
18
+ // // width:"100%",
19
+ // overflow:"hidden"
20
+ // });
21
+ this.container.setAttr({
22
+ ariaRoledescription : "carousel",
23
+ ariaLive: "polite",
24
+ ariaLabel : "Content Slider"
25
+ })
26
+ this.track = Section().size("100%","100%").style({
27
+ transition : "transform 0.3s ease-in-out",
28
+ });
29
+ this.bullets = Flex().style({
30
+ // position : "absolute",
31
+ // top : 0,
32
+ gap : "10px",
33
+ padding:"10px",
34
+ })
35
+ this.container.append(
36
+ this.track,
37
+ this.bullets
38
+ )
39
+ this.append(this.container)
40
+ }
41
+ #updateAriaHidden(){
42
+ for(let i=0;i<this.track.items.length;i++){
43
+ this.track[i].setAttr({
44
+ ariaHidden : (i!==this.cache.currentIndex)
45
+ })
46
+ }
47
+ }
48
+ goto(n = 0){
49
+ this.cache.currentIndex = n;
50
+ this.__updatePos();
51
+ this.#updateAriaHidden()
52
+ }
53
+ next(n = 1){
54
+ this.cache.currentIndex += n;
55
+ this.__updatePos();
56
+ this.#updateAriaHidden()
57
+ return this;
58
+ }
59
+ previous(n = 1){
60
+ this.cache.currentIndex -= n;
61
+ this.__updatePos();
62
+ this.#updateAriaHidden()
63
+ return this;
64
+ }
65
+ #update(){
66
+ const length = this.track.items.length;
67
+ for(let i=0;i<length;i++){
68
+ this.track.items[i].setAttr({
69
+ ariaLabel : `Slide ${i+1} of ${length}`,
70
+ dataSlideIndex : i
71
+ })
72
+ this.bullets.items[i].setAttr({
73
+ dataIndex : i,
74
+ ariaLabel : `Go to slide ${i}`
75
+ })
76
+ this.bullets[i].events.click?.destroy();
77
+ this.bullets[i].onClick(()=>this.goto(i))
78
+ }
79
+ }
80
+ #addSlide(UIElement){
81
+ this.track.append(this.cache.slideBuilder(UIElement).setAttr({
82
+ ariaRoledescription : "slide",
83
+ role : "group",
84
+ ariaLabel : "" // link to update
85
+ }));
86
+ const bullet = text().size("15px","15px").style({
87
+ borderRadius:"50%",
88
+ cursor : "pointer",
89
+ border : "3px solid blue",
90
+ background : "white"
91
+ }).setAttr({
92
+ role : "button",
93
+ tabIndex : 0
94
+ })
95
+ .onPtrEnter(e=>e.target.st.background("gold").scale(1.2,1.2))
96
+ .onPtrLeave(e=>e.target.st.background("white").scale(1,1))
97
+ this.bullets.append(
98
+ bullet
99
+ )
100
+ return this;
101
+ }
102
+ addSlides(...slides){
103
+ slides.forEach(n=>this.#addSlide(n));
104
+ this.#update();
105
+ this.#updateAriaHidden();
106
+ return this;
107
+ }
108
+ }
109
+
110
+ export{
111
+ __ZikoUISlider__
112
+ }
@@ -0,0 +1,34 @@
1
+ import { __ZikoUISlider__ } from "./__ZikoUISlider__";
2
+ import { Flex } from "../Flex";
3
+ class ZikoUIHorizontalSlider extends __ZikoUISlider__{
4
+ constructor(...slides){
5
+ super("section","hSlider")
6
+ this.container.vertical(0,0)
7
+ Object.assign(this.cache,{
8
+ slideBuilder : (UIElement) => Flex(UIElement).style({
9
+ minWidth : "100%",
10
+ width:"100%",
11
+ height:"100%",
12
+ }).vertical(0,0)
13
+ })
14
+ this.track.size("100%","90%").style({
15
+ display : "flex"
16
+ })
17
+ this.addSlides(...slides);
18
+ this.bullets.horizontal(0,0).style({
19
+ width : "100%",
20
+ height : "10%",
21
+ })
22
+ }
23
+ __updatePos(){
24
+ const width = this.container.width;
25
+ this.track.st.translateX(-this.cache.currentIndex * width);
26
+ }
27
+
28
+ }
29
+
30
+ const hSlider=(...slides)=>new ZikoUIHorizontalSlider(...slides);
31
+ export{
32
+ hSlider,
33
+ ZikoUIHorizontalSlider
34
+ }
@@ -0,0 +1,12 @@
1
+ export * from "./hSlider.js"
2
+ export * from "./vSlider.js"
3
+ import { hSlider } from "./hSlider.js"
4
+ import { vSlider } from "./vSlider.js"
5
+ const Slider = ({orintation = "horizontal",slides = []}) =>{
6
+ if(["v","vertical"].includes(orintation.toLowerCase())) return vSlider(...slides);
7
+ else if(["h","horizontal"].includes(orintation.toLowerCase())) return hSlider(...slides);
8
+ else Error(`{ orientation : ${orintation}} Not supported`)
9
+ }
10
+ export{
11
+ Slider
12
+ }
@@ -0,0 +1,27 @@
1
+ import { __ZikoUISlider__ } from "./__ZikoUISlider__";
2
+ import { Flex } from "../Flex";
3
+ class ZikoUIVerticalSlider extends __ZikoUISlider__{
4
+ constructor(...slides){
5
+ super("section","vSlider");
6
+ Object.assign(this.cache,{
7
+ slideBuilder : (UIElement) => Flex(UIElement).size("100%","100%").vertical(0, 0)
8
+ })
9
+ this.addSlides(...slides);
10
+ this.container.horizontal(0,0)
11
+ this.track.size("90%","100%")
12
+ this.bullets.vertical(0,0).style({
13
+ height : "100%",
14
+ width : "10%"
15
+ })
16
+ }
17
+ __updatePos(){
18
+ const height = this.container.height;
19
+ this.track.st.translateY(-this.cache.currentIndex * height);
20
+ }
21
+ }
22
+
23
+ const vSlider=(...slides)=>new ZikoUIVerticalSlider(...slides);
24
+ export{
25
+ vSlider,
26
+ ZikoUIVerticalSlider
27
+ }
@@ -1,62 +1,62 @@
1
- import ZikoUIElement from "../../../primitives/ZikoUIElement";
2
- class __ZikoUISplitter__ extends ZikoUIElement{
3
- constructor(flexDirection, resizerCursor, resizerProp){
4
- super("div", "Splitter")
5
- Object.assign(this.cache,{
6
- isResizing : false,
7
- flexDirection,
8
- resizerCursor,
9
- resizerProp
10
- })
11
- this.style({
12
- display:"flex",
13
- flexDirection : this.cache.flexDirection,
14
- border: "2px solid #333",
15
- overflow: "hidden"
16
- })
17
- this.resizer = new ZikoUIElement("div", "resizer").style({
18
- [this.cache.resizerProp]:"5px",
19
- backgroundColor: "gold",
20
- cursor: this.cache.resizerCursor,
21
- touchAction: "none",
22
- });
23
- this.onPtrDown(e=>{
24
- this.cache.isResizing = true;
25
- this.style({
26
- cursor : this.cache.resizerCursor // ns-resize
27
- });
28
- this.resizer.element.setPointerCapture(e.event.pointerId);
29
- })
30
- this.onPtrUp(e=>{
31
- this.cache.isResizing = false;
32
- this.style({
33
- cursor: "default"
34
- })
35
- this.resizer.element.releasePointerCapture(e.event.pointerId);
36
- })
37
- this.onPtrCancel(()=>{
38
- this.cache.isResizing = false;
39
- this.style({
40
- cursor: "default"
41
- })
42
- })
43
- this.onPtrOut(()=>{
44
- if (this.cache.isResizing) {
45
- this.cache.isResizing = false;
46
- this.style({
47
- cursor: "default"
48
- })
49
- }
50
- })
51
- }
52
- get isSplitter(){
53
- return true;
54
- }
55
- styleResizer(style={}){
56
- this.resizer.style(style);
57
- return this;
58
- }
59
- }
60
- export{
61
- __ZikoUISplitter__
1
+ import ZikoUIElement from "../../primitives/ZikoUIElement";
2
+ class __ZikoUISplitter__ extends ZikoUIElement{
3
+ constructor(flexDirection, resizerCursor, resizerProp){
4
+ super("div", "Splitter")
5
+ Object.assign(this.cache,{
6
+ isResizing : false,
7
+ flexDirection,
8
+ resizerCursor,
9
+ resizerProp
10
+ })
11
+ this.style({
12
+ display:"flex",
13
+ flexDirection : this.cache.flexDirection,
14
+ border: "2px solid #333",
15
+ overflow: "hidden"
16
+ })
17
+ this.resizer = new ZikoUIElement("div", "resizer").style({
18
+ [this.cache.resizerProp]:"5px",
19
+ backgroundColor: "gold",
20
+ cursor: this.cache.resizerCursor,
21
+ touchAction: "none",
22
+ });
23
+ this.onPtrDown(e=>{
24
+ this.cache.isResizing = true;
25
+ this.style({
26
+ cursor : this.cache.resizerCursor // ns-resize
27
+ });
28
+ this.resizer.element.setPointerCapture(e.event.pointerId);
29
+ })
30
+ this.onPtrUp(e=>{
31
+ this.cache.isResizing = false;
32
+ this.style({
33
+ cursor: "default"
34
+ })
35
+ this.resizer.element.releasePointerCapture(e.event.pointerId);
36
+ })
37
+ this.onPtrCancel(()=>{
38
+ this.cache.isResizing = false;
39
+ this.style({
40
+ cursor: "default"
41
+ })
42
+ })
43
+ this.onPtrOut(()=>{
44
+ if (this.cache.isResizing) {
45
+ this.cache.isResizing = false;
46
+ this.style({
47
+ cursor: "default"
48
+ })
49
+ }
50
+ })
51
+ }
52
+ get isSplitter(){
53
+ return true;
54
+ }
55
+ styleResizer(style={}){
56
+ this.resizer.style(style);
57
+ return this;
58
+ }
59
+ }
60
+ export{
61
+ __ZikoUISplitter__
62
62
  }