@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
@@ -0,0 +1,46 @@
1
+ onetype.AddonReady('elements', (elements) =>
2
+ {
3
+ elements.ItemAdd({
4
+ id: 'global-heading',
5
+ icon: 'title',
6
+ name: 'Heading',
7
+ description: 'Page heading with title and description.',
8
+ category: 'Global',
9
+ author: 'OneType',
10
+ config: {
11
+ icon: {
12
+ type: 'string',
13
+ value: ''
14
+ },
15
+ title: {
16
+ type: 'string',
17
+ value: 'Title'
18
+ },
19
+ description: {
20
+ type: 'string',
21
+ value: ''
22
+ },
23
+ variant: {
24
+ type: 'array',
25
+ value: ['left', 'size-m'],
26
+ options: ['left', 'center', 'right', 'page', 'clean', 'size-s', 'size-m', 'size-l']
27
+ }
28
+ },
29
+ render: function()
30
+ {
31
+ return `
32
+ <div :class="'holder ' + variant.join(' ')">
33
+ <div class="text">
34
+ <i ot-if="icon" class="icon">{{ icon }}</i>
35
+ <h2 ot-if="!variant.includes('page')" class="title">{{ title }}</h2>
36
+ <h1 ot-if="variant.includes('page')" class="title">{{ title }}</h1>
37
+ <p ot-if="description" class="description">{{ description }}</p>
38
+ </div>
39
+ <div class="right">
40
+ <slot name="right"></slot>
41
+ </div>
42
+ </div>
43
+ `;
44
+ }
45
+ });
46
+ });
@@ -1,9 +1,13 @@
1
+ /* Root */
2
+
1
3
  .e-4696d703
2
4
  {
3
5
  display: flex;
4
6
  width: 100%;
5
7
  }
6
8
 
9
+ /* Holder */
10
+
7
11
  .e-4696d703 > .holder
8
12
  {
9
13
  display: flex;
@@ -12,13 +16,16 @@
12
16
  width: 100%;
13
17
  }
14
18
 
15
- .e-4696d703 > .holder[variant="bg-2"]
16
- {
17
- background: var(--ot-bg-2);
18
- border: 1px solid var(--ot-bg-2-border);
19
- border-radius: var(--ot-radius-m);
20
- padding: var(--ot-spacing-m);
21
- }
19
+ /* Background variants */
20
+
21
+ .e-4696d703 > .holder.bg-1 { background: var(--ot-bg-1); border: 1px solid var(--ot-bg-1-border); border-radius: var(--ot-radius-m); padding: var(--ot-spacing-m); }
22
+ .e-4696d703 > .holder.bg-2 { background: var(--ot-bg-2); border: 1px solid var(--ot-bg-2-border); border-radius: var(--ot-radius-m); padding: var(--ot-spacing-m); }
23
+ .e-4696d703 > .holder.bg-3 { background: var(--ot-bg-3); border: 1px solid var(--ot-bg-3-border); border-radius: var(--ot-radius-m); padding: var(--ot-spacing-m); }
24
+ .e-4696d703 > .holder.bg-4 { background: var(--ot-bg-4); border: 1px solid var(--ot-bg-4-border); border-radius: var(--ot-radius-m); padding: var(--ot-spacing-m); }
25
+
26
+ /* Border variant */
27
+
28
+ .e-4696d703 > .holder.border { border: 1px solid var(--ot-bg-2-border); border-radius: var(--ot-radius-m); padding: var(--ot-spacing-m); }
22
29
 
23
30
  /* Line wrapper */
24
31
 
@@ -119,7 +126,7 @@
119
126
  display: flex;
120
127
  flex-direction: column;
121
128
  gap: var(--ot-spacing-x);
122
- padding-left: 24px;
129
+ padding-left: var(--ot-spacing-l);
123
130
  margin: 0;
124
131
  }
125
132
 
@@ -152,7 +159,7 @@
152
159
  border-left: 3px solid var(--ot-brand);
153
160
  padding: var(--ot-spacing-s) var(--ot-spacing-m);
154
161
  background: var(--ot-bg-2);
