@onetype/framework 2.0.41 → 2.0.43

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 (354) hide show
  1. package/addons/ai/addon.js +78 -0
  2. package/addons/ai/addons/agents/item/functions/describe.js +28 -0
  3. package/addons/ai/addons/agents/item/functions/execute.js +41 -0
  4. package/addons/ai/addons/agents/item/functions/messages.js +38 -0
  5. package/addons/ai/addons/agents/item/functions/run.js +49 -0
  6. package/addons/ai/addons/agents/item/functions/schema.js +45 -0
  7. package/addons/ai/addons/agents/load.js +9 -0
  8. package/addons/ai/addons/orchestrators/item/functions/agents/execute.js +14 -0
  9. package/addons/ai/addons/orchestrators/item/functions/agents/steps.js +23 -0
  10. package/addons/ai/addons/orchestrators/item/functions/modes/action.js +131 -0
  11. package/addons/ai/addons/orchestrators/item/functions/run.js +28 -0
  12. package/addons/ai/addons/orchestrators/item/functions/utils/emit.js +11 -0
  13. package/addons/ai/addons/orchestrators/item/functions/utils/history.js +8 -0
  14. package/addons/ai/addons/orchestrators/item/functions/utils/state.js +29 -0
  15. package/addons/ai/addons/orchestrators/load.js +15 -0
  16. package/addons/ai/addons/pipelines/functions/execute.js +56 -0
  17. package/addons/ai/addons/pipelines/functions/run.js +72 -0
  18. package/addons/ai/addons/pipelines/load.js +6 -0
  19. package/addons/ai/addons/providers/functions/default.js +8 -0
  20. package/addons/ai/addons/providers/item/functions/request.js +108 -0
  21. package/addons/ai/addons/providers/items/nue.js +69 -0
  22. package/addons/ai/addons/providers/items/ollama.js +79 -0
  23. package/addons/ai/addons/providers/load.js +8 -0
  24. package/addons/ai/items/agents/steps.js +159 -0
  25. package/addons/ai/items/agents/summary.js +29 -0
  26. package/addons/ai/items/orchestrators/general.js +7 -0
  27. package/addons/ai/load.js +13 -0
  28. package/addons/ai/test/agents.js +149 -0
  29. package/addons/ai/test/index.js +63 -0
  30. package/addons/core/assets/back/functions/utils/transform.js +21 -23
  31. package/addons/core/assets/back/items/html/css.js +2 -2
  32. package/addons/core/assets/back/items/html/js.js +2 -2
  33. package/addons/core/clients/back/http/item/functions/gRPC/create.js +3 -3
  34. package/addons/core/clients/back/http/item/functions/http/create.js +3 -3
  35. package/addons/core/commands/back/functions/grpc/client.js +3 -3
  36. package/addons/core/commands/back/functions/grpc/server.js +2 -2
  37. package/addons/core/commands/core/addon.js +4 -1
  38. package/addons/core/commands/core/functions/run.js +1 -1
  39. package/addons/core/commands/core/item/functions/run.js +1 -1
  40. package/addons/core/commands/core/load.js +27 -9
  41. package/addons/core/database/back/events/addon.add.js +1 -1
  42. package/addons/core/database/back/events/middleware/addon.items.find.js +2 -2
  43. package/addons/core/database/back/events/middleware/item.crud.create.js +2 -2
  44. package/addons/core/database/back/events/middleware/item.crud.delete.js +2 -2
  45. package/addons/core/database/back/events/middleware/item.crud.update.js +2 -2
  46. package/addons/core/database/back/item/functions/create.js +4 -3
  47. package/addons/core/database/back/item/functions/delete.js +1 -1
  48. package/addons/core/database/back/item/functions/find.js +1 -1
  49. package/addons/core/database/back/item/functions/update.js +3 -3
  50. package/addons/core/database/front/events/addon.add.js +1 -1
  51. package/addons/core/servers/back/grpc/item/functions/start.js +1 -1
  52. package/addons/core/servers/back/http/item/functions/start.js +6 -6
  53. package/addons/float/overlays/css/overlay.css +35 -0
  54. package/addons/float/overlays/js/addon.js +18 -0
  55. package/addons/float/overlays/js/events/click.js +27 -0
  56. package/addons/float/overlays/js/events/escape.js +18 -0
  57. package/addons/float/overlays/js/functions/flip.js +51 -0
  58. package/addons/float/overlays/js/functions/index.js +17 -0
  59. package/addons/float/overlays/js/functions/position.js +62 -0
  60. package/addons/float/overlays/js/functions/reposition.js +29 -0
  61. package/addons/float/overlays/js/item/catch/add.js +123 -0
  62. package/addons/float/overlays/js/item/catch/remove.js +29 -0
  63. package/addons/float/popup/css/popup.css +93 -0
  64. package/addons/float/popup/js/addon.js +34 -0
  65. package/addons/float/popup/js/functions/close.js +25 -0
  66. package/addons/float/popup/js/functions/modal.js +31 -0
  67. package/addons/float/popup/js/functions/popup.js +21 -0
  68. package/addons/float/popup/js/functions/toast.js +55 -0
  69. package/addons/float/popup/js/functions/tooltip.js +34 -0
  70. package/addons/float/popup/js/items/directives/popup.js +58 -0
  71. package/addons/float/popup/js/items/directives/tooltip.js +72 -0
  72. package/addons/render/directives/front/{js/#register/addon.js → addon.js} +8 -8
  73. package/addons/render/directives/front/{js/functions → functions}/process/attributes.js +7 -2
  74. package/addons/render/directives/front/{js/functions → functions}/process/match.js +8 -8
  75. package/addons/render/directives/front/functions/process.js +88 -0
  76. package/{lib/items/directives → addons/render/directives/front/items/self}/1000-render.js +1 -0
  77. package/{lib/items/directives → addons/render/directives/front/items/self}/110-show.js +3 -5
  78. package/{lib/items/directives → addons/render/directives/front/items/self}/160-slot.js +2 -1
  79. package/{lib/items/directives → addons/render/directives/front/items/self}/200-for.js +3 -3
  80. package/addons/render/directives/front/items/self/500-click-outside.js +45 -0
  81. package/addons/render/directives/front/items/self/500-events.js +68 -0
  82. package/addons/render/directives/front/items/self/500-mouse-enter.js +62 -0
  83. package/addons/render/directives/front/items/self/500-mouse-leave.js +62 -0
  84. package/{lib/items/directives → addons/render/directives/front/items/self}/650-fetch.js +2 -3
  85. package/{lib/items/directives → addons/render/directives/front/items/self}/660-form.js +5 -6
  86. package/addons/render/{elements/front/items/directives → directives/front/items/self}/element.js +7 -1
  87. package/addons/render/directives/front/items/self/node.js +43 -0
  88. package/addons/render/elements/front/functions/runtime.js +25 -0
  89. package/addons/render/elements/front/items/self/cards/pricing/pricing.css +174 -0
  90. package/{lib/items/elements/sections → addons/render/elements/front/items/self/cards}/pricing/pricing.js +30 -11
  91. package/addons/render/elements/front/items/self/core/builder/builder.css +180 -0
  92. package/addons/render/elements/front/items/self/core/builder/builder.js +257 -0
  93. package/addons/render/elements/front/items/self/core/repeater/repeater.css +197 -0
  94. package/addons/render/elements/front/items/self/core/repeater/repeater.js +224 -0
  95. package/addons/render/elements/front/items/self/form/button/button.css +250 -0
  96. package/{lib/items/elements → addons/render/elements/front/items/self}/form/button/button.js +16 -21
  97. package/addons/render/elements/front/items/self/form/checkbox/checkbox.css +109 -0
  98. package/addons/render/elements/front/items/self/form/checkbox/checkbox.js +75 -0
  99. package/addons/render/elements/front/items/self/form/color/color.css +156 -0
  100. package/addons/render/elements/front/items/self/form/color/color.js +122 -0
  101. package/addons/render/elements/front/items/self/form/date/date.css +84 -0
  102. package/addons/render/elements/front/items/self/form/date/date.js +68 -0
  103. package/addons/render/elements/front/items/self/form/field/field.css +72 -0
  104. package/{lib/items/elements → addons/render/elements/front/items/self}/form/field/field.js +4 -4
  105. package/addons/render/elements/front/items/self/form/input/input.css +86 -0
  106. package/addons/render/elements/front/items/self/form/input/input.js +124 -0
  107. package/addons/render/elements/front/items/self/form/radio/radio.css +118 -0
  108. package/addons/render/elements/front/items/self/form/radio/radio.js +80 -0
  109. package/addons/render/elements/front/items/self/form/rating/rating.css +57 -0
  110. package/{lib/items/elements → addons/render/elements/front/items/self}/form/rating/rating.js +18 -21
  111. package/addons/render/elements/front/items/self/form/section/section.css +86 -0
  112. package/{lib/items/elements → addons/render/elements/front/items/self}/form/section/section.js +5 -5
  113. package/addons/render/elements/front/items/self/form/select/select.css +186 -0
  114. package/addons/render/elements/front/items/self/form/select/select.js +161 -0
  115. package/addons/render/elements/front/items/self/form/slider/slider.css +123 -0
  116. package/{lib/items/elements → addons/render/elements/front/items/self}/form/slider/slider.js +89 -70
  117. package/addons/render/elements/front/items/self/form/tags/tags.css +152 -0
  118. package/addons/render/elements/front/items/self/form/tags/tags.js +166 -0
  119. package/addons/render/elements/front/items/self/form/textarea/textarea.css +80 -0
  120. package/addons/render/elements/front/items/self/form/textarea/textarea.js +113 -0
  121. package/addons/render/elements/front/items/self/form/toggle/toggle.css +105 -0
  122. package/addons/render/elements/front/items/self/form/toggle/toggle.js +66 -0
  123. package/addons/render/elements/front/items/self/global/code/code.css +97 -0
  124. package/{lib/items/elements → addons/render/elements/front/items/self}/global/code/code.js +10 -6
  125. package/addons/render/elements/front/items/self/global/faq/faq.css +98 -0
  126. package/{lib/items/elements → addons/render/elements/front/items/self}/global/faq/faq.js +16 -4
  127. package/{lib/items/elements → addons/render/elements/front/items/self}/global/heading/heading.css +37 -14
  128. package/addons/render/elements/front/items/self/global/heading/heading.js +46 -0
  129. package/{lib/items/elements → addons/render/elements/front/items/self}/global/markdown/markdown.css +22 -15
  130. package/addons/render/elements/front/items/self/global/markdown/markdown.js +26 -0
  131. package/addons/render/elements/front/items/self/global/menu/menu.css +173 -0
  132. package/addons/render/elements/front/items/self/global/menu/menu.js +103 -0
  133. package/addons/render/elements/front/items/self/global/notice/notice.css +57 -0
  134. package/{lib/items/elements → addons/render/elements/front/items/self}/global/notice/notice.js +4 -4
  135. package/addons/render/elements/front/items/self/global/parameters/parameters.css +96 -0
  136. package/{lib/items/elements → addons/render/elements/front/items/self}/global/parameters/parameters.js +15 -6
  137. package/{lib/items/elements → addons/render/elements/front/items/self}/global/tags/tags.css +18 -5
  138. package/{lib/items/elements → addons/render/elements/front/items/self}/global/tags/tags.js +11 -3
  139. package/{lib/items/elements → addons/render/elements/front/items/self}/navigation/navbar/navbar.css +39 -17
  140. package/{lib/items/elements → addons/render/elements/front/items/self}/navigation/navbar/navbar.js +24 -10
  141. package/{lib/items/elements → addons/render/elements/front/items/self}/navigation/sidebar/sidebar.css +25 -39
  142. package/{lib/items/elements → addons/render/elements/front/items/self}/navigation/sidebar/sidebar.js +29 -7
  143. package/addons/render/elements/front/items/self/navigation/tabs/tabs.css +66 -0
  144. package/{lib/items/elements → addons/render/elements/front/items/self}/navigation/tabs/tabs.js +17 -3
  145. package/{lib/items/elements → addons/render/elements/front/items/self}/status/code/code.css +21 -12
  146. package/{lib/items/elements → addons/render/elements/front/items/self}/status/empty/empty.css +23 -18
  147. package/{lib/items/elements → addons/render/elements/front/items/self}/status/empty/empty.js +5 -1
  148. package/{lib/items/elements → addons/render/elements/front/items/self}/status/error/error.css +22 -12
  149. package/{lib/items/elements → addons/render/elements/front/items/self}/status/error/error.js +2 -2
  150. package/{lib/items/elements → addons/render/elements/front/items/self}/status/loading/loading.css +31 -14
  151. package/{lib/items/elements → addons/render/elements/front/items/self}/status/loading/loading.js +4 -4
  152. package/addons/render/pages/core/load.js +1 -1
  153. package/addons/render/pages/front/events/click.js +1 -1
  154. package/addons/render/pages/front/events/load.js +6 -16
  155. package/addons/render/pages/front/functions/change.js +21 -110
  156. package/addons/render/pages/front/functions/match.js +2 -3
  157. package/addons/render/pages/front/functions/open.js +3 -35
  158. package/addons/render/pages/front/functions/resolve.js +30 -0
  159. package/addons/render/pages/front/item/catch/add.js +12 -10
  160. package/addons/render/pages/front/item/catch/remove.js +5 -7
  161. package/addons/render/pages/front/item/functions/enter.js +15 -28
  162. package/addons/render/pages/front/item/functions/leave.js +6 -8
  163. package/addons/render/pages/front/items/commands/change.js +60 -0
  164. package/addons/render/pages/front/items/commands/list.js +38 -0
  165. package/addons/render/pages/front/items/directives/change.js +1 -1
  166. package/addons/render/transforms/css/transforms.css +4 -0
  167. package/addons/render/transforms/{addon.js → js/addon.js} +7 -0
  168. package/addons/render/transforms/js/item/functions/run.js +87 -0
  169. package/addons/services/cloudflare/images/back/addon.js +23 -0
  170. package/addons/services/cloudflare/images/back/expose.js +22 -0
  171. package/addons/services/cloudflare/images/back/functions/api.js +47 -0
  172. package/addons/services/cloudflare/images/back/functions/meta/detect.js +28 -0
  173. package/addons/services/cloudflare/images/back/functions/meta/dimensions/gif.js +11 -0
  174. package/addons/services/cloudflare/images/back/functions/meta/dimensions/jpeg.js +31 -0
  175. package/addons/services/cloudflare/images/back/functions/meta/dimensions/png.js +11 -0
  176. package/addons/services/cloudflare/images/back/functions/meta/dimensions/webp.js +36 -0
  177. package/addons/services/cloudflare/images/back/functions/meta.js +16 -0
  178. package/addons/services/cloudflare/images/back/items/commands/delete.js +38 -0
  179. package/addons/services/cloudflare/images/back/items/commands/get.js +56 -0
  180. package/addons/services/cloudflare/images/back/items/commands/list.js +49 -0
  181. package/addons/services/cloudflare/images/back/items/commands/upload.js +79 -0
  182. package/addons/services/cloudflare/images/back/load.js +21 -0
  183. package/addons/services/cloudflare/images/front/items/elements/browse/browse.css +235 -0
  184. package/addons/services/cloudflare/images/front/items/elements/browse/browse.js +193 -0
  185. package/addons/services/cloudflare/images/front/items/elements/input/input.css +154 -0
  186. package/addons/services/cloudflare/images/front/items/elements/input/input.js +147 -0
  187. package/addons/services/cloudflare/images/sql.txt +43 -0
  188. package/lib/browser.js +1 -24
  189. package/lib/events.js +12 -12
  190. package/lib/load.js +12 -42
  191. package/lib/src/classes/addon/class.js +1 -2
  192. package/lib/src/classes/addon/classes/item/mixins/get.js +3 -3
  193. package/lib/src/classes/addon/classes/item/mixins/set.js +3 -5
  194. package/lib/src/classes/addon/classes/item/mixins/store.js +1 -1
  195. package/lib/src/classes/addon/classes/render/class.js +8 -22
  196. package/lib/src/classes/addon/classes/render/mixins/compile.js +6 -4
  197. package/lib/src/classes/addon/classes/render/mixins/dom.js +3 -1
  198. package/lib/src/classes/addon/classes/render/mixins/events.js +30 -43
  199. package/lib/src/classes/addon/classes/render/mixins/get.js +0 -5
  200. package/lib/src/classes/addon/classes/render/mixins/methods.js +105 -40
  201. package/lib/src/classes/addon/classes/render/mixins/process.js +7 -3
  202. package/lib/src/classes/addon/classes/render/mixins/set.js +3 -1
  203. package/lib/src/classes/addon/mixins/fields.js +4 -6
  204. package/lib/src/classes/addon/mixins/functions.js +11 -11
  205. package/lib/src/classes/addon/mixins/items.js +17 -9
  206. package/lib/src/classes/addon/mixins/render.js +1 -1
  207. package/lib/src/classes/addon/mixins/table.js +1 -1
  208. package/lib/src/classes/error/class.js +10 -0
  209. package/lib/src/mixins/addons.js +7 -20
  210. package/lib/src/mixins/assets.js +1 -1
  211. package/lib/src/mixins/data.js +14 -14
  212. package/lib/src/mixins/dependencies.js +5 -5
  213. package/lib/src/mixins/dom.js +204 -201
  214. package/lib/src/mixins/emitter.js +13 -14
  215. package/lib/src/mixins/error.js +14 -1
  216. package/lib/src/mixins/function.js +1 -0
  217. package/lib/src/mixins/generate.js +1 -1
  218. package/lib/src/mixins/helper.js +3 -31
  219. package/lib/{items/elements/global/markdown → src/mixins}/markdown.js +90 -139
  220. package/lib/src/mixins/middleware.js +2 -2
  221. package/lib/src/mixins/observer.js +337 -0
  222. package/lib/src/mixins/request.js +2 -2
  223. package/lib/src/mixins/route.js +11 -2
  224. package/lib/src/mixins/state.js +17 -3
  225. package/lib/src/onetype.js +11 -18
  226. package/lib/styles/classes/layout.css +1 -3
  227. package/lib/styles/reset.css +1 -1
  228. package/lib/styles/variables.css +2 -1
  229. package/package.json +7 -3
  230. package/README.md +0 -86
  231. package/addons/core/queue/index.js +0 -66
  232. package/addons/float/modals/front/css/modals.css +0 -26
  233. package/addons/float/modals/front/js/addon.js +0 -10
  234. package/addons/float/modals/front/js/item/catch/add.js +0 -48
  235. package/addons/float/modals/front/js/item/catch/remove.js +0 -9
  236. package/addons/float/overlays/front/css/overlays.css +0 -29
  237. package/addons/float/overlays/front/js/addon.js +0 -17
  238. package/addons/float/overlays/front/js/events/click.js +0 -27
  239. package/addons/float/overlays/front/js/events/escape.js +0 -18
  240. package/addons/float/overlays/front/js/functions/flip.js +0 -74
  241. package/addons/float/overlays/front/js/functions/index.js +0 -17
  242. package/addons/float/overlays/front/js/functions/position.js +0 -63
  243. package/addons/float/overlays/front/js/item/catch/add.js +0 -121
  244. package/addons/float/overlays/front/js/item/catch/remove.js +0 -16
  245. package/addons/float/popups/css/popups.css +0 -4
  246. package/addons/float/popups/js/addon.js +0 -18
  247. package/addons/float/popups/js/item/catch/add.js +0 -7
  248. package/addons/float/popups/js/item/catch/remove.js +0 -7
  249. package/addons/float/popups/js/item/catch/set.js +0 -73
  250. package/addons/float/popups/js/items/directives/popup.js +0 -54
  251. package/addons/float/toasts/addon.js +0 -17
  252. package/addons/float/toasts/item/catch/add.js +0 -7
  253. package/addons/float/toasts/item/catch/remove.js +0 -7
  254. package/addons/float/toasts/item/catch/set.js +0 -86
  255. package/addons/float/toasts/items/elements/toast/toast.css +0 -84
  256. package/addons/float/toasts/items/elements/toast/toast.js +0 -61
  257. package/addons/float/tooltips/addon.js +0 -15
  258. package/addons/float/tooltips/item/catch/add.js +0 -7
  259. package/addons/float/tooltips/item/catch/remove.js +0 -26
  260. package/addons/float/tooltips/item/catch/set.js +0 -65
  261. package/addons/float/tooltips/items/directives/tooltip.js +0 -74
  262. package/addons/float/tooltips/items/elements/tooltip.css +0 -64
  263. package/addons/float/tooltips/items/elements/tooltip.js +0 -42
  264. package/addons/render/directives/front/js/functions/process.js +0 -57
  265. package/addons/render/transforms/item/functions/run.js +0 -18
  266. package/docs/addons.md +0 -281
  267. package/docs/architecture.md +0 -238
  268. package/docs/commands.md +0 -308
  269. package/docs/database.md +0 -171
  270. package/docs/frontend.md +0 -396
  271. package/docs/servers.md +0 -187
  272. package/examples/basic-api/README.md +0 -34
  273. package/examples/basic-api/addons/tasks/addon.js +0 -10
  274. package/examples/basic-api/addons/tasks/items/commands/create.js +0 -22
  275. package/examples/basic-api/addons/tasks/items/commands/delete.js +0 -26
  276. package/examples/basic-api/addons/tasks/items/commands/list.js +0 -17
  277. package/examples/basic-api/addons/tasks/items/commands/toggle.js +0 -26
  278. package/examples/basic-api/addons/tasks/load.js +0 -8
  279. package/examples/basic-api/index.js +0 -15
  280. package/examples/basic-api/package.json +0 -7
  281. package/examples/basic-front/back/assets.js +0 -12
  282. package/examples/basic-front/back/index.js +0 -13
  283. package/examples/basic-front/back/items/commands/html.js +0 -14
  284. package/examples/basic-front/back/items/commands/test.js +0 -19
  285. package/examples/basic-front/back/items/html/fonts.js +0 -12
  286. package/examples/basic-front/front/pages/home.js +0 -16
  287. package/examples/basic-front/front/styles/main.css +0 -31
  288. package/examples/basic-front/front/test.js +0 -7
  289. package/examples/basic-front/package.json +0 -7
  290. package/lib/items/directives/500-blur.js +0 -46
  291. package/lib/items/directives/500-change.js +0 -53
  292. package/lib/items/directives/500-click-outside.js +0 -50
  293. package/lib/items/directives/500-click.js +0 -52
  294. package/lib/items/directives/500-double-click.js +0 -52
  295. package/lib/items/directives/500-focus.js +0 -46
  296. package/lib/items/directives/500-input.js +0 -46
  297. package/lib/items/directives/500-keydown.js +0 -53
  298. package/lib/items/directives/500-keyup.js +0 -53
  299. package/lib/items/directives/500-mouse-enter.js +0 -61
  300. package/lib/items/directives/500-mouse-leave.js +0 -61
  301. package/lib/items/directives/500-mouse-move.js +0 -45
  302. package/lib/items/directives/500-scroll.js +0 -45
  303. package/lib/items/directives/500-submit.js +0 -52
  304. package/lib/items/elements/form/button/styles/base.css +0 -176
  305. package/lib/items/elements/form/button/styles/sizes.css +0 -78
  306. package/lib/items/elements/form/button/styles/variants.css +0 -421
  307. package/lib/items/elements/form/checkbox/checkbox.js +0 -58
  308. package/lib/items/elements/form/checkbox/styles/base.css +0 -52
  309. package/lib/items/elements/form/checkbox/styles/sizes.css +0 -39
  310. package/lib/items/elements/form/checkbox/styles/variants.css +0 -121
  311. package/lib/items/elements/form/field/field.css +0 -96
  312. package/lib/items/elements/form/input/input.css +0 -111
  313. package/lib/items/elements/form/input/input.js +0 -79
  314. package/lib/items/elements/form/input/styles/base.css +0 -26
  315. package/lib/items/elements/form/input/styles/sizes.css +0 -15
  316. package/lib/items/elements/form/input/styles/variants.css +0 -98
  317. package/lib/items/elements/form/radio/radio.js +0 -58
  318. package/lib/items/elements/form/radio/styles/base.css +0 -48
  319. package/lib/items/elements/form/radio/styles/sizes.css +0 -36
  320. package/lib/items/elements/form/radio/styles/variants.css +0 -121
  321. package/lib/items/elements/form/rating/rating.css +0 -95
  322. package/lib/items/elements/form/section/section.css +0 -129
  323. package/lib/items/elements/form/slider/slider.css +0 -244
  324. package/lib/items/elements/form/textarea/textarea.css +0 -117
  325. package/lib/items/elements/form/textarea/textarea.js +0 -70
  326. package/lib/items/elements/global/card/card.css +0 -57
  327. package/lib/items/elements/global/card/card.js +0 -48
  328. package/lib/items/elements/global/code/code.css +0 -66
  329. package/lib/items/elements/global/faq/faq.css +0 -76
  330. package/lib/items/elements/global/heading/heading.js +0 -52
  331. package/lib/items/elements/global/notice/notice.css +0 -91
  332. package/lib/items/elements/global/parameters/parameters.css +0 -77
  333. package/lib/items/elements/navigation/tabs/tabs.css +0 -47
  334. package/lib/items/elements/sections/footer/footer.css +0 -205
  335. package/lib/items/elements/sections/footer/footer.js +0 -109
  336. package/lib/items/elements/sections/hero/hero.css +0 -100
  337. package/lib/items/elements/sections/hero/hero.js +0 -54
  338. package/lib/items/elements/sections/pricing/pricing.css +0 -148
  339. package/lib/items/elements/sections/stats/stats.css +0 -34
  340. package/lib/items/elements/sections/stats/stats.js +0 -74
  341. package/lib/src/mixins/logger.js +0 -83
  342. package/lib/styles/queries.css +0 -6
  343. /package/addons/modules/shortcuts/front/{#register/addon.js → addon.js} +0 -0
  344. /package/addons/render/directives/front/{js/functions → functions}/process/data.js +0 -0
  345. /package/{lib/items/directives → addons/render/directives/front/items/self}/100-if.js +0 -0
  346. /package/{lib/items/directives → addons/render/directives/front/items/self}/700-text.js +0 -0
  347. /package/{lib/items/directives → addons/render/directives/front/items/self}/750-html.js +0 -0
  348. /package/addons/render/elements/front/{#register/addon.js → addon.js} +0 -0
  349. /package/{lib/items/elements → addons/render/elements/front/items/self}/status/code/code.js +0 -0
  350. /package/addons/render/transforms/{functions → js/functions}/data.js +0 -0
  351. /package/addons/render/transforms/{functions → js/functions}/run.js +0 -0
  352. /package/addons/render/transforms/{functions → js/functions}/runtime.js +0 -0
  353. /package/addons/render/transforms/{item → js/item}/functions/load.js +0 -0
  354. /package/addons/render/transforms/{items/directives → js/items/self}/transform.js +0 -0
@@ -1,8 +1,13 @@
1
+ /* Root */
2
+
1
3
  .e-4a1d382d
2
4
  {
3
5
  display: flex;
6
+ width: 100%;
4
7
  }
5
8
 
9
+ /* Holder */
10
+
6
11
  .e-4a1d382d > .holder
7
12
  {
8
13
  display: flex;
@@ -11,11 +16,13 @@
11
16
  flex-wrap: wrap;
12
17
  }
13
18
 
19
+ /* Tag */
20
+
14
21
  .e-4a1d382d > .holder > .tag
15
22
  {
16
23
  display: flex;
17
24
  align-items: center;
18
- padding: 6px 14px;
25
+ padding: var(--ot-spacing-s) var(--ot-spacing-m);
19
26
  font-size: var(--ot-size-s);
20
27
  font-weight: 500;
21
28
  color: var(--ot-text-2);
@@ -25,7 +32,7 @@
25
32
  cursor: pointer;
26
33
  outline: none;
27
34
  white-space: nowrap;
28
- transition: color 0.2s ease, background 0.2s ease, border-color 0.2s ease;
35
+ transition: color 0.15s ease, background 0.15s ease, border-color 0.15s ease;
29
36
  }
30
37
 
31
38
  .e-4a1d382d > .holder > .tag:hover
@@ -45,10 +52,10 @@
45
52
 
46
53
  .e-4a1d382d > .holder > .tag > .dot
47
54
  {
48
- width: 6px;
49
- height: 6px;
55
+ width: var(--ot-spacing-s);
56
+ height: var(--ot-spacing-s);
50
57
  border-radius: 50%;
51
- margin-right: 6px;
58
+ margin-right: var(--ot-spacing-s);
52
59
  flex-shrink: 0;
53
60
  }
54
61
 
@@ -62,3 +69,9 @@
62
69
  {
63
70
  background: white;
64
71
  }
72
+
73
+ /* Size variants */
74
+
75
+ .e-4a1d382d > .holder.size-s > .tag { padding: var(--ot-spacing-x) var(--ot-spacing-s); font-size: var(--ot-size-s); }
76
+ .e-4a1d382d > .holder.size-m > .tag { padding: var(--ot-spacing-s) var(--ot-spacing-m); font-size: var(--ot-size-s); }
77
+ .e-4a1d382d > .holder.size-l > .tag { padding: var(--ot-spacing-m) var(--ot-spacing-l); font-size: var(--ot-size-m); }
@@ -10,12 +10,20 @@ onetype.AddonReady('elements', (elements) =>
10
10
  config: {
11
11
  items: {
12
12
  type: 'array',
13
- value: ['All']
13
+ value: ['All'],
14
+ each: {
15
+ type: 'string'
16
+ }
14
17
  },
15
18
  active: {
16
19
  type: 'string',
17
20
  value: 'All'
18
21
  },
22
+ variant: {
23
+ type: 'array',
24
+ value: [],
25
+ options: ['size-s', 'size-m', 'size-l']
26
+ },
19
27
  _change: {
20
28
  type: 'function'
21
29
  }
@@ -33,12 +41,12 @@ onetype.AddonReady('elements', (elements) =>
33
41
 
34
42
  if(this._change)
35
43
  {
36
- this._change(tag);
44
+ this._change({ value: tag });
37
45
  }
38
46
  };
39
47
 
40
48
  return `
41
- <div class="holder">
49
+ <div :class="'holder ' + variant.join(' ')">
42
50
  <button
43
51
  ot-for="tag in normalized()"
44
52
  :class="'tag' + (tag.label === active ? ' active' : '')"
@@ -1,17 +1,21 @@
1
+ /* Root */
2
+
1
3
  .e-64d8716d
2
4
  {
3
5
  display: flex;
4
6
  flex-direction: column;
7
+ width: 100%;
5
8
  }
6
9
 
10
+ /* Holder */
11
+
7
12
  .e-64d8716d > .holder
8
13
  {
9
14
  display: flex;
10
15
  align-items: center;
11
16
  width: 100%;
12
- height: 48px;
17
+ height: var(--ot-height-l);
13
18
  padding: 0 var(--ot-spacing-m);
14
- background: var(--ot-bg-1);
15
19
  border-bottom: 1px solid var(--ot-bg-2-border);
16
20
  }
17
21
 
@@ -27,17 +31,16 @@
27
31
 
28
32
  .e-64d8716d > .holder > .logo > .logo-icon
29
33
  {
30
- height: 16px;
34
+ height: var(--ot-size-m);
31
35
  }
32
36
 
33
37
  .e-64d8716d > .holder > .logo > .logo-arrow
34
38
  {
35
39
  display: none;
36
- font-size: 16px;
40
+ font-size: var(--ot-size-m);
37
41
  color: var(--ot-text-2);
38
42
  }
39
43
 
40
-
41
44
  /* Tabs */
42
45
 
43
46
  .e-64d8716d > .holder > .tabs
@@ -54,26 +57,25 @@
54
57
  display: flex;
55
58
  align-items: center;
56
59
  height: 100%;
57
- gap: 6px;
60
+ gap: var(--ot-spacing-s);
58
61
  padding: 0 var(--ot-spacing-m);
59
62
  border-right: 1px solid var(--ot-bg-2-border);
60
63
  text-decoration: none;
61
64
  white-space: nowrap;
62
- transition: color 0.2s ease, background 0.2s ease;
65
+ transition: color 0.15s ease, background 0.15s ease;
63
66
  font-weight: 500;
64
67
  color: var(--ot-text-2);
65
68
  }
66
69
 
67
70
  .e-64d8716d > .holder .tab > i
68
71
  {
69
- font-size: 16px;
72
+ font-size: var(--ot-size-m);
70
73
  }
71
74
 
72
75
  .e-64d8716d > .holder .tab:hover,
73
76
  .e-64d8716d > .holder .tab.active
74
77
  {
75
78
  color: var(--ot-text-1);
76
- background: var(--ot-bg-2);
77
79
  }
78
80
 
79
81
  /* Right */
@@ -94,8 +96,8 @@
94
96
  display: none;
95
97
  align-items: center;
96
98
  justify-content: center;
97
- width: 34px;
98
- height: 34px;
99
+ width: var(--ot-height-m);
100
+ height: var(--ot-height-m);
99
101
  margin-left: auto;
100
102
  background: none;
101
103
  border: none;
@@ -105,7 +107,7 @@
105
107
 
106
108
  .e-64d8716d > .holder > .burger > i
107
109
  {
108
- font-size: 20px;
110
+ font-size: var(--ot-size-l);
109
111
  }
110
112
 
111
113
  /* Menu */
@@ -114,7 +116,6 @@
114
116
  {
115
117
  display: none;
116
118
  flex-direction: column;
117
- background: var(--ot-bg-1);
118
119
  border-bottom: 1px solid var(--ot-bg-2-border);
119
120
  }
120
121
 
@@ -122,8 +123,8 @@
122
123
  {
123
124
  display: flex;
124
125
  align-items: center;
125
- gap: 8px;
126
- padding: 10px var(--ot-spacing-m);
126
+ gap: var(--ot-spacing-s);
127
+ padding: var(--ot-spacing-s) var(--ot-spacing-m);
127
128
  font-size: var(--ot-size-m);
128
129
  font-weight: 500;
129
130
  color: var(--ot-text-2);
@@ -133,16 +134,37 @@
133
134
 
134
135
  .e-64d8716d > .menu > .link > i
135
136
  {
136
- font-size: 16px;
137
+ font-size: var(--ot-size-m);
137
138
  }
138
139
 
139
140
  .e-64d8716d > .menu > .link:hover,
140
141
  .e-64d8716d > .menu > .link.active
141
142
  {
142
143
  color: var(--ot-text-1);
143
- background: var(--ot-bg-2);
144
144
  }
145
145
 
146
+ /* Background variants */
147
+
148
+ .e-64d8716d > .holder.bg-1 { background: var(--ot-bg-1); }
149
+ .e-64d8716d > .holder.bg-1 ~ .menu { background: var(--ot-bg-1); }
150
+ .e-64d8716d > .holder.bg-1 .tab:hover, .e-64d8716d > .holder.bg-1 .tab.active { background: var(--ot-bg-1-hover); }
151
+ .e-64d8716d > .holder.bg-1 ~ .menu > .link:hover, .e-64d8716d > .holder.bg-1 ~ .menu > .link.active { background: var(--ot-bg-1-hover); }
152
+
153
+ .e-64d8716d > .holder.bg-2 { background: var(--ot-bg-2); }
154
+ .e-64d8716d > .holder.bg-2 ~ .menu { background: var(--ot-bg-2); }
155
+ .e-64d8716d > .holder.bg-2 .tab:hover, .e-64d8716d > .holder.bg-2 .tab.active { background: var(--ot-bg-2-hover); }
156
+ .e-64d8716d > .holder.bg-2 ~ .menu > .link:hover, .e-64d8716d > .holder.bg-2 ~ .menu > .link.active { background: var(--ot-bg-2-hover); }
157
+
158
+ .e-64d8716d > .holder.bg-3 { background: var(--ot-bg-3); }
159
+ .e-64d8716d > .holder.bg-3 ~ .menu { background: var(--ot-bg-3); }
160
+ .e-64d8716d > .holder.bg-3 .tab:hover, .e-64d8716d > .holder.bg-3 .tab.active { background: var(--ot-bg-3-hover); }
161
+ .e-64d8716d > .holder.bg-3 ~ .menu > .link:hover, .e-64d8716d > .holder.bg-3 ~ .menu > .link.active { background: var(--ot-bg-3-hover); }
162
+
163
+ .e-64d8716d > .holder.bg-4 { background: var(--ot-bg-4); }
164
+ .e-64d8716d > .holder.bg-4 ~ .menu { background: var(--ot-bg-4); }
165
+ .e-64d8716d > .holder.bg-4 .tab:hover, .e-64d8716d > .holder.bg-4 .tab.active { background: var(--ot-bg-4-hover); }
166
+ .e-64d8716d > .holder.bg-4 ~ .menu > .link:hover, .e-64d8716d > .holder.bg-4 ~ .menu > .link.active { background: var(--ot-bg-4-hover); }
167
+
146
168
  /* Mobile */
147
169
 
148
170
  @media screen and (max-width: 900px)
@@ -8,15 +8,29 @@ onetype.AddonReady('elements', (elements) =>
8
8
  category: 'Navigation',
9
9
  author: 'OneType',
10
10
  config: {
11
+ logo: {
12
+ type: 'string',
13
+ value: 'https://cdn.onetype.ai/brand/logo/full-orange.svg'
14
+ },
11
15
  items: {
12
16
  type: 'array',
13
- value: [
14
- { icon: 'widgets', label: 'Transforms', href: '/transforms', position: 'left' },
15
- { icon: 'payments', label: 'Pricing', href: '/pricing', position: 'left' },
16
- { icon: 'menu_book', label: 'Docs', href: 'https://docs.onetype.ai/transforms', position: 'left' },
17
- { icon: 'code', label: 'GitHub', href: 'https://github.com/nicely-gg/transforms', position: 'right' },
18
- { icon: 'arrow_forward', label: 'Get Started', href: '/get-started', position: 'right' }
19
- ]
17
+ value: [],
18
+ each: {
19
+ type: 'object',
20
+ config: {
21
+ icon: { type: 'string', value: '' },
22
+ label: { type: 'string', value: '' },
23
+ href: { type: 'string', value: '' },
24
+ target: { type: 'string', value: '' },
25
+ position: { type: 'string', value: 'left', options: ['left', 'right'] },
26
+ match: { type: 'string|array', value: '' }
27
+ }
28
+ }
29
+ },
30
+ variant: {
31
+ type: 'array',
32
+ value: ['bg-1'],
33
+ options: ['bg-1', 'bg-2', 'bg-3', 'bg-4']
20
34
  }
21
35
  },
22
36
  render: function()
@@ -53,9 +67,9 @@ onetype.AddonReady('elements', (elements) =>
53
67
  };
54
68
 
55
69
  return `
56
- <nav class="holder">
70
+ <nav :class="'holder ' + variant.join(' ')">
57
71
  <a class="logo" href="/">
58
- <img class="logo-icon" src="https://cdn.onetype.ai/brand/logo/full-orange.svg" alt="OneType" />
72
+ <img class="logo-icon" :src="logo" alt="OneType" />
59
73
  <i class="logo-arrow">keyboard_arrow_down</i>
60
74
  </a>
61
75
  <div class="tabs">
@@ -64,7 +78,7 @@ onetype.AddonReady('elements', (elements) =>
64
78
  <div class="right">
65
79
  <a ot-for="item in right" :class="'tab' + (item.active ? ' active' : '')" :href="item.href" :target="item.target || null"><i>{{ item.icon }}</i> {{ item.label }}</a>
66
80
  </div>
67
- <button class="burger" ot-click="toggle"><i ot-if="!open">menu</i><i ot-if="open">close</i></button>
81
+ <button class="burger" ot-click="toggle"><i>{{ open ? 'close' : 'menu' }}</i></button>
68
82
  </nav>
69
83
  <div ot-if="open" class="menu">
70
84
  <a ot-for="item in all" :class="'link' + (item.active ? ' active' : '')" :href="item.href" :target="item.target || null"><i>{{ item.icon }}</i> {{ item.label }}</a>
@@ -1,3 +1,5 @@
1
+ /* Root */
2
+
1
3
  .e-210c16c7
2
4
  {
3
5
  display: flex;
@@ -6,13 +8,14 @@
6
8
  height: 100%;
7
9
  }
8
10
 
11
+ /* Holder */
12
+
9
13
  .e-210c16c7 > .holder
10
14
  {
11
15
  display: flex;
12
16
  flex-direction: column;
13
17
  width: 100%;
14
18
  padding: var(--ot-spacing-m) var(--ot-spacing-s);
15
- gap: 0;
16
19
  overflow-y: auto;
17
20
  }
18
21
 
@@ -24,7 +27,7 @@
24
27
  {
25
28
  display: flex;
26
29
  flex-direction: column;
27
- gap: 2px;
30
+ gap: var(--ot-spacing-x);
28
31
  padding: var(--ot-spacing-s) 0;
29
32
  border-top: 1px solid var(--ot-bg-3-border);
30
33
  }
@@ -43,7 +46,7 @@
43
46
  .e-210c16c7 > .holder > .bottom > .group > .title,
44
47
  .e-210c16c7 > .drawer > .group > .title
45
48
  {
46
- font-size: 10px;
49
+ font-size: var(--ot-size-s);
47
50
  font-weight: 600;
48
51
  color: var(--ot-text-2);
49
52
  text-transform: uppercase;
@@ -70,14 +73,14 @@
70
73
  border: 1px solid transparent;
71
74
  border-radius: var(--ot-radius-m);
72
75
  cursor: pointer;
73
- transition: all 0.15s ease;
76
+ transition: color 0.15s ease, background 0.15s ease;
74
77
  }
75
78
 
76
79
  .e-210c16c7 > .holder > .group > .item > i,
77
80
  .e-210c16c7 > .holder > .bottom > .group > .item > i,
78
81
  .e-210c16c7 > .drawer > .group > .item > i
79
82
  {
80
- font-size: 20px;
83
+ font-size: var(--ot-size-l);
81
84
  opacity: 0.4;
82
85
  transition: opacity 0.15s ease;
83
86
  }
@@ -91,18 +94,20 @@
91
94
  text-overflow: ellipsis;
92
95
  }
93
96
 
97
+ /* Count badge */
98
+
94
99
  .e-210c16c7 > .holder > .group > .item > .count,
95
100
  .e-210c16c7 > .holder > .bottom > .group > .item > .count,
96
101
  .e-210c16c7 > .drawer > .group > .item > .count
97
102
  {
98
103
  margin-left: auto;
99
104
  font-size: var(--ot-size-s);
100
- min-width: 20px;
101
- height: 20px;
105
+ min-width: var(--ot-height-x);
106
+ height: var(--ot-height-x);
102
107
  display: flex;
103
108
  align-items: center;
104
109
  justify-content: center;
105
- border-radius: 10px;
110
+ border-radius: var(--ot-radius-m);
106
111
  background: var(--ot-bg-4);
107
112
  color: var(--ot-text-2);
108
113
  font-weight: 500;
@@ -153,17 +158,16 @@
153
158
  margin-top: auto;
154
159
  }
155
160
 
156
- /* Variants */
161
+ /* Background variants */
157
162
 
158
- .e-210c16c7 > .holder.bg-2
159
- {
160
- background: var(--ot-bg-2);
161
- }
163
+ .e-210c16c7 > .holder.bg-1 { background: var(--ot-bg-1); }
164
+ .e-210c16c7 > .holder.bg-2 { background: var(--ot-bg-2); }
165
+ .e-210c16c7 > .holder.bg-3 { background: var(--ot-bg-3); }
166
+ .e-210c16c7 > .holder.bg-4 { background: var(--ot-bg-4); }
162
167
 
163
- .e-210c16c7 > .holder.border
164
- {
165
- border-right: 1px solid var(--ot-bg-2-border);
166
- }
168
+ /* Border variant */
169
+
170
+ .e-210c16c7 > .holder.border { border-right: 1px solid var(--ot-bg-2-border); }
167
171
 
168
172
  /* Bar, Overlay, Drawer — hidden on desktop */
169
173
 
@@ -198,7 +202,7 @@
198
202
  bottom: 0;
199
203
  left: 0;
200
204
  width: 100vw;
201
- height: 40px;
205
+ height: var(--ot-height-l);
202
206
  background: var(--ot-bg-1);
203
207
  border-top: 1px solid var(--ot-bg-2-border);
204
208
  border-bottom: 1px solid var(--ot-bg-2-border);
@@ -208,29 +212,11 @@
208
212
 
209
213
  .e-210c16c7 > .bar > .toggle
210
214
  {
211
- font-size: 20px;
215
+ font-size: var(--ot-size-l);
212
216
  color: var(--ot-brand);
213
217
  pointer-events: none;
214
218
  }
215
219
 
216
- .e-210c16c7 > .drawer > .toggle
217
- {
218
- display: flex;
219
- align-items: center;
220
- justify-content: center;
221
- width: 34px;
222
- height: 34px;
223
- background: none;
224
- border: none;
225
- color: var(--ot-text-2);
226
- cursor: pointer;
227
- }
228
-
229
- .e-210c16c7 > .drawer > .toggle > i
230
- {
231
- font-size: 20px;
232
- }
233
-
234
220
  .e-210c16c7 > .overlay
235
221
  {
236
222
  display: block;
@@ -262,7 +248,7 @@
262
248
  align-items: center;
263
249
  justify-content: center;
264
250
  width: 100%;
265
- height: 40px;
251
+ height: var(--ot-height-l);
266
252
  background: none;
267
253
  border: none;
268
254
  border-bottom: 1px solid var(--ot-bg-2-border);
@@ -273,7 +259,7 @@
273
259
 
274
260
  .e-210c16c7 > .drawer > .toggle > i
275
261
  {
276
- font-size: 20px;
262
+ font-size: var(--ot-size-l);
277
263
  }
278
264
 
279
265
  .e-210c16c7 > .drawer > .group
@@ -10,7 +10,29 @@ onetype.AddonReady('elements', (elements) =>
10
10
  config: {
11
11
  groups: {
12
12
  type: 'array',
13
- value: []
13
+ value: [],
14
+ each: {
15
+ type: 'object',
16
+ config: {
17
+ title: { type: 'string', value: '' },
18
+ placement: { type: 'string', value: 'top', options: ['top', 'bottom'] },
19
+ items: {
20
+ type: 'array',
21
+ value: [],
22
+ each: {
23
+ type: 'object',
24
+ config: {
25
+ icon: { type: 'string', value: '' },
26
+ label: { type: 'string', value: '' },
27
+ href: { type: 'string', value: '' },
28
+ value: { type: 'string', value: '' },
29
+ match: { type: 'string', value: '' },
30
+ count: { type: 'number', value: null }
31
+ }
32
+ }
33
+ }
34
+ }
35
+ }
14
36
  },
15
37
  active: {
16
38
  type: 'string',
@@ -19,7 +41,7 @@ onetype.AddonReady('elements', (elements) =>
19
41
  variant: {
20
42
  type: 'array',
21
43
  value: [],
22
- options: ['bg-2', 'border']
44
+ options: ['bg-1', 'bg-2', 'bg-3', 'bg-4', 'border']
23
45
  },
24
46
  _click: {
25
47
  type: 'function'
@@ -51,7 +73,7 @@ onetype.AddonReady('elements', (elements) =>
51
73
 
52
74
  if(this._click)
53
75
  {
54
- this._click(item);
76
+ this._click({ value: item });
55
77
  }
56
78
  };
57
79
 
@@ -68,7 +90,7 @@ onetype.AddonReady('elements', (elements) =>
68
90
  <a ot-for="item in group.items" :class="'item' + (isActive(item) ? ' active' : '')" :href="item.href || 'javascript:void(0)'" ot-click="handleClick(item)">
69
91
  <i ot-if="item.icon">{{ item.icon }}</i>
70
92
  <span>{{ item.label }}</span>
71
- <span ot-if="item.count !== undefined" class="count">{{ item.count }}</span>
93
+ <span ot-if="item.count !== undefined && item.count !== null" class="count">{{ item.count }}</span>
72
94
  </a>
73
95
  </div>
74
96
  <div ot-if="bottom.length" class="bottom">
@@ -77,7 +99,7 @@ onetype.AddonReady('elements', (elements) =>
77
99
  <a ot-for="item in group.items" :class="'item' + (isActive(item) ? ' active' : '')" :href="item.href || 'javascript:void(0)'" ot-click="handleClick(item)">
78
100
  <i ot-if="item.icon">{{ item.icon }}</i>
79
101
  <span>{{ item.label }}</span>
80
- <span ot-if="item.count !== undefined" class="count">{{ item.count }}</span>
102
+ <span ot-if="item.count !== undefined && item.count !== null" class="count">{{ item.count }}</span>
81
103
  </a>
82
104
  </div>
83
105
  </div>
@@ -94,7 +116,7 @@ onetype.AddonReady('elements', (elements) =>
94
116
  <a ot-for="item in group.items" :class="'item' + (isActive(item) ? ' active' : '')" :href="item.href || 'javascript:void(0)'" ot-click="handleClick(item)">
95
117
  <i ot-if="item.icon">{{ item.icon }}</i>
96
118
  <span>{{ item.label }}</span>
97
- <span ot-if="item.count !== undefined" class="count">{{ item.count }}</span>
119
+ <span ot-if="item.count !== undefined && item.count !== null" class="count">{{ item.count }}</span>
98
120
  </a>
99
121
  </div>
100
122
  <div ot-if="bottom.length" class="group">
@@ -103,7 +125,7 @@ onetype.AddonReady('elements', (elements) =>
103
125
  <a ot-for="item in group.items" :class="'item' + (isActive(item) ? ' active' : '')" :href="item.href || 'javascript:void(0)'" ot-click="handleClick(item)">
104
126
  <i ot-if="item.icon">{{ item.icon }}</i>
105
127
  <span>{{ item.label }}</span>
106
- <span ot-if="item.count !== undefined" class="count">{{ item.count }}</span>
128
+ <span ot-if="item.count !== undefined && item.count !== null" class="count">{{ item.count }}</span>
107
129
  </a>
108
130
  </div>
109
131
  </div>
@@ -0,0 +1,66 @@
1
+ /* Root */
2
+
3
+ .e-1a8b6ac1
4
+ {
5
+ display: flex;
6
+ width: 100%;
7
+ }
8
+
9
+ /* Holder */
10
+
11
+ .e-1a8b6ac1 > .holder
12
+ {
13
+ display: flex;
14
+ align-items: center;
15
+ border: 1px solid transparent;
16
+ border-radius: var(--ot-radius-m);
17
+ padding: var(--ot-spacing-x);
18
+ }
19
+
20
+ /* Tab */
21
+
22
+ .e-1a8b6ac1 > .holder > .tab
23
+ {
24
+ display: flex;
25
+ align-items: center;
26
+ gap: var(--ot-spacing-s);
27
+ padding: var(--ot-spacing-s) var(--ot-spacing-m);
28
+ border-radius: var(--ot-radius-m);
29
+ font-size: var(--ot-size-m);
30
+ font-weight: 500;
31
+ color: var(--ot-text-2);
32
+ text-decoration: none;
33
+ white-space: nowrap;
34
+ cursor: pointer;
35
+ transition: color 0.15s ease, background 0.15s ease;
36
+ }
37
+
38
+ .e-1a8b6ac1 > .holder > .tab > i
39
+ {
40
+ font-size: var(--ot-size-m);
41
+ }
42
+
43
+ .e-1a8b6ac1 > .holder > .tab:hover:not(.active)
44
+ {
45
+ color: var(--ot-text-1);
46
+ }
47
+
48
+ /* Active — relative to bg variant */
49
+
50
+ .e-1a8b6ac1 > .holder.bg-1 > .tab.active { background: var(--ot-bg-2); color: var(--ot-text-1); }
51
+ .e-1a8b6ac1 > .holder.bg-2 > .tab.active { background: var(--ot-bg-3); color: var(--ot-text-1); }
52
+ .e-1a8b6ac1 > .holder.bg-3 > .tab.active { background: var(--ot-bg-4); color: var(--ot-text-1); }
53
+ .e-1a8b6ac1 > .holder.bg-4 > .tab.active { background: var(--ot-bg-4-hover); color: var(--ot-text-1); }
54
+
55
+ /* Background variants */
56
+
57
+ .e-1a8b6ac1 > .holder.bg-1 { background: var(--ot-bg-1); border-color: var(--ot-bg-1-border); }
58
+ .e-1a8b6ac1 > .holder.bg-2 { background: var(--ot-bg-2); border-color: var(--ot-bg-2-border); }
59
+ .e-1a8b6ac1 > .holder.bg-3 { background: var(--ot-bg-3); border-color: var(--ot-bg-3-border); }
60
+ .e-1a8b6ac1 > .holder.bg-4 { background: var(--ot-bg-4); border-color: var(--ot-bg-4-border); }
61
+
62
+ /* Size variants */
63
+
64
+ .e-1a8b6ac1 > .holder.size-s > .tab { padding: var(--ot-spacing-x) var(--ot-spacing-s); font-size: var(--ot-size-s); }
65
+ .e-1a8b6ac1 > .holder.size-m > .tab { padding: var(--ot-spacing-s) var(--ot-spacing-m); font-size: var(--ot-size-m); }
66
+ .e-1a8b6ac1 > .holder.size-l > .tab { padding: var(--ot-spacing-m) var(--ot-spacing-l); font-size: var(--ot-size-m); }
@@ -14,7 +14,21 @@ onetype.AddonReady('elements', (elements) =>
14
14
  },
15
15
  items: {
16
16
  type: 'array',
17
- value: []
17
+ value: [],
18
+ each: {
19
+ type: 'object',
20
+ config: {
21
+ id: { type: 'string', value: '' },
22
+ label: { type: 'string', value: '' },
23
+ icon: { type: 'string', value: '' },
24
+ href: { type: 'string', value: '' }
25
+ }
26
+ }
27
+ },
28
+ variant: {
29
+ type: 'array',
30
+ value: ['bg-2'],
31
+ options: ['bg-1', 'bg-2', 'bg-3', 'bg-4', 'size-s', 'size-m', 'size-l']
18
32
  },
19
33
  _change: {
20
34
  type: 'function'
@@ -28,12 +42,12 @@ onetype.AddonReady('elements', (elements) =>
28
42
 
29
43
  if(this._change)
30
44
  {
31
- this._change(id);
45
+ this._change({ value: id });
32
46
  }
33
47
  };
34
48
 
35
49
  return `
36
- <div class="holder">
50
+ <div :class="'holder ' + variant.join(' ')">
37
51
  <a ot-for="item in items" :class="'tab' + (active === item.id ? ' active' : '')" :href="item.href || 'javascript:void(0)'" ot-click="select(item.id)">
38
52
  <i ot-if="item.icon">{{ item.icon }}</i>
39
53
  <span>{{ item.label }}</span>