nodality 1.0.0-beta.74 → 1.0.0-beta.76

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 (245) hide show
  1. package/dist/animator.cjs.js +1 -1
  2. package/dist/animator.cjs.js.LICENSE.txt +1 -1
  3. package/dist/animator.esm.js +1 -1
  4. package/dist/animator.esm.js.LICENSE.txt +1 -1
  5. package/dist/appleanim.cjs.js.LICENSE.txt +1 -1
  6. package/dist/appleanim.esm.js.LICENSE.txt +1 -1
  7. package/dist/audionew.cjs.js +1 -1
  8. package/dist/audionew.cjs.js.LICENSE.txt +1 -1
  9. package/dist/audionew.esm.js +1 -1
  10. package/dist/audionew.esm.js.LICENSE.txt +1 -1
  11. package/dist/base.cjs.js.LICENSE.txt +1 -1
  12. package/dist/base.esm.js.LICENSE.txt +1 -1
  13. package/dist/betaDesktopBar.esm.js +1 -1
  14. package/dist/betaDesktopBar.esm.js.LICENSE.txt +1 -1
  15. package/dist/betaMobileBar.esm.js +1 -1
  16. package/dist/betaMobileBar.esm.js.LICENSE.txt +1 -1
  17. package/dist/bundle.umd.js +1 -1
  18. package/dist/bundle.umd.js.LICENSE.txt +1 -1
  19. package/dist/button.cjs.js +1 -1
  20. package/dist/button.cjs.js.LICENSE.txt +1 -1
  21. package/dist/button.esm.js +1 -1
  22. package/dist/button.esm.js.LICENSE.txt +1 -1
  23. package/dist/cardGetter.cjs.js.LICENSE.txt +1 -1
  24. package/dist/cardGetter.esm.js.LICENSE.txt +1 -1
  25. package/dist/center.cjs.js.LICENSE.txt +1 -1
  26. package/dist/center.esm.js.LICENSE.txt +1 -1
  27. package/dist/checkbox.cjs.js +1 -1
  28. package/dist/checkbox.cjs.js.LICENSE.txt +1 -1
  29. package/dist/checkbox.esm.js +1 -1
  30. package/dist/checkbox.esm.js.LICENSE.txt +1 -1
  31. package/dist/code.cjs.js +1 -1
  32. package/dist/code.cjs.js.LICENSE.txt +1 -1
  33. package/dist/code.esm.js +1 -1
  34. package/dist/code.esm.js.LICENSE.txt +1 -1
  35. package/dist/container.cjs.js +1 -1
  36. package/dist/container.cjs.js.LICENSE.txt +1 -1
  37. package/dist/container.esm.js +1 -1
  38. package/dist/container.esm.js.LICENSE.txt +1 -1
  39. package/dist/datalist.cjs.js.LICENSE.txt +1 -1
  40. package/dist/datalist.esm.js.LICENSE.txt +1 -1
  41. package/dist/designer.cjs.js +1 -1
  42. package/dist/designer.cjs.js.LICENSE.txt +1 -1
  43. package/dist/designer.esm.js +1 -1
  44. package/dist/designer.esm.js.LICENSE.txt +1 -1
  45. package/dist/dropdown.cjs.js +1 -1
  46. package/dist/dropdown.cjs.js.LICENSE.txt +1 -1
  47. package/dist/dropdown.esm.js +1 -1
  48. package/dist/dropdown.esm.js.LICENSE.txt +1 -1
  49. package/dist/elementMapper.cjs.js +1 -1
  50. package/dist/elementMapper.cjs.js.LICENSE.txt +1 -1
  51. package/dist/elementMapper.esm.js +1 -1
  52. package/dist/elementMapper.esm.js.LICENSE.txt +1 -1
  53. package/dist/finalresult.esm.js +1 -1
  54. package/dist/finalresult.esm.js.LICENSE.txt +1 -1
  55. package/dist/flexCard.cjs.js +1 -1
  56. package/dist/flexCard.cjs.js.LICENSE.txt +1 -1
  57. package/dist/flexCard.esm.js +1 -1
  58. package/dist/flexCard.esm.js.LICENSE.txt +1 -1
  59. package/dist/flexGrid.cjs.js +1 -1
  60. package/dist/flexGrid.cjs.js.LICENSE.txt +1 -1
  61. package/dist/flexGrid.esm.js +1 -1
  62. package/dist/flexGrid.esm.js.LICENSE.txt +1 -1
  63. package/dist/flexRow.cjs.js +1 -1
  64. package/dist/flexRow.cjs.js.LICENSE.txt +1 -1
  65. package/dist/flexRow.esm.js +1 -1
  66. package/dist/flexRow.esm.js.LICENSE.txt +1 -1
  67. package/dist/floatingInput.cjs.js +1 -1
  68. package/dist/floatingInput.cjs.js.LICENSE.txt +1 -1
  69. package/dist/floatingInput.esm.js +1 -1
  70. package/dist/floatingInput.esm.js.LICENSE.txt +1 -1
  71. package/dist/free.cjs.js +1 -1
  72. package/dist/free.cjs.js.LICENSE.txt +1 -1
  73. package/dist/free.esm.js +1 -1
  74. package/dist/free.esm.js.LICENSE.txt +1 -1
  75. package/dist/horizontalScroller.esm.js.LICENSE.txt +1 -1
  76. package/dist/image.cjs.js +1 -1
  77. package/dist/image.cjs.js.LICENSE.txt +1 -1
  78. package/dist/image.esm.js +1 -1
  79. package/dist/image.esm.js.LICENSE.txt +1 -1
  80. package/dist/imagePicker.cjs.js +1 -1
  81. package/dist/imagePicker.cjs.js.LICENSE.txt +1 -1
  82. package/dist/imagePicker.esm.js +1 -1
  83. package/dist/imagePicker.esm.js.LICENSE.txt +1 -1
  84. package/dist/index.cjs.js +1 -1
  85. package/dist/index.cjs.js.LICENSE.txt +1 -1
  86. package/dist/index.esm.js +1 -1
  87. package/dist/index.esm.js.LICENSE.txt +1 -1
  88. package/dist/link.cjs.js +1 -1
  89. package/dist/link.cjs.js.LICENSE.txt +1 -1
  90. package/dist/link.esm.js +1 -1
  91. package/dist/link.esm.js.LICENSE.txt +1 -1
  92. package/dist/linkGetter.cjs.js +1 -1
  93. package/dist/linkGetter.cjs.js.LICENSE.txt +1 -1
  94. package/dist/linkGetter.esm.js +1 -1
  95. package/dist/linkGetter.esm.js.LICENSE.txt +1 -1
  96. package/dist/metaAdder.cjs.js.LICENSE.txt +1 -1
  97. package/dist/metaAdder.esm.js.LICENSE.txt +1 -1
  98. package/dist/modal2025.cjs.js.LICENSE.txt +1 -1
  99. package/dist/modal2025.esm.js.LICENSE.txt +1 -1
  100. package/dist/multiswitchers.esm.js +1 -1
  101. package/dist/multiswitchers.esm.js.LICENSE.txt +1 -1
  102. package/dist/newNavBar.cjs.js +1 -1
  103. package/dist/newNavBar.cjs.js.LICENSE.txt +1 -1
  104. package/dist/newNavBar.esm.js +1 -1
  105. package/dist/newNavBar.esm.js.LICENSE.txt +1 -1
  106. package/dist/picker.cjs.js +1 -1
  107. package/dist/picker.cjs.js.LICENSE.txt +1 -1
  108. package/dist/picker.esm.js +1 -1
  109. package/dist/picker.esm.js.LICENSE.txt +1 -1
  110. package/dist/progress.cjs.js.LICENSE.txt +1 -1
  111. package/dist/progress.esm.js.LICENSE.txt +1 -1
  112. package/dist/radio.cjs.js.LICENSE.txt +1 -1
  113. package/dist/radio.esm.js.LICENSE.txt +1 -1
  114. package/dist/range.cjs.js.LICENSE.txt +1 -1
  115. package/dist/range.esm.js.LICENSE.txt +1 -1
  116. package/dist/scrollvideo.cjs.js.LICENSE.txt +1 -1
  117. package/dist/scrollvideo.esm.js.LICENSE.txt +1 -1
  118. package/dist/sideBar.cjs.js.LICENSE.txt +1 -1
  119. package/dist/sideBar.esm.js.LICENSE.txt +1 -1
  120. package/dist/sideNavBar.cjs.js +1 -1
  121. package/dist/sideNavBar.cjs.js.LICENSE.txt +1 -1
  122. package/dist/sideNavBar.esm.js +1 -1
  123. package/dist/sideNavBar.esm.js.LICENSE.txt +1 -1
  124. package/dist/simpleBar.cjs.js +1 -1
  125. package/dist/simpleBar.cjs.js.LICENSE.txt +1 -1
  126. package/dist/simpleBar.esm.js +1 -1
  127. package/dist/simpleBar.esm.js.LICENSE.txt +1 -1
  128. package/dist/stack.cjs.js.LICENSE.txt +1 -1
  129. package/dist/stack.esm.js.LICENSE.txt +1 -1
  130. package/dist/stacker.cjs.js.LICENSE.txt +1 -1
  131. package/dist/stacker.esm.js.LICENSE.txt +1 -1
  132. package/dist/table.cjs.js +1 -1
  133. package/dist/table.cjs.js.LICENSE.txt +1 -1
  134. package/dist/table.esm.js +1 -1
  135. package/dist/table.esm.js.LICENSE.txt +1 -1
  136. package/dist/text.cjs.js +1 -1
  137. package/dist/text.cjs.js.LICENSE.txt +1 -1
  138. package/dist/text.esm.js +1 -1
  139. package/dist/text.esm.js.LICENSE.txt +1 -1
  140. package/dist/textField.cjs.js +1 -1
  141. package/dist/textField.cjs.js.LICENSE.txt +1 -1
  142. package/dist/textField.esm.js +1 -1
  143. package/dist/textField.esm.js.LICENSE.txt +1 -1
  144. package/dist/transformanim.cjs.js +1 -1
  145. package/dist/transformanim.cjs.js.LICENSE.txt +1 -1
  146. package/dist/transformanim.esm.js +1 -1
  147. package/dist/transformanim.esm.js.LICENSE.txt +1 -1
  148. package/dist/wrap.cjs.js.LICENSE.txt +1 -1
  149. package/dist/wrap.esm.js.LICENSE.txt +1 -1
  150. package/dist/zoomCard.cjs.js +1 -1
  151. package/dist/zoomCard.cjs.js.LICENSE.txt +1 -1
  152. package/dist/zoomCard.esm.js +1 -1
  153. package/dist/zoomCard.esm.js.LICENSE.txt +1 -1
  154. package/layout/DEPRECATED-PARAGRAPH.js +1 -1
  155. package/layout/animator.js +59 -74
  156. package/layout/audio.js +1 -1
  157. package/layout/audionew.js +1 -1
  158. package/layout/base-2.js +1 -1
  159. package/layout/base.js +1 -1
  160. package/layout/betaDesktopBar.js +1 -1
  161. package/layout/betaMobileBar.js +1 -1
  162. package/layout/box.js +1 -1
  163. package/layout/button.js +1 -1
  164. package/layout/cards.js +1 -1
  165. package/layout/center.js +1 -1
  166. package/layout/checkbox.js +1 -1
  167. package/layout/cleanRow.js +1 -1
  168. package/layout/code.js +1 -1
  169. package/layout/container.js +78 -188
  170. package/layout/custom.js +1 -1
  171. package/layout/divImage.js +1 -1
  172. package/layout/dropdown.js +1 -1
  173. package/layout/dropdown2025.js +40 -2
  174. package/layout/emptyElement.js +1 -1
  175. package/layout/externalStylesheet.js +1 -1
  176. package/layout/flexCard.js +1 -1
  177. package/layout/flexGrid.js +4 -1
  178. package/layout/flexrow.js +1 -1
  179. package/layout/footer.js +1 -1
  180. package/layout/formComponents/custom.js +1 -1
  181. package/layout/formComponents/dataList.js +1 -1
  182. package/layout/formComponents/floatingInput.js +2 -1
  183. package/layout/formComponents/form-all.js +1 -1
  184. package/layout/formComponents/form.js +2 -1
  185. package/layout/formComponents/imagePicker.js +1 -1
  186. package/layout/formComponents/picker.js +1 -1
  187. package/layout/formComponents/radio.js +1 -1
  188. package/layout/formComponents/radiogroup.js +1 -1
  189. package/layout/formComponents/range.js +1 -1
  190. package/layout/free.js +4 -4
  191. package/layout/grid-new.js +1 -1
  192. package/layout/grid.js +1 -1
  193. package/layout/gridSwitcher.js +1 -1
  194. package/layout/group.js +1 -1
  195. package/layout/header.js +1 -1
  196. package/layout/horizontalScroller.js +1 -1
  197. package/layout/image-old.js +1 -1
  198. package/layout/image.js +1 -1
  199. package/layout/index.js +1 -1
  200. package/layout/label.js +1 -1
  201. package/layout/link.js +1 -1
  202. package/layout/list-OLD.js +1 -1
  203. package/layout/list.js +1 -1
  204. package/layout/metaAdder.js +1 -1
  205. package/layout/modal2025.js +1 -1
  206. package/layout/modernwrap.js +1 -1
  207. package/layout/multiswitcher.js +1 -1
  208. package/layout/multiswitcherBeta.js +1 -1
  209. package/layout/navBar-OLD.js +1 -1
  210. package/layout/navBar.js +1 -1
  211. package/layout/navFactor/customDiv.js +3 -1
  212. package/layout/newFlatAdder.js +1 -1
  213. package/layout/newNavBar copy 2.js +1 -1
  214. package/layout/newNavBar copy.js +1 -1
  215. package/layout/newNavBar.js +1 -1
  216. package/layout/offsetContainer.js +1 -1
  217. package/layout/progress.js +1 -1
  218. package/layout/row.js +1 -1
  219. package/layout/savedNewNavBar.js +1 -1
  220. package/layout/scrollvideo.js +8 -4
  221. package/layout/sideBar.js +1 -1
  222. package/layout/sideNavBar.js +1 -1
  223. package/layout/simpleBar.js +1 -1
  224. package/layout/slider2025.js +1 -1
  225. package/layout/spacer.js +1 -1
  226. package/layout/stack.js +1 -1
  227. package/layout/styler.js +1 -1
  228. package/layout/switcher.js +1 -1
  229. package/layout/table.js +1 -1
  230. package/layout/text.js +25 -5
  231. package/layout/textField.js +1 -1
  232. package/layout/ulist.js +1 -1
  233. package/layout/video.js +1 -1
  234. package/layout/withoutNew.js +1 -1
  235. package/layout/wrap.js +1 -1
  236. package/layout/zoomCard.js +1 -1
  237. package/lib/AppleAnim.js +2 -1
  238. package/lib/Stacker.js +3 -1
  239. package/lib/TransformAnim.js +5 -2
  240. package/lib/cardGetter.js +1 -1
  241. package/lib/designer.js +42 -3
  242. package/lib/elementMapper.js +169 -4
  243. package/lib/linkGetter.js +4 -1
  244. package/lib/scrollvideo.js +3 -1
  245. package/package.json +2 -2
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * nodality v1.0.0-beta.74
2
+ * nodality v1.0.0-beta.76
3
3
  * (c) 2025 Filip Vabrousek