155
- border-radius: 0 8px 8px 0;
162
+ border-radius: 0 var(--ot-radius-m) var(--ot-radius-m) 0;
156
163
  margin: 0;
157
164
  font-size: var(--ot-size-m);
158
165
  color: var(--ot-text-2);
@@ -164,8 +171,8 @@
164
171
 
165
172
  .e-4696d703 > .holder code.inline
166
173
  {
167
- padding: 2px 7px;
168
- border-radius: 4px;
174
+ padding: var(--ot-spacing-x) var(--ot-spacing-s);
175
+ border-radius: var(--ot-radius-s);
169
176
  background: var(--ot-bg-2);
170
177
  border: 1px solid var(--ot-bg-2-border);
171
178
  font-family: 'JetBrains Mono', 'Fira Code', monospace;
@@ -180,7 +187,7 @@
180
187
  position: relative;
181
188
  background: var(--ot-bg-2);
182
189
  border: 1px solid var(--ot-bg-2-border);
183
- border-radius: 8px;
190
+ border-radius: var(--ot-radius-m);
184
191
  padding: var(--ot-spacing-m);
185
192
  overflow-x: auto;
186
193
  margin: 0;
@@ -189,7 +196,7 @@
189
196
  .e-4696d703 > .holder .codeblock > code
190
197
  {
191
198
  font-family: 'JetBrains Mono', 'Fira Code', monospace;
192
- font-size: 13px;
199
+ font-size: var(--ot-size-m);
193
200
  line-height: 1.7;
194
201
  color: var(--ot-text-1);
195
202
  tab-size: 4;
@@ -201,7 +208,7 @@
201
208
  {
202
209
  width: 100%;
203
210
  border-collapse: collapse;
204
- border-radius: 8px;
211
+ border-radius: var(--ot-radius-m);
205
212
  background-color: var(--ot-bg-2);
206
213
  overflow: hidden;
207
214
  }
@@ -251,6 +258,6 @@
251
258
  {
252
259
  max-width: 100%;
253
260
  height: auto;
254
- border-radius: 8px;
261
+ border-radius: var(--ot-radius-m);
255
262
  border: 1px solid var(--ot-bg-2-border);
256
263
  }
@@ -0,0 +1,26 @@
1
+ onetype.AddonReady('elements', (elements) =>
2
+ {
3
+ elements.ItemAdd({
4
+ id: 'global-markdown',
5
+ icon: 'article',
6
+ name: 'Markdown',
7
+ description: 'Renders markdown content as styled HTML.',
8
+ category: 'Global',
9
+ author: 'OneType',
10
+ config: {
11
+ content: {
12
+ type: 'string',
13
+ value: ''
14
+ },
15
+ variant: {
16
+ type: 'array',
17
+ value: [],
18
+ options: ['bg-1', 'bg-2', 'bg-3', 'bg-4', 'border']
19
+ }
20
+ },
21
+ render: function()
22
+ {
23
+ return `<div :class="'holder ' + variant.join(' ')">${onetype.Markdown(this.content)}</div>`;
24
+ }
25
+ });
26
+ });
@@ -0,0 +1,173 @@
1
+ /* Root */
2
+
3
+ .e-4a1a1973
4
+ {
5
+ display: flex;
6
+ width: 100%;
7
+ }
8
+
9
+ .e-4a1a1973 .e-4a1a1973
10
+ {
11
+ flex-direction: column;
12
+ padding-left: var(--ot-spacing-m);
13
+ }
14
+
15
+ /* Holder */
16
+
17
+ .e-4a1a1973 > .holder
18
+ {
19
+ display: flex;
20
+ flex-direction: column;
21
+ width: 100%;
22
+ padding: var(--ot-spacing-x) 0;
23
+ border: 1px solid transparent;
24
+ border-radius: var(--ot-radius-m);
25
+ overflow: hidden;
26
+ }
27
+
28
+ /* Entry */
29
+
30
+ .e-4a1a1973 .entry
31
+ {
32
+ display: flex;
33
+ flex-direction: column;
34
+ }
35
+
36
+ /* Content (clickable row) */
37
+
38
+ .e-4a1a1973 .entry > .content
39
+ {
40
+ display: flex;
41
+ align-items: center;
42
+ gap: var(--ot-spacing-s);
43
+ padding: 0 var(--ot-spacing-m);
44
+ padding-left: calc(var(--ot-spacing-m) + var(--ot-spacing-m) * var(--depth, 0));
45
+ height: var(--ot-height-m);
46
+ cursor: pointer;
47
+ user-select: none;
48
+ transition: background 0.1s ease;
49
+ }
50
+
51
+ .e-4a1a1973 .entry > .content:hover
52
+ {
53
+ background: var(--ot-bg-1-hover);
54
+ }
55
+
56
+ .e-4a1a1973 .entry.disabled > .content
57
+ {
58
+ opacity: 0.4;
59
+ cursor: not-allowed;
60
+ pointer-events: none;
61
+ }
62
+
63
+ /* Icon */
64
+
65
+ .e-4a1a1973 .entry > .content > .icon
66
+ {
67
+ font-size: var(--ot-size-m);
68
+ color: var(--ot-text-2);
69
+ width: 20px;
70
+ text-align: center;
71
+ flex-shrink: 0;
72
+ }
73
+
74
+ /* Label */
75
+
76
+ .e-4a1a1973 .entry > .content > .label
77
+ {
78
+ font-size: var(--ot-size-m);
79
+ color: var(--ot-text-1);
80
+ flex: 1;
81
+ white-space: nowrap;
82
+ overflow: hidden;
83
+ text-overflow: ellipsis;
84
+ }
85
+
86
+ /* Shortcut */
87
+
88
+ .e-4a1a1973 .entry > .content > .shortcut
89
+ {
90
+ font-size: var(--ot-size-s);
91
+ color: var(--ot-text-2);
92
+ opacity: 0.6;
93
+ flex-shrink: 0;
94
+ margin-left: var(--ot-spacing-l);
95
+ letter-spacing: 0.02em;
96
+ }
97
+
98
+ /* Arrow */
99
+
100
+ .e-4a1a1973 .entry > .content > .arrow
101
+ {
102
+ font-size: var(--ot-size-m);
103
+ color: var(--ot-text-2);
104
+ flex-shrink: 0;
105
+ margin-left: auto;
106
+ transition: color 0.15s ease;
107
+ }
108
+
109
+ .e-4a1a1973 .entry.open > .content > .arrow
110
+ {
111
+ color: var(--ot-text-1);
112
+ }
113
+
114
+ /* Separator */
115
+
116
+ .e-4a1a1973 .entry > .separator
117
+ {
118
+ height: 1px;
119
+ margin: var(--ot-spacing-x) var(--ot-spacing-m);
120
+ background: var(--ot-bg-2-border);
121
+ }
122
+
123
+ /* Header */
124
+
125
+ .e-4a1a1973 .entry > .header
126
+ {
127
+ font-size: var(--ot-size-s);
128
+ font-weight: 600;
129
+ color: var(--ot-text-2);
130
+ padding: var(--ot-spacing-s) var(--ot-spacing-m) var(--ot-spacing-x);
131
+ user-select: none;
132
+ text-transform: uppercase;
133
+ letter-spacing: 0.04em;
134
+ }
135
+
136
+ /* Background variants */
137
+
138
+ .e-4a1a1973 > .holder.bg-1 { background: var(--ot-bg-1); border-color: var(--ot-bg-1-border); }
139
+ .e-4a1a1973 > .holder.bg-1 .entry > .content:hover { background: var(--ot-bg-1-hover); }
140
+ .e-4a1a1973 > .holder.bg-1 .entry > .separator { background: var(--ot-bg-1-border); }
141
+
142
+ .e-4a1a1973 > .holder.bg-2 { background: var(--ot-bg-2); border-color: var(--ot-bg-2-border); }
143
+ .e-4a1a1973 > .holder.bg-2 .entry > .content:hover { background: var(--ot-bg-2-hover); }
144
+ .e-4a1a1973 > .holder.bg-2 .entry > .separator { background: var(--ot-bg-2-border); }
145
+
146
+ .e-4a1a1973 > .holder.bg-3 { background: var(--ot-bg-3); border-color: var(--ot-bg-3-border); }
147
+ .e-4a1a1973 > .holder.bg-3 .entry > .content:hover { background: var(--ot-bg-3-hover); }
148
+ .e-4a1a1973 > .holder.bg-3 .entry > .separator { background: var(--ot-bg-3-border); }
149
+
150
+ .e-4a1a1973 > .holder.bg-4 { background: var(--ot-bg-4); border-color: var(--ot-bg-4-border); }
151
+ .e-4a1a1973 > .holder.bg-4 .entry > .content:hover { background: var(--ot-bg-4-hover); }
152
+ .e-4a1a1973 > .holder.bg-4 .entry > .separator { background: var(--ot-bg-4-border); }
153
+
154
+ /* Border variant */
155
+
156
+ .e-4a1a1973 > .holder.border { border: 1px solid var(--ot-bg-2-border); }
157
+
158
+ /* Size variants */
159
+
160
+ .e-4a1a1973 > .holder.size-s .entry > .content { height: var(--ot-height-s); padding: 0 var(--ot-spacing-s); gap: var(--ot-spacing-x); }
161
+ .e-4a1a1973 > .holder.size-s .entry > .content > .icon { font-size: var(--ot-size-s); width: 16px; }
162
+ .e-4a1a1973 > .holder.size-s .entry > .content > .label { font-size: var(--ot-size-s); }
163
+ .e-4a1a1973 > .holder.size-s .entry > .content > .shortcut { font-size: 10px; }
164
+ .e-4a1a1973 > .holder.size-s .entry > .header { font-size: 10px; padding: var(--ot-spacing-x) var(--ot-spacing-s) 2px; }
165
+ .e-4a1a1973 > .holder.size-s .entry > .separator { margin: 2px var(--ot-spacing-s); }
166
+
167
+ .e-4a1a1973 > .holder.size-m .entry > .content { height: var(--ot-height-m); }
168
+
169
+ .e-4a1a1973 > .holder.size-l .entry > .content { height: var(--ot-height-l); padding: 0 var(--ot-spacing-l); gap: var(--ot-spacing-m); }
170
+ .e-4a1a1973 > .holder.size-l .entry > .content > .icon { font-size: var(--ot-size-l); width: 28px; }
171
+ .e-4a1a1973 > .holder.size-l .entry > .content > .label { font-size: var(--ot-size-m); }
172
+ .e-4a1a1973 > .holder.size-l .entry > .header { font-size: var(--ot-size-s); padding: var(--ot-spacing-m) var(--ot-spacing-l) var(--ot-spacing-x); }
173
+ .e-4a1a1973 > .holder.size-l .entry > .separator { margin: var(--ot-spacing-x) var(--ot-spacing-l); }
@@ -0,0 +1,103 @@
1
+ onetype.AddonReady('elements', (elements) =>
2
+ {
3
+ elements.ItemAdd({
4
+ id: 'global-menu',
5
+ icon: 'menu',
6
+ name: 'Menu',
7
+ description: 'Multi-level menu with icons, shortcuts, headers and separators.',
8
+ category: 'Global',
9
+ author: 'OneType',
10
+ config: {
11
+ items: {
12
+ type: 'array',
13
+ value: [],
14
+ each: {
15
+ type: 'object',
16
+ config: {
17
+ type: { type: 'string', value: 'action', options: ['action', 'separator', 'header'] },
18
+ icon: { type: 'string', value: '' },
19
+ label: { type: 'string', value: '' },
20
+ value: { type: 'string', value: '' },
21
+ shortcut: { type: 'string', value: '' },
22
+ disabled: { type: 'boolean', value: false },
23
+ items: { type: 'array', value: [] }
24
+ }
25
+ }
26
+ },
27
+ depth: {
28
+ type: 'number',
29
+ value: 0
30
+ },
31
+ variant: {
32
+ type: 'array',
33
+ value: ['bg-2', 'size-m'],
34
+ options: ['bg-1', 'bg-2', 'bg-3', 'bg-4', 'border', 'size-s', 'size-m', 'size-l']
35
+ },
36
+ _select: {
37
+ type: 'function'
38
+ }
39
+ },
40
+ render: function()
41
+ {
42
+ this.opened = {};
43
+
44
+ this.toggle = (index) =>
45
+ {
46
+ this.opened[index] = !this.opened[index];
47
+ this.Update();
48
+ };
49
+
50
+ this.isOpen = (index) =>
51
+ {
52
+ return !!this.opened[index];
53
+ };
54
+
55
+ this.select = (item) =>
56
+ {
57
+ if (item.disabled)
58
+ {
59
+ return;
60
+ }
61
+
62
+ if (this._select)
63
+ {
64
+ this._select({ value: item.value || item.label });
65
+ }
66
+ };
67
+
68
+ this.hasChildren = (item) =>
69
+ {
70
+ return item.items && item.items.length > 0;
71
+ };
72
+
73
+ const items = `
74
+ <div ot-for="item, index in items" :class="'entry ' + item.type + (item.disabled ? ' disabled' : '') + (hasChildren(item) ? ' parent' : '') + (isOpen(index) ? ' open' : '')">
75
+ <div ot-if="item.type === 'separator'" class="separator"></div>
76
+ <div ot-if="item.type === 'header'" class="header">{{ item.label }}</div>
77
+ <div ot-if="item.type === 'action' && hasChildren(item)" class="content" ot-click="toggle(index)">
78
+ <i ot-if="item.icon" class="icon">{{ item.icon }}</i>
79
+ <span class="label">{{ item.label }}</span>
80
+ <i class="arrow">{{ isOpen(index) ? 'expand_less' : 'expand_more' }}</i>
81
+ </div>
82
+ <div ot-if="item.type === 'action' && !hasChildren(item)" class="content" ot-click="select(item)">
83
+ <i ot-if="item.icon" class="icon">{{ item.icon }}</i>
84
+ <span class="label">{{ item.label }}</span>
85
+ <span ot-if="item.shortcut" class="shortcut">{{ item.shortcut }}</span>
86
+ </div>
87
+ <e-global-menu ot-if="hasChildren(item) && isOpen(index)" :items="item.items" :depth="depth + 1" :_select="_select" :style="'--depth: ' + (depth + 1)"></e-global-menu>
88
+ </div>
89
+ `;
90
+
91
+ if (this.depth > 0)
92
+ {
93
+ return items;
94
+ }
95
+
96
+ return `
97
+ <div :class="'holder ' + variant.join(' ')">
98
+ ${items}
99
+ </div>
100
+ `;
101
+ }
102
+ });
103
+ });
@@ -0,0 +1,57 @@
1
+ /* Root */
2
+
3
+ .e-2e3de5ec
4
+ {
5
+ display: flex;
6
+ width: 100%;
7
+ }
8
+
9
+ /* Holder */
10
+
11
+ .e-2e3de5ec > .holder
12
+ {
13
+ display: flex;
14
+ align-items: center;
15
+ gap: var(--ot-spacing-s);
16
+ width: 100%;
17
+ padding: var(--ot-spacing-s) var(--ot-spacing-m);
18
+ border-radius: var(--ot-radius-m);
19
+ font-size: var(--ot-size-s);
20
+ border: 1px solid transparent;
21
+ }
22
+
23
+ /* Icon */
24
+
25
+ .e-2e3de5ec > .holder > .icon
26
+ {
27
+ font-size: var(--ot-size-m);
28
+ flex-shrink: 0;
29
+ }
30
+
31
+ /* Text */
32
+
33
+ .e-2e3de5ec > .holder > .text
34
+ {
35
+ line-height: 1.4;
36
+ }
37
+
38
+ /* Color variants */
39
+
40
+ .e-2e3de5ec > .holder.red { background: var(--ot-red-opacity); border-color: var(--ot-red-border); color: var(--ot-red); }
41
+ .e-2e3de5ec > .holder.green { background: var(--ot-green-opacity); border-color: var(--ot-green-border); color: var(--ot-green); }
42
+ .e-2e3de5ec > .holder.blue { background: var(--ot-blue-opacity); border-color: var(--ot-blue-border); color: var(--ot-blue); }
43
+ .e-2e3de5ec > .holder.orange { background: var(--ot-orange-opacity); border-color: var(--ot-orange-border); color: var(--ot-orange); }
44
+ .e-2e3de5ec > .holder.brand { background: var(--ot-brand-opacity); border-color: var(--ot-brand-border); color: var(--ot-brand); }
45
+
46
+ /* Background variants */
47
+
48
+ .e-2e3de5ec > .holder.bg-1 { background: var(--ot-bg-1); border-color: var(--ot-bg-1-border); color: var(--ot-text-2); }
49
+ .e-2e3de5ec > .holder.bg-2 { background: var(--ot-bg-2); border-color: var(--ot-bg-2-border); color: var(--ot-text-2); }
50
+ .e-2e3de5ec > .holder.bg-3 { background: var(--ot-bg-3); border-color: var(--ot-bg-3-border); color: var(--ot-text-2); }
51
+ .e-2e3de5ec > .holder.bg-4 { background: var(--ot-bg-4); border-color: var(--ot-bg-4-border); color: var(--ot-text-2); }
52
+
53
+ /* Size variants */
54
+
55
+ .e-2e3de5ec > .holder.size-s { padding: var(--ot-spacing-x) var(--ot-spacing-s); font-size: var(--ot-size-s); }
56
+ .e-2e3de5ec > .holder.size-m { padding: var(--ot-spacing-s) var(--ot-spacing-m); font-size: var(--ot-size-m); }
57
+ .e-2e3de5ec > .holder.size-l { padding: var(--ot-spacing-m) var(--ot-spacing-l); font-size: var(--ot-size-m); }
@@ -17,15 +17,15 @@ onetype.AddonReady('elements', (elements) =>
17
17
  value: ''
18
18
  },
19
19
  variant: {
20
- type: 'string',
21
- value: 'red',
22
- options: ['red', 'green', 'blue', 'orange', 'brand', 'bg-1', 'bg-2', 'bg-3', 'bg-4']
20
+ type: 'array',
21
+ value: ['red'],
22
+ options: ['red', 'green', 'blue', 'orange', 'brand', 'bg-1', 'bg-2', 'bg-3', 'bg-4', 'size-s', 'size-m', 'size-l']
23
23
  }
24
24
  },
25
25
  render: function()
26
26
  {
27
27
  return `
28
- <div class="holder" :variant="variant">
28
+ <div :class="'holder ' + variant.join(' ')">
29
29
  <i ot-if="icon" class="icon">{{ icon }}</i>
30
30
  <span class="text">{{ text }}</span>
31
31
  </div>
@@ -0,0 +1,96 @@
1
+ /* Root */
2
+
3
+ .e-29179902
4
+ {
5
+ display: flex;
6
+ width: 100%;
7
+ }
8
+
9
+ /* Holder */
10
+
11
+ .e-29179902 > .holder
12
+ {
13
+ display: flex;
14
+ flex-direction: column;
15
+ width: 100%;
16
+ }
17
+
18
+ /* Param */
19
+
20
+ .e-29179902 > .holder > .param
21
+ {
22
+ display: flex;
23
+ align-items: center;
24
+ justify-content: space-between;
25
+ gap: var(--ot-spacing-m);
26
+ padding: var(--ot-spacing-s) 0;
27
+ border-bottom: 1px solid var(--ot-bg-2-border);
28
+ }
29
+
30
+ .e-29179902 > .holder > .param:last-child
31
+ {
32
+ border-bottom: none;
33
+ }
34
+
35
+ /* Left */
36
+
37
+ .e-29179902 > .holder > .param > .left
38
+ {
39
+ display: flex;
40
+ align-items: center;
41
+ gap: var(--ot-spacing-s);
42
+ }
43
+
44
+ /* Name */
45
+
46
+ .e-29179902 > .holder > .param > .left > .name
47
+ {
48
+ font-size: var(--ot-size-m);
49
+ font-weight: 600;
50
+ font-family: monospace;
51
+ color: var(--ot-text-1);
52
+ }
53
+
54
+ /* Type badge */
55
+
56
+ .e-29179902 > .holder > .param > .left > .type
57
+ {
58
+ font-size: var(--ot-size-s);
59
+ font-weight: 500;
60
+ padding: var(--ot-spacing-x) var(--ot-spacing-s);
61
+ border-radius: var(--ot-radius-s);
62
+ background: var(--ot-blue-opacity);
63
+ color: var(--ot-blue);
64
+ }
65
+
66
+ /* Required badge */
67
+
68
+ .e-29179902 > .holder > .param > .left > .required
69
+ {
70
+ font-size: var(--ot-size-s);
71
+ font-weight: 500;
72
+ padding: var(--ot-spacing-x) var(--ot-spacing-s);
73
+ border-radius: var(--ot-radius-s);
74
+ background: var(--ot-orange-opacity);
75
+ color: var(--ot-orange);
76
+ }
77
+
78
+ /* Description */
79
+
80
+ .e-29179902 > .holder > .param > .description
81
+ {
82
+ font-size: var(--ot-size-s);
83
+ color: var(--ot-text-2);
84
+ text-align: right;
85
+ }
86
+
87
+ /* Background variants */
88
+
89
+ .e-29179902 > .holder.bg-1 { background: var(--ot-bg-1); border: 1px solid var(--ot-bg-1-border); border-radius: var(--ot-radius-m); padding: var(--ot-spacing-m); }
90
+ .e-29179902 > .holder.bg-2 { background: var(--ot-bg-2); border: 1px solid var(--ot-bg-2-border); border-radius: var(--ot-radius-m); padding: var(--ot-spacing-m); }
91
+ .e-29179902 > .holder.bg-3 { background: var(--ot-bg-3); border: 1px solid var(--ot-bg-3-border); border-radius: var(--ot-radius-m); padding: var(--ot-spacing-m); }
92
+ .e-29179902 > .holder.bg-4 { background: var(--ot-bg-4); border: 1px solid var(--ot-bg-4-border); border-radius: var(--ot-radius-m); padding: var(--ot-spacing-m); }
93
+
94
+ /* Border variant */
95
+
96
+ .e-29179902 > .holder.border { border: 1px solid var(--ot-bg-2-border); border-radius: var(--ot-radius-m); padding: var(--ot-spacing-m); }
@@ -10,25 +10,34 @@ onetype.AddonReady('elements', (elements) =>
10
10
  config: {
11
11
  items: {
12
12
  type: 'array',
13
- value: []
13
+ value: [],
14
+ each: {
15
+ type: 'object',
16
+ config: {
17
+ name: { type: 'string', value: '' },
18
+ type: { type: 'string', value: '' },
19
+ required: { type: 'boolean', value: false },
20
+ description: { type: 'string', value: '' }
21
+ }
22
+ }
14
23
  },
15
24
  variant: {
16
- type: 'string',
17
- value: '',
18
- options: ['', 'bg-2']
25
+ type: 'array',
26
+ value: [],
27
+ options: ['bg-1', 'bg-2', 'bg-3', 'bg-4', 'border']
19
28
  }
20
29
  },
21
30
  render: function()
22
31
  {
23
32
  return `
24
- <div class="holder" :variant="variant">
33
+ <div :class="'holder ' + variant.join(' ')">
25
34
  <div ot-for="item in items" class="param">
26
35
  <div class="left">
27
36
  <span class="name">{{ item.name }}</span>
28
37
  <span class="type">{{ item.type }}</span>
29
38
  <span ot-if="item.required" class="required">required</span>
30
39
  </div>
31
- <span ot-if="item.description" class="desc">{{ item.description }}</span>
40
+ <span ot-if="item.description" class="description">{{ item.description }}</span>
32
41
  </div>
33
42
  </div>
34
43
  `;