4
4
  * License: MIT
5
5
  */
@@ -109,9 +109,170 @@ class ElementMapper { // 22:09:58 04/11/2024
109
109
  return this.stack(obj);
110
110
  } else if (obj.el.type === "simple"){
111
111
  return this.simple(obj);
112
- }
112
+ } else if (obj.el.type === "copy"){
113
+ return this.mapCopy(obj);
114
+ }
113
115
  }
114
116
 
117
+ static mapCopy(obj) {
118
+ const customOptions = obj.customOptions;
119
+ const ft = customOptions.filter(l => l.op === "copy")[0];
120
+ const count = ft?.count ?? 3;
121
+
122
+ const minSize = 300; // size of whole wheel
123
+ const cardSize = 30; // width/height of text wrapper
124
+ const padding = 30; // empty ring inside wheel
125
+ const wheelRadius = minSize / 2 - padding;
126
+ const ringRadius = wheelRadius - cardSize / 2;
127
+
128
+ let animation = `
129
+ animation: {
130
+ op: {
131
+ name: "animation",
132
+ color: "green",
133
+ width: "1px",
134
+ fireAt: "inview",
135
+ keyframesOpen: [
136
+ {
137
+ transform: "rotate(360deg)",
138
+ opacity: 0
139
+ },
140
+ {
141
+ transform: "rotate(0deg)",
142
+ opacity: 1
143
+ }
144
+ ],
145
+ keyframesClose: [
146
+ {
147
+ transform: "rotate(0deg)",
148
+ opacity: 1
149
+ },
150
+ {
151
+ transform: "rotate(0deg)",
152
+ opacity: 0
153
+ }
154
+ ],
155
+ openOptions: {
156
+ duration: 300,
157
+ fill: "forwards",
158
+ delay: 1000
159
+ },
160
+ closeOptions: {
161
+ duration: 1,
162
+ fill: "forwards",
163
+ delay: 1000
164
+ }
165
+ },
166
+ target: [
167
+ "#first"
168
+ ]
169
+ },
170
+ `;
171
+
172
+ return `new Wrapper()
173
+ .set({
174
+ width: "${minSize}px",
175
+ height: "${minSize}px",
176
+ display: "flex",
177
+ justifyContent: "center",
178
+ alignItems: "center",
179
+ position: "absolute",
180
+ id: "#first",
181
+ scale: 0.3,
182
+ ${ft?.animation ? animation : ""}
183
+ })
184
+ .add(
185
+ Array.from({ length: ${count} }).map((_, i) => {
186
+
187
+ const bbox = {width: "${minSize}px", height: "${minSize}px"};
188
+
189
+ const elHeight = bbox.height;
190
+
191
+ const cx = ${minSize / 2};
192
+ const cy = ${minSize / 2};
193
+
194
+ const R = ${minSize/2};
195
+
196
+ const n = ${count};
197
+
198
+ // Evenly spaced angles, starting at top (-90°)
199
+ const angle = (i / n) * Math.PI * 2 - Math.PI/2;
200
+ const dist = R + parseFloat(elHeight)/2;
201
+
202
+ const x = cx + dist * Math.cos(angle);
203
+ const y = cy + dist * Math.sin(angle);
204
+
205
+ let rot = angle * 180 / Math.PI + 90;
206
+ rot = (rot % 360 + 360) % 360;
207
+ rot = (rot % 360 + 360) % 360;
208
+
209
+ return new Text("Hello").set({
210
+ size: "S1",
211
+ color: "green",
212
+ font: "Arial",
213
+ left: \`\${x}px\`,
214
+ top: \`\${y}px\`,
215
+ transform: {
216
+ op: {
217
+ name: "transform",
218
+ transform: {
219
+ static: true,
220
+ keep: true,
221
+ values: [
222
+ "tx:-50%",
223
+ "ty:-50%",
224
+ \`rotate(\${rot}deg)\`
225
+ ]
226
+ }
227
+ }
228
+ }
229
+ })
230
+
231
+
232
+ })
233
+ )`;
234
+ }
235
+
236
+
237
+ static mapCopya(){
238
+
239
+
240
+ return `\n
241
+ new Wrapper()
242
+ .set({
243
+ width: "600px",
244
+ height: "300px",
245
+ justifyContent: "center",
246
+ alignItems: "center",
247
+ display: "flex",
248
+ position: "relative",
249
+ })
250
+ .add(
251
+ Array.from({ length: 3 }).map((_, i) => {
252
+ const angle = i * 120;
253
+ return new Text("Hello")
254
+ .set({
255
+ size: "S1",
256
+ color: "green",
257
+ position: "absolute",
258
+ transform: {
259
+ op: {
260
+ name: "transform",
261
+ transform: {
262
+ static: true,
263
+ keep: true,
264
+ hardCSS: \`translate(-50%, -50%) rotate(\${angle}deg) translate(${radius}px) rotate(\${-angle}deg)\`
265
+ values: [
266
+ \`translate(-50%, -50%) rotate(\${angle}deg) translate(120px) rotate(\${-angle}deg)\`,
267
+ ],
268
+ }
269
+ }
270
+ }
271
+ });
272
+ })
273
+ )
274
+ `;
275
+ }
115
276
 
116
277
  static button(){
117
278
  return new Button("Submit")
@@ -273,7 +434,7 @@ class ElementMapper { // 22:09:58 04/11/2024
273
434
 
274
435
  return new Dropdown()
275
436
  .set({
276
- behaviour: "mouseover", // click otherwise
437
+ behaviour: "click", // click otherwise
277
438
  //width: "120px",
278
439
 
279
440
  // socenter: true,
@@ -1047,6 +1208,9 @@ if (obj.el.dropdown){
1047
1208
 
1048
1209
 
1049
1210
 
1211
+ console.log("OXERO");
1212
+ console.log(obj.customOptions);
1213
+ console.log(this.filtero("span", el.id, obj.customOptions));
1050
1214
 
1051
1215
  return new Text(el.text || el.value)
1052
1216
  .set({
@@ -1066,6 +1230,7 @@ if (obj.el.dropdown){
1066
1230
  marginOp: this.filtero("margin", el.id, obj.customOptions),
1067
1231
  transform: this.filtero("transform", el.id, obj.customOptions),
1068
1232
  filtera: this.filtero("filter", el.id, obj.customOptions),
1233
+ // copy: this.filtero("copy", el.id, obj.customOptions),
1069
1234
  });
1070
1235
  }
1071
1236
 
@@ -1181,7 +1346,7 @@ if (obj.el.dropdown){
1181
1346
 
1182
1347
  return `\n
1183
1348
  new FlexGrid()
1184
- .set({colat: "700px", wrap: true, align: "center"})
1349
+ .set({colat: "700px", wrap: true, align: "center", gap: "1rem"})
1185
1350
  .items([${cards}])
1186
1351
  \n`;
1187
1352
  }
package/lib/linkGetter.js CHANGED
@@ -1,9 +1,10 @@
1
1
  /*!
2
- * nodality v1.0.0-beta.74
2
+ * nodality v1.0.0-beta.76
3
3
  * (c) 2025 Filip Vabrousek
4
4
  * License: MIT
5
5
  */
6
6
 
7
+ import { Link } from "../layout/link.js";
7
8
  class LinkStyler {
8
9
  static style(obj){
9
10
  let bst = obj.bst;
@@ -62,6 +63,8 @@ class LinkStyler {
62
63
  }
63
64
  }
64
65
 
66
+ console.log("OMESTE");
67
+ console.log(bst[j]);
65
68
  let split = bst[j].op.ops.split("-");
66
69
 
67
70
  // alert(allow);
@@ -1,9 +1,11 @@
1
1
  /*!
2
- * nodality v1.0.0-beta.74
2
+ * nodality v1.0.0-beta.76
3
3
  * (c) 2025 Filip Vabrousek
4
4
  * License: MIT
5
5
  */
6
6
 
7
+
8
+
7
9
  class ScrollVideo {
8
10
  constructor() {
9
11
  this.frameNumber = 0; // Start video at frame 0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nodality",
3
- "version": "1.0.0-beta.74",
3
+ "version": "1.0.0-beta.76",
4
4
  "description": "A lightweight library for declarative UI elements.",
5
5
  "main": "dist/index.js",
6
6
  "module": "dist/index.esm.js",
@@ -20,7 +20,7 @@
20
20
  "test:jest": "jest",
21
21
  "test:playwright": "playwright test",
22
22
  "test": "node scripts/generatePlaywright.js && playwright test",
23
- "postpublish": "git add . && git commit -m \"release: v$npm_package_version\" && git tag v$npm_package_version && git push --set-upstream origin main && git push origin v$npm_package_version",
23
+ "postpublish": "sh scripts/postpublish.sh",
24
24
  "inject-license": "node scripts/injectLicense.js"
25
25
  },
26
26
  "jest": {