@nuraly/lumenui 0.2.1 → 0.2.2

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 (525) hide show
  1. package/dist/nuralyui.bundle.js +2010 -1271
  2. package/dist/nuralyui.bundle.js.gz +0 -0
  3. package/dist/src/components/button/controllers/base.controller.d.ts +15 -0
  4. package/dist/src/components/button/controllers/base.controller.js +13 -0
  5. package/dist/src/components/button/controllers/index.d.ts +10 -0
  6. package/dist/src/components/button/controllers/index.js +10 -0
  7. package/dist/src/components/button/controllers/keyboard.controller.d.ts +32 -0
  8. package/dist/src/components/button/controllers/keyboard.controller.js +78 -0
  9. package/dist/src/components/button/controllers/link.controller.d.ts +30 -0
  10. package/dist/src/components/button/controllers/link.controller.js +75 -0
  11. package/dist/src/components/button/controllers/ripple.controller.d.ts +23 -0
  12. package/dist/src/components/button/controllers/ripple.controller.js +69 -0
  13. package/dist/src/components/button/interfaces/base-controller.interface.d.ts +61 -0
  14. package/dist/src/components/button/interfaces/base-controller.interface.js +7 -0
  15. package/dist/src/components/button/interfaces/index.d.ts +2 -0
  16. package/dist/src/components/button/interfaces/index.js +2 -0
  17. package/dist/src/components/button/test/nr-button_test.d.ts +2 -0
  18. package/dist/src/components/button/test/nr-button_test.js +91 -0
  19. package/dist/src/components/canvas/base-canvas.component.d.ts +2 -1
  20. package/dist/src/components/canvas/base-canvas.component.js +6 -0
  21. package/dist/src/components/canvas/bundle.js +702 -475
  22. package/dist/src/components/canvas/bundle.js.gz +0 -0
  23. package/dist/src/components/canvas/chatbot-panel.style.js +50 -59
  24. package/dist/src/components/canvas/chatbot-trigger/chatbot-trigger-fields.component.d.ts +115 -0
  25. package/dist/src/components/canvas/chatbot-trigger/chatbot-trigger-fields.component.js +480 -0
  26. package/dist/src/components/canvas/chatbot-trigger/chatbot-trigger-fields.style.d.ts +7 -0
  27. package/dist/src/components/canvas/chatbot-trigger/chatbot-trigger-fields.style.js +323 -0
  28. package/dist/src/components/canvas/chatbot-trigger/chatbot-trigger.types.d.ts +162 -0
  29. package/dist/src/components/canvas/chatbot-trigger/chatbot-trigger.types.js +88 -0
  30. package/dist/src/components/canvas/chatbot-trigger/index.d.ts +9 -0
  31. package/dist/src/components/canvas/chatbot-trigger/index.js +12 -0
  32. package/dist/src/components/canvas/controllers/base.controller.d.ts +53 -0
  33. package/dist/src/components/canvas/controllers/base.controller.js +80 -0
  34. package/dist/src/components/canvas/controllers/clipboard.controller.d.ts +80 -0
  35. package/dist/src/components/canvas/controllers/clipboard.controller.js +300 -0
  36. package/dist/src/components/canvas/controllers/collaboration.controller.d.ts +54 -0
  37. package/dist/src/components/canvas/controllers/collaboration.controller.js +425 -0
  38. package/dist/src/components/canvas/controllers/config.controller.d.ts +61 -0
  39. package/dist/src/components/canvas/controllers/config.controller.js +118 -0
  40. package/dist/src/components/canvas/controllers/connection.controller.d.ts +69 -0
  41. package/dist/src/components/canvas/controllers/connection.controller.js +183 -0
  42. package/dist/src/components/canvas/controllers/drag.controller.d.ts +56 -0
  43. package/dist/src/components/canvas/controllers/drag.controller.js +195 -0
  44. package/dist/src/components/canvas/controllers/frame.controller.d.ts +94 -0
  45. package/dist/src/components/canvas/controllers/frame.controller.js +456 -0
  46. package/dist/src/components/canvas/controllers/index.d.ts +19 -0
  47. package/dist/src/components/canvas/controllers/index.js +32 -0
  48. package/dist/src/components/canvas/controllers/keyboard.controller.d.ts +44 -0
  49. package/dist/src/components/canvas/controllers/keyboard.controller.js +275 -0
  50. package/dist/src/components/canvas/controllers/marquee.controller.d.ts +71 -0
  51. package/dist/src/components/canvas/controllers/marquee.controller.js +128 -0
  52. package/dist/src/components/canvas/controllers/selection.controller.d.ts +85 -0
  53. package/dist/src/components/canvas/controllers/selection.controller.js +202 -0
  54. package/dist/src/components/canvas/controllers/touch.controller.d.ts +55 -0
  55. package/dist/src/components/canvas/controllers/touch.controller.js +299 -0
  56. package/dist/src/components/canvas/controllers/undo.controller.d.ts +100 -0
  57. package/dist/src/components/canvas/controllers/undo.controller.js +218 -0
  58. package/dist/src/components/canvas/controllers/viewport.controller.d.ts +91 -0
  59. package/dist/src/components/canvas/controllers/viewport.controller.js +287 -0
  60. package/dist/src/components/canvas/data-node/data-node-config.component.d.ts +67 -0
  61. package/dist/src/components/canvas/data-node/data-node-config.component.js +496 -0
  62. package/dist/src/components/canvas/data-node/data-node-fields.component.d.ts +198 -0
  63. package/dist/src/components/canvas/data-node/data-node-fields.component.js +931 -0
  64. package/dist/src/components/canvas/data-node/data-node-fields.style.d.ts +7 -0
  65. package/dist/src/components/canvas/data-node/data-node-fields.style.js +448 -0
  66. package/dist/src/components/canvas/data-node/data-node.types.d.ts +245 -0
  67. package/dist/src/components/canvas/data-node/data-node.types.js +158 -0
  68. package/dist/src/components/canvas/data-node/index.d.ts +9 -0
  69. package/dist/src/components/canvas/data-node/index.js +12 -0
  70. package/dist/src/components/canvas/data-node/schema-select.component.d.ts +36 -0
  71. package/dist/src/components/canvas/data-node/schema-select.component.js +196 -0
  72. package/dist/src/components/canvas/data-node/table-select.component.d.ts +38 -0
  73. package/dist/src/components/canvas/data-node/table-select.component.js +199 -0
  74. package/dist/src/components/canvas/interfaces/canvas-host.interface.d.ts +91 -0
  75. package/dist/src/components/canvas/interfaces/canvas-host.interface.js +7 -0
  76. package/dist/src/components/canvas/interfaces/collaboration.interface.d.ts +58 -0
  77. package/dist/src/components/canvas/interfaces/collaboration.interface.js +10 -0
  78. package/dist/src/components/canvas/interfaces/index.d.ts +8 -0
  79. package/dist/src/components/canvas/interfaces/index.js +7 -0
  80. package/dist/src/components/canvas/templates/chatbot-panel.template.d.ts +28 -0
  81. package/dist/src/components/canvas/templates/chatbot-panel.template.js +49 -0
  82. package/dist/src/components/canvas/templates/config-panel.template.d.ts +22 -0
  83. package/dist/src/components/canvas/templates/config-panel.template.js +22 -0
  84. package/dist/src/components/canvas/templates/context-menu.template.d.ts +30 -0
  85. package/dist/src/components/canvas/templates/context-menu.template.js +80 -0
  86. package/dist/src/components/canvas/templates/edges.template.d.ts +41 -0
  87. package/dist/src/components/canvas/templates/edges.template.js +243 -0
  88. package/dist/src/components/canvas/templates/empty-state.template.d.ts +17 -0
  89. package/dist/src/components/canvas/templates/empty-state.template.js +25 -0
  90. package/dist/src/components/canvas/templates/frame.template.d.ts +24 -0
  91. package/dist/src/components/canvas/templates/frame.template.js +74 -0
  92. package/dist/src/components/canvas/templates/index.d.ts +18 -0
  93. package/dist/src/components/canvas/templates/index.js +30 -0
  94. package/dist/src/components/canvas/templates/palette.template.d.ts +27 -0
  95. package/dist/src/components/canvas/templates/palette.template.js +110 -0
  96. package/dist/src/components/canvas/templates/presence-bar.template.d.ts +18 -0
  97. package/dist/src/components/canvas/templates/presence-bar.template.js +60 -0
  98. package/dist/src/components/canvas/templates/remote-cursors.template.d.ts +19 -0
  99. package/dist/src/components/canvas/templates/remote-cursors.template.js +43 -0
  100. package/dist/src/components/canvas/templates/toolbar.template.d.ts +52 -0
  101. package/dist/src/components/canvas/templates/toolbar.template.js +118 -0
  102. package/dist/src/components/canvas/templates/wb-floating-toolbar.template.d.ts +30 -0
  103. package/dist/src/components/canvas/templates/wb-floating-toolbar.template.js +219 -0
  104. package/dist/src/components/canvas/templates/wb-sidebar.template.d.ts +23 -0
  105. package/dist/src/components/canvas/templates/wb-sidebar.template.js +152 -0
  106. package/dist/src/components/canvas/utils/variable-resolver.d.ts +71 -0
  107. package/dist/src/components/canvas/utils/variable-resolver.js +280 -0
  108. package/dist/src/components/canvas/workflow-canvas.component.js +6 -0
  109. package/dist/src/components/canvas/workflow-canvas.style.js +46 -55
  110. package/dist/src/components/carousel/demo/carousel-demo.d.ts +6 -0
  111. package/dist/src/components/carousel/demo/carousel-demo.js +68 -0
  112. package/dist/src/components/chatbot/audio-compress.d.ts +26 -0
  113. package/dist/src/components/chatbot/audio-compress.js +84 -0
  114. package/dist/src/components/chatbot/bundle.js +388 -144
  115. package/dist/src/components/chatbot/bundle.js.gz +0 -0
  116. package/dist/src/components/chatbot/chatbot-audio.controller.d.ts +35 -0
  117. package/dist/src/components/chatbot/chatbot-audio.controller.js +160 -0
  118. package/dist/src/components/chatbot/chatbot.component.d.ts +12 -0
  119. package/dist/src/components/chatbot/chatbot.component.js +41 -2
  120. package/dist/src/components/chatbot/chatbot.style.js +141 -0
  121. package/dist/src/components/chatbot/chatbot.types.d.ts +8 -0
  122. package/dist/src/components/chatbot/controllers/index.d.ts +8 -0
  123. package/dist/src/components/chatbot/controllers/index.js +8 -0
  124. package/dist/src/components/chatbot/controllers/scroll.controller.d.ts +34 -0
  125. package/dist/src/components/chatbot/controllers/scroll.controller.js +43 -0
  126. package/dist/src/components/chatbot/core/chatbot-core.controller.d.ts +283 -0
  127. package/dist/src/components/chatbot/core/chatbot-core.controller.js +824 -0
  128. package/dist/src/components/chatbot/core/event-bus.d.ts +54 -0
  129. package/dist/src/components/chatbot/core/event-bus.js +102 -0
  130. package/dist/src/components/chatbot/core/index.d.ts +12 -0
  131. package/dist/src/components/chatbot/core/index.js +15 -0
  132. package/dist/src/components/chatbot/core/types.d.ts +403 -0
  133. package/dist/src/components/chatbot/core/types.js +16 -0
  134. package/dist/src/components/chatbot/locales/locale-codes.d.ts +14 -0
  135. package/dist/src/components/chatbot/locales/locale-codes.js +23 -0
  136. package/dist/src/components/chatbot/plugins/analytics-plugin.d.ts +23 -0
  137. package/dist/src/components/chatbot/plugins/analytics-plugin.js +52 -0
  138. package/dist/src/components/chatbot/plugins/artifact-plugin.d.ts +71 -0
  139. package/dist/src/components/chatbot/plugins/artifact-plugin.js +313 -0
  140. package/dist/src/components/chatbot/plugins/chat-plugin.d.ts +44 -0
  141. package/dist/src/components/chatbot/plugins/chat-plugin.js +58 -0
  142. package/dist/src/components/chatbot/plugins/flight-card-plugin.d.ts +116 -0
  143. package/dist/src/components/chatbot/plugins/flight-card-plugin.js +594 -0
  144. package/dist/src/components/chatbot/plugins/flow-diagram-plugin.d.ts +23 -0
  145. package/dist/src/components/chatbot/plugins/flow-diagram-plugin.js +495 -0
  146. package/dist/src/components/chatbot/plugins/index.d.ts +16 -0
  147. package/dist/src/components/chatbot/plugins/index.js +17 -0
  148. package/dist/src/components/chatbot/plugins/json-graph-renderer-plugin.d.ts +43 -0
  149. package/dist/src/components/chatbot/plugins/json-graph-renderer-plugin.js +166 -0
  150. package/dist/src/components/chatbot/plugins/markdown-plugin.d.ts +26 -0
  151. package/dist/src/components/chatbot/plugins/markdown-plugin.js +68 -0
  152. package/dist/src/components/chatbot/plugins/persistence-plugin.d.ts +30 -0
  153. package/dist/src/components/chatbot/plugins/persistence-plugin.js +91 -0
  154. package/dist/src/components/chatbot/plugins/print-job-card-plugin.d.ts +110 -0
  155. package/dist/src/components/chatbot/plugins/print-job-card-plugin.js +505 -0
  156. package/dist/src/components/chatbot/plugins/selection-card-plugin.d.ts +111 -0
  157. package/dist/src/components/chatbot/plugins/selection-card-plugin.js +318 -0
  158. package/dist/src/components/chatbot/providers/custom-api-provider.d.ts +63 -0
  159. package/dist/src/components/chatbot/providers/custom-api-provider.js +240 -0
  160. package/dist/src/components/chatbot/providers/index.d.ts +16 -0
  161. package/dist/src/components/chatbot/providers/index.js +13 -0
  162. package/dist/src/components/chatbot/providers/mock-provider.d.ts +154 -0
  163. package/dist/src/components/chatbot/providers/mock-provider.js +411 -0
  164. package/dist/src/components/chatbot/providers/native-ws-provider.d.ts +184 -0
  165. package/dist/src/components/chatbot/providers/native-ws-provider.js +544 -0
  166. package/dist/src/components/chatbot/providers/openai-provider.d.ts +32 -0
  167. package/dist/src/components/chatbot/providers/openai-provider.js +246 -0
  168. package/dist/src/components/chatbot/providers/socket-provider.d.ts +159 -0
  169. package/dist/src/components/chatbot/providers/socket-provider.js +390 -0
  170. package/dist/src/components/chatbot/providers/workflow-socket-provider.d.ts +116 -0
  171. package/dist/src/components/chatbot/providers/workflow-socket-provider.js +484 -0
  172. package/dist/src/components/chatbot/storage/index.d.ts +7 -0
  173. package/dist/src/components/chatbot/storage/index.js +8 -0
  174. package/dist/src/components/chatbot/storage/storage-implementations.d.ts +43 -0
  175. package/dist/src/components/chatbot/storage/storage-implementations.js +179 -0
  176. package/dist/src/components/chatbot/templates/artifact-panel.template.d.ts +22 -0
  177. package/dist/src/components/chatbot/templates/artifact-panel.template.js +81 -0
  178. package/dist/src/components/chatbot/templates/chatbot-main.template.d.ts +49 -0
  179. package/dist/src/components/chatbot/templates/chatbot-main.template.js +115 -0
  180. package/dist/src/components/chatbot/templates/file-preview-modal.template.d.ts +19 -0
  181. package/dist/src/components/chatbot/templates/file-preview-modal.template.js +74 -0
  182. package/dist/src/components/chatbot/templates/file-upload-area.template.d.ts +19 -0
  183. package/dist/src/components/chatbot/templates/file-upload-area.template.js +29 -0
  184. package/dist/src/components/chatbot/templates/index.d.ts +15 -0
  185. package/dist/src/components/chatbot/templates/index.js +15 -0
  186. package/dist/src/components/chatbot/templates/input-box.template.d.ts +49 -0
  187. package/dist/src/components/chatbot/templates/input-box.template.js +317 -0
  188. package/dist/src/components/chatbot/templates/message.template.d.ts +31 -0
  189. package/dist/src/components/chatbot/templates/message.template.js +214 -0
  190. package/dist/src/components/chatbot/templates/suggestion.template.d.ts +20 -0
  191. package/dist/src/components/chatbot/templates/suggestion.template.js +40 -0
  192. package/dist/src/components/chatbot/templates/thread-sidebar.template.d.ts +24 -0
  193. package/dist/src/components/chatbot/templates/thread-sidebar.template.js +160 -0
  194. package/dist/src/components/chatbot/templates/url-modal.template.d.ts +25 -0
  195. package/dist/src/components/chatbot/templates/url-modal.template.js +100 -0
  196. package/dist/src/components/chatbot/utils/format.d.ts +23 -0
  197. package/dist/src/components/chatbot/utils/format.js +84 -0
  198. package/dist/src/components/chatbot/utils/index.d.ts +7 -0
  199. package/dist/src/components/chatbot/utils/index.js +7 -0
  200. package/dist/src/components/checkbox/mixins/checkbox-event-mixin.d.ts +87 -0
  201. package/dist/src/components/checkbox/mixins/checkbox-event-mixin.js +94 -0
  202. package/dist/src/components/checkbox/mixins/checkbox-focus-mixin.d.ts +55 -0
  203. package/dist/src/components/checkbox/mixins/checkbox-focus-mixin.js +57 -0
  204. package/dist/src/components/checkbox/mixins/index.d.ts +10 -0
  205. package/dist/src/components/checkbox/mixins/index.js +8 -0
  206. package/dist/src/components/checkbox/test/checkbox_test.d.ts +2 -0
  207. package/dist/src/components/checkbox/test/checkbox_test.js +88 -0
  208. package/dist/src/components/collapse/controllers/accordion.controller.d.ts +60 -0
  209. package/dist/src/components/collapse/controllers/accordion.controller.js +132 -0
  210. package/dist/src/components/collapse/controllers/animation.controller.d.ts +40 -0
  211. package/dist/src/components/collapse/controllers/animation.controller.js +125 -0
  212. package/dist/src/components/collapse/controllers/base.controller.d.ts +48 -0
  213. package/dist/src/components/collapse/controllers/base.controller.js +69 -0
  214. package/dist/src/components/collapse/controllers/index.d.ts +12 -0
  215. package/dist/src/components/collapse/controllers/index.js +11 -0
  216. package/dist/src/components/collapse/controllers/keyboard.controller.d.ts +73 -0
  217. package/dist/src/components/collapse/controllers/keyboard.controller.js +186 -0
  218. package/dist/src/components/colorpicker/controllers/base.controller.d.ts +14 -0
  219. package/dist/src/components/colorpicker/controllers/base.controller.js +15 -0
  220. package/dist/src/components/colorpicker/controllers/dropdown.controller.d.ts +60 -0
  221. package/dist/src/components/colorpicker/controllers/dropdown.controller.js +243 -0
  222. package/dist/src/components/colorpicker/controllers/event.controller.d.ts +46 -0
  223. package/dist/src/components/colorpicker/controllers/event.controller.js +130 -0
  224. package/dist/src/components/colorpicker/controllers/index.d.ts +4 -0
  225. package/dist/src/components/colorpicker/controllers/index.js +4 -0
  226. package/dist/src/components/colorpicker/interfaces/index.d.ts +60 -0
  227. package/dist/src/components/colorpicker/interfaces/index.js +2 -0
  228. package/dist/src/components/datepicker/controllers/calendar.controller.d.ts +78 -0
  229. package/dist/src/components/datepicker/controllers/calendar.controller.js +225 -0
  230. package/dist/src/components/datepicker/controllers/index.d.ts +11 -0
  231. package/dist/src/components/datepicker/controllers/index.js +11 -0
  232. package/dist/src/components/datepicker/controllers/keyboard.controller.d.ts +96 -0
  233. package/dist/src/components/datepicker/controllers/keyboard.controller.js +246 -0
  234. package/dist/src/components/datepicker/controllers/month-year-dropdown.controller.d.ts +48 -0
  235. package/dist/src/components/datepicker/controllers/month-year-dropdown.controller.js +92 -0
  236. package/dist/src/components/datepicker/controllers/positioning.controller.d.ts +82 -0
  237. package/dist/src/components/datepicker/controllers/positioning.controller.js +247 -0
  238. package/dist/src/components/datepicker/controllers/selection.controller.d.ts +92 -0
  239. package/dist/src/components/datepicker/controllers/selection.controller.js +267 -0
  240. package/dist/src/components/datepicker/interfaces/base-controller.interface.d.ts +40 -0
  241. package/dist/src/components/datepicker/interfaces/base-controller.interface.js +7 -0
  242. package/dist/src/components/datepicker/interfaces/datepicker-controllers.interface.d.ts +112 -0
  243. package/dist/src/components/datepicker/interfaces/datepicker-controllers.interface.js +7 -0
  244. package/dist/src/components/datepicker/interfaces/index.d.ts +8 -0
  245. package/dist/src/components/datepicker/interfaces/index.js +7 -0
  246. package/dist/src/components/datepicker/templates/days.template.d.ts +4 -0
  247. package/dist/src/components/datepicker/templates/days.template.js +40 -0
  248. package/dist/src/components/datepicker/templates/dropdown.template.d.ts +10 -0
  249. package/dist/src/components/datepicker/templates/dropdown.template.js +50 -0
  250. package/dist/src/components/datepicker/templates/headers.template.d.ts +2 -0
  251. package/dist/src/components/datepicker/templates/headers.template.js +5 -0
  252. package/dist/src/components/datepicker/templates/months.template.d.ts +6 -0
  253. package/dist/src/components/datepicker/templates/months.template.js +10 -0
  254. package/dist/src/components/datepicker/templates/years.template.d.ts +6 -0
  255. package/dist/src/components/datepicker/templates/years.template.js +11 -0
  256. package/dist/src/components/datepicker/test/datepicker_test.d.ts +2 -0
  257. package/dist/src/components/datepicker/test/datepicker_test.js +134 -0
  258. package/dist/src/components/datepicker/utils/day.helper.d.ts +5 -0
  259. package/dist/src/components/datepicker/utils/day.helper.js +53 -0
  260. package/dist/src/components/datepicker/utils/formatter.d.ts +2 -0
  261. package/dist/src/components/datepicker/utils/formatter.js +9 -0
  262. package/dist/src/components/datepicker/utils/index.d.ts +11 -0
  263. package/dist/src/components/datepicker/utils/index.js +11 -0
  264. package/dist/src/components/datepicker/utils/locale.helper.d.ts +144 -0
  265. package/dist/src/components/datepicker/utils/locale.helper.js +151 -0
  266. package/dist/src/components/datepicker/utils/month.helper.d.ts +3 -0
  267. package/dist/src/components/datepicker/utils/month.helper.js +24 -0
  268. package/dist/src/components/datepicker/utils/string.helper.d.ts +2 -0
  269. package/dist/src/components/datepicker/utils/string.helper.js +4 -0
  270. package/dist/src/components/document/demo/document-demo.d.ts +12 -0
  271. package/dist/src/components/document/demo/document-demo.js +40 -0
  272. package/dist/src/components/dropdown/controllers/base.controller.d.ts +18 -0
  273. package/dist/src/components/dropdown/controllers/base.controller.js +22 -0
  274. package/dist/src/components/dropdown/controllers/dropdown.controller.d.ts +50 -0
  275. package/dist/src/components/dropdown/controllers/dropdown.controller.js +408 -0
  276. package/dist/src/components/dropdown/controllers/index.d.ts +3 -0
  277. package/dist/src/components/dropdown/controllers/index.js +3 -0
  278. package/dist/src/components/dropdown/interfaces/controller-interfaces.d.ts +79 -0
  279. package/dist/src/components/dropdown/interfaces/controller-interfaces.js +2 -0
  280. package/dist/src/components/dropdown/interfaces/index.d.ts +2 -0
  281. package/dist/src/components/dropdown/interfaces/index.js +2 -0
  282. package/dist/src/components/dropdown/templates/nr-dropdown-item.d.ts +12 -0
  283. package/dist/src/components/dropdown/templates/nr-dropdown-item.js +55 -0
  284. package/dist/src/components/dropdown/templates/nr-dropdown-item.style.d.ts +2 -0
  285. package/dist/src/components/dropdown/templates/nr-dropdown-item.style.js +34 -0
  286. package/dist/src/components/dropdown/templates/nr-dropdown-menu.d.ts +18 -0
  287. package/dist/src/components/dropdown/templates/nr-dropdown-menu.js +70 -0
  288. package/dist/src/components/dropdown/templates/nr-dropdown-menu.style.d.ts +2 -0
  289. package/dist/src/components/dropdown/templates/nr-dropdown-menu.style.js +49 -0
  290. package/dist/src/components/file-upload/demo/file-upload-demo.d.ts +18 -0
  291. package/dist/src/components/file-upload/demo/file-upload-demo.js +156 -0
  292. package/dist/src/components/form/controllers/submission.controller.d.ts +60 -0
  293. package/dist/src/components/form/controllers/submission.controller.js +220 -0
  294. package/dist/src/components/form/controllers/validation.controller.d.ts +87 -0
  295. package/dist/src/components/form/controllers/validation.controller.js +236 -0
  296. package/dist/src/components/form/interfaces/validation.interface.d.ts +118 -0
  297. package/dist/src/components/form/interfaces/validation.interface.js +7 -0
  298. package/dist/src/components/icon/mixins/clickable-mixin.d.ts +57 -0
  299. package/dist/src/components/icon/mixins/clickable-mixin.js +111 -0
  300. package/dist/src/components/icon/mixins/index.d.ts +7 -0
  301. package/dist/src/components/icon/mixins/index.js +7 -0
  302. package/dist/src/components/iconpicker/controllers/event.controller.d.ts +38 -0
  303. package/dist/src/components/iconpicker/controllers/event.controller.js +68 -0
  304. package/dist/src/components/iconpicker/controllers/index.d.ts +9 -0
  305. package/dist/src/components/iconpicker/controllers/index.js +9 -0
  306. package/dist/src/components/iconpicker/controllers/search.controller.d.ts +34 -0
  307. package/dist/src/components/iconpicker/controllers/search.controller.js +55 -0
  308. package/dist/src/components/iconpicker/controllers/selection.controller.d.ts +27 -0
  309. package/dist/src/components/iconpicker/controllers/selection.controller.js +39 -0
  310. package/dist/src/components/iconpicker/interfaces/icon-picker.interface.d.ts +13 -0
  311. package/dist/src/components/iconpicker/interfaces/icon-picker.interface.js +7 -0
  312. package/dist/src/components/iconpicker/interfaces/index.d.ts +7 -0
  313. package/dist/src/components/iconpicker/interfaces/index.js +7 -0
  314. package/dist/src/components/iconpicker/utils/icon-filter.utils.d.ts +29 -0
  315. package/dist/src/components/iconpicker/utils/icon-filter.utils.js +96 -0
  316. package/dist/src/components/iconpicker/utils/icon-loader.utils.d.ts +39 -0
  317. package/dist/src/components/iconpicker/utils/icon-loader.utils.js +115 -0
  318. package/dist/src/components/iconpicker/utils/index.d.ts +8 -0
  319. package/dist/src/components/iconpicker/utils/index.js +8 -0
  320. package/dist/src/components/iconpicker/utils/lucide-icons.d.ts +10 -0
  321. package/dist/src/components/iconpicker/utils/lucide-icons.js +1624 -0
  322. package/dist/src/components/input/controllers/base.controller.d.ts +35 -0
  323. package/dist/src/components/input/controllers/base.controller.js +13 -0
  324. package/dist/src/components/input/controllers/event.controller.d.ts +111 -0
  325. package/dist/src/components/input/controllers/event.controller.js +355 -0
  326. package/dist/src/components/input/controllers/index.d.ts +14 -0
  327. package/dist/src/components/input/controllers/index.js +10 -0
  328. package/dist/src/components/input/controllers/state.controller.d.ts +153 -0
  329. package/dist/src/components/input/controllers/state.controller.js +245 -0
  330. package/dist/src/components/input/controllers/validation.controller.d.ts +205 -0
  331. package/dist/src/components/input/controllers/validation.controller.js +698 -0
  332. package/dist/src/components/input/mixins/focus-mixin.d.ts +60 -0
  333. package/dist/src/components/input/mixins/focus-mixin.js +65 -0
  334. package/dist/src/components/input/mixins/index.d.ts +12 -0
  335. package/dist/src/components/input/mixins/index.js +9 -0
  336. package/dist/src/components/input/mixins/number-mixin.d.ts +51 -0
  337. package/dist/src/components/input/mixins/number-mixin.js +128 -0
  338. package/dist/src/components/input/mixins/selection-mixin.d.ts +57 -0
  339. package/dist/src/components/input/mixins/selection-mixin.js +80 -0
  340. package/dist/src/components/input/test/nr-input_test.d.ts +2 -0
  341. package/dist/src/components/input/test/nr-input_test.js +159 -0
  342. package/dist/src/components/input/utils/index.d.ts +8 -0
  343. package/dist/src/components/input/utils/index.js +8 -0
  344. package/dist/src/components/input/utils/input-renderers.d.ts +54 -0
  345. package/dist/src/components/input/utils/input-renderers.js +178 -0
  346. package/dist/src/components/input/utils/input-validation.utils.d.ts +26 -0
  347. package/dist/src/components/input/utils/input-validation.utils.js +103 -0
  348. package/dist/src/components/menu/controllers/accessibility.controller.d.ts +86 -0
  349. package/dist/src/components/menu/controllers/accessibility.controller.js +235 -0
  350. package/dist/src/components/menu/controllers/base.controller.d.ts +41 -0
  351. package/dist/src/components/menu/controllers/base.controller.js +61 -0
  352. package/dist/src/components/menu/controllers/index.d.ts +10 -0
  353. package/dist/src/components/menu/controllers/index.js +10 -0
  354. package/dist/src/components/menu/controllers/keyboard.controller.d.ts +84 -0
  355. package/dist/src/components/menu/controllers/keyboard.controller.js +328 -0
  356. package/dist/src/components/menu/controllers/state.controller.d.ts +106 -0
  357. package/dist/src/components/menu/controllers/state.controller.js +249 -0
  358. package/dist/src/components/menu/interfaces/controller.interface.d.ts +51 -0
  359. package/dist/src/components/menu/interfaces/controller.interface.js +7 -0
  360. package/dist/src/components/menu/interfaces/index.d.ts +7 -0
  361. package/dist/src/components/menu/interfaces/index.js +7 -0
  362. package/dist/src/components/modal/controllers/index.d.ts +8 -0
  363. package/dist/src/components/modal/controllers/index.js +8 -0
  364. package/dist/src/components/modal/controllers/modal-drag-controller.d.ts +39 -0
  365. package/dist/src/components/modal/controllers/modal-drag-controller.js +108 -0
  366. package/dist/src/components/modal/controllers/modal-keyboard-controller.d.ts +36 -0
  367. package/dist/src/components/modal/controllers/modal-keyboard-controller.js +128 -0
  368. package/dist/src/components/panel/controllers/index.d.ts +8 -0
  369. package/dist/src/components/panel/controllers/index.js +8 -0
  370. package/dist/src/components/panel/controllers/panel-drag-controller.d.ts +40 -0
  371. package/dist/src/components/panel/controllers/panel-drag-controller.js +118 -0
  372. package/dist/src/components/panel/controllers/panel-resize-controller.d.ts +37 -0
  373. package/dist/src/components/panel/controllers/panel-resize-controller.js +124 -0
  374. package/dist/src/components/presence/bundle.js +528 -0
  375. package/dist/src/components/presence/bundle.js.gz +0 -0
  376. package/dist/src/components/presence/index.d.ts +10 -0
  377. package/dist/src/components/presence/index.js +10 -0
  378. package/dist/src/components/presence/presence-avatars.component.d.ts +40 -0
  379. package/dist/src/components/presence/presence-avatars.component.js +83 -0
  380. package/dist/src/components/presence/presence-avatars.style.d.ts +7 -0
  381. package/dist/src/components/presence/presence-avatars.style.js +105 -0
  382. package/dist/src/components/presence/presence-chat.component.d.ts +53 -0
  383. package/dist/src/components/presence/presence-chat.component.js +228 -0
  384. package/dist/src/components/presence/presence-chat.style.d.ts +7 -0
  385. package/dist/src/components/presence/presence-chat.style.js +248 -0
  386. package/dist/src/components/presence/presence.component.d.ts +71 -0
  387. package/dist/src/components/presence/presence.component.js +263 -0
  388. package/dist/src/components/presence/presence.style.d.ts +7 -0
  389. package/dist/src/components/presence/presence.style.js +12 -0
  390. package/dist/src/components/presence/presence.types.d.ts +31 -0
  391. package/dist/src/components/presence/presence.types.js +7 -0
  392. package/dist/src/components/presence/react.d.ts +24 -0
  393. package/dist/src/components/presence/react.js +41 -0
  394. package/dist/src/components/radio-group/controllers/focus.controller.d.ts +98 -0
  395. package/dist/src/components/radio-group/controllers/focus.controller.js +216 -0
  396. package/dist/src/components/radio-group/controllers/group.controller.d.ts +140 -0
  397. package/dist/src/components/radio-group/controllers/group.controller.js +179 -0
  398. package/dist/src/components/radio-group/controllers/index.d.ts +11 -0
  399. package/dist/src/components/radio-group/controllers/index.js +11 -0
  400. package/dist/src/components/radio-group/controllers/keyboard.controller.d.ts +24 -0
  401. package/dist/src/components/radio-group/controllers/keyboard.controller.js +93 -0
  402. package/dist/src/components/radio-group/controllers/ripple.controller.d.ts +59 -0
  403. package/dist/src/components/radio-group/controllers/ripple.controller.js +208 -0
  404. package/dist/src/components/radio-group/controllers/validation.controller.d.ts +73 -0
  405. package/dist/src/components/radio-group/controllers/validation.controller.js +108 -0
  406. package/dist/src/components/radio-group/interfaces/base-controller.interface.d.ts +75 -0
  407. package/dist/src/components/radio-group/interfaces/base-controller.interface.js +7 -0
  408. package/dist/src/components/radio-group/interfaces/focus-controller.interface.d.ts +40 -0
  409. package/dist/src/components/radio-group/interfaces/focus-controller.interface.js +7 -0
  410. package/dist/src/components/radio-group/interfaces/index.d.ts +11 -0
  411. package/dist/src/components/radio-group/interfaces/index.js +7 -0
  412. package/dist/src/components/radio-group/interfaces/ripple-controller.interface.d.ts +31 -0
  413. package/dist/src/components/radio-group/interfaces/ripple-controller.interface.js +7 -0
  414. package/dist/src/components/radio-group/interfaces/selection-controller.interface.d.ts +45 -0
  415. package/dist/src/components/radio-group/interfaces/selection-controller.interface.js +7 -0
  416. package/dist/src/components/radio-group/interfaces/validation-controller.interface.d.ts +48 -0
  417. package/dist/src/components/radio-group/interfaces/validation-controller.interface.js +7 -0
  418. package/dist/src/components/radio-group/test/radio_test.d.ts +2 -0
  419. package/dist/src/components/radio-group/test/radio_test.js +79 -0
  420. package/dist/src/components/select/controllers/base.controller.d.ts +10 -0
  421. package/dist/src/components/select/controllers/base.controller.js +8 -0
  422. package/dist/src/components/select/controllers/dropdown.controller.d.ts +76 -0
  423. package/dist/src/components/select/controllers/dropdown.controller.js +281 -0
  424. package/dist/src/components/select/controllers/event.controller.d.ts +54 -0
  425. package/dist/src/components/select/controllers/event.controller.js +113 -0
  426. package/dist/src/components/select/controllers/focus.controller.d.ts +79 -0
  427. package/dist/src/components/select/controllers/focus.controller.js +230 -0
  428. package/dist/src/components/select/controllers/index.d.ts +9 -0
  429. package/dist/src/components/select/controllers/index.js +9 -0
  430. package/dist/src/components/select/controllers/keyboard.controller.d.ts +75 -0
  431. package/dist/src/components/select/controllers/keyboard.controller.js +369 -0
  432. package/dist/src/components/select/controllers/search.controller.d.ts +71 -0
  433. package/dist/src/components/select/controllers/search.controller.js +167 -0
  434. package/dist/src/components/select/controllers/selection.controller.d.ts +67 -0
  435. package/dist/src/components/select/controllers/selection.controller.js +217 -0
  436. package/dist/src/components/select/controllers/validation.controller.d.ts +66 -0
  437. package/dist/src/components/select/controllers/validation.controller.js +189 -0
  438. package/dist/src/components/select/interfaces/base-controller.interface.d.ts +147 -0
  439. package/dist/src/components/select/interfaces/base-controller.interface.js +2 -0
  440. package/dist/src/components/select/interfaces/controller-interfaces.d.ts +94 -0
  441. package/dist/src/components/select/interfaces/controller-interfaces.js +11 -0
  442. package/dist/src/components/select/interfaces/index.d.ts +3 -0
  443. package/dist/src/components/select/interfaces/index.js +3 -0
  444. package/dist/src/components/slider-input/utils/debounce.d.ts +2 -0
  445. package/dist/src/components/slider-input/utils/debounce.js +8 -0
  446. package/dist/src/components/slider-input/utils/index.d.ts +2 -0
  447. package/dist/src/components/slider-input/utils/index.js +2 -0
  448. package/dist/src/components/table/controllers/base.controller.d.ts +15 -0
  449. package/dist/src/components/table/controllers/base.controller.js +13 -0
  450. package/dist/src/components/table/controllers/filter.controller.d.ts +48 -0
  451. package/dist/src/components/table/controllers/filter.controller.js +152 -0
  452. package/dist/src/components/table/controllers/index.d.ts +11 -0
  453. package/dist/src/components/table/controllers/index.js +11 -0
  454. package/dist/src/components/table/controllers/pagination.controller.d.ts +36 -0
  455. package/dist/src/components/table/controllers/pagination.controller.js +110 -0
  456. package/dist/src/components/table/controllers/selection.controller.d.ts +40 -0
  457. package/dist/src/components/table/controllers/selection.controller.js +120 -0
  458. package/dist/src/components/table/controllers/sort.controller.d.ts +32 -0
  459. package/dist/src/components/table/controllers/sort.controller.js +102 -0
  460. package/dist/src/components/table/interfaces/index.d.ts +7 -0
  461. package/dist/src/components/table/interfaces/index.js +7 -0
  462. package/dist/src/components/table/interfaces/table-host.interface.d.ts +48 -0
  463. package/dist/src/components/table/interfaces/table-host.interface.js +7 -0
  464. package/dist/src/components/table/templates/actions.template.d.ts +14 -0
  465. package/dist/src/components/table/templates/actions.template.js +15 -0
  466. package/dist/src/components/table/templates/column-filter.template.d.ts +24 -0
  467. package/dist/src/components/table/templates/column-filter.template.js +76 -0
  468. package/dist/src/components/table/templates/content.template.d.ts +37 -0
  469. package/dist/src/components/table/templates/content.template.js +208 -0
  470. package/dist/src/components/table/templates/empty.template.d.ts +8 -0
  471. package/dist/src/components/table/templates/empty.template.js +47 -0
  472. package/dist/src/components/table/templates/filter.template.d.ts +14 -0
  473. package/dist/src/components/table/templates/filter.template.js +28 -0
  474. package/dist/src/components/table/templates/index.d.ts +8 -0
  475. package/dist/src/components/table/templates/index.js +8 -0
  476. package/dist/src/components/table/templates/loading.template.d.ts +21 -0
  477. package/dist/src/components/table/templates/loading.template.js +51 -0
  478. package/dist/src/components/table/templates/pagination.template.d.ts +24 -0
  479. package/dist/src/components/table/templates/pagination.template.js +52 -0
  480. package/dist/src/components/tabs/controllers/base.controller.d.ts +49 -0
  481. package/dist/src/components/tabs/controllers/base.controller.js +26 -0
  482. package/dist/src/components/tabs/controllers/dragdrop.controller.d.ts +84 -0
  483. package/dist/src/components/tabs/controllers/dragdrop.controller.js +202 -0
  484. package/dist/src/components/tabs/controllers/editable.controller.d.ts +100 -0
  485. package/dist/src/components/tabs/controllers/editable.controller.js +242 -0
  486. package/dist/src/components/tabs/controllers/event.controller.d.ts +104 -0
  487. package/dist/src/components/tabs/controllers/event.controller.js +239 -0
  488. package/dist/src/components/tabs/controllers/index.d.ts +12 -0
  489. package/dist/src/components/tabs/controllers/index.js +18 -0
  490. package/dist/src/components/tabs/controllers/keyboard.controller.d.ts +85 -0
  491. package/dist/src/components/tabs/controllers/keyboard.controller.js +233 -0
  492. package/dist/src/components/tabs/controllers/popout.controller.d.ts +96 -0
  493. package/dist/src/components/tabs/controllers/popout.controller.js +441 -0
  494. package/dist/src/components/textarea/controllers/base.controller.d.ts +43 -0
  495. package/dist/src/components/textarea/controllers/base.controller.js +19 -0
  496. package/dist/src/components/textarea/controllers/event.controller.d.ts +169 -0
  497. package/dist/src/components/textarea/controllers/event.controller.js +408 -0
  498. package/dist/src/components/textarea/controllers/index.d.ts +9 -0
  499. package/dist/src/components/textarea/controllers/index.js +9 -0
  500. package/dist/src/components/textarea/controllers/validation.controller.d.ts +133 -0
  501. package/dist/src/components/textarea/controllers/validation.controller.js +315 -0
  502. package/dist/src/components/timepicker/controllers/formatting.controller.d.ts +93 -0
  503. package/dist/src/components/timepicker/controllers/formatting.controller.js +195 -0
  504. package/dist/src/components/timepicker/controllers/index.d.ts +9 -0
  505. package/dist/src/components/timepicker/controllers/index.js +9 -0
  506. package/dist/src/components/timepicker/controllers/selection.controller.d.ts +72 -0
  507. package/dist/src/components/timepicker/controllers/selection.controller.js +175 -0
  508. package/dist/src/components/timepicker/controllers/validation.controller.d.ts +88 -0
  509. package/dist/src/components/timepicker/controllers/validation.controller.js +200 -0
  510. package/dist/src/components/timepicker/interfaces/timepicker.interface.d.ts +103 -0
  511. package/dist/src/components/timepicker/interfaces/timepicker.interface.js +7 -0
  512. package/dist/src/components/timepicker/test/timepicker_test.d.ts +7 -0
  513. package/dist/src/components/timepicker/test/timepicker_test.js +218 -0
  514. package/dist/src/components/timepicker/utils/time.utils.d.ts +87 -0
  515. package/dist/src/components/timepicker/utils/time.utils.js +235 -0
  516. package/dist/src/components/toast/controllers/base.controller.d.ts +20 -0
  517. package/dist/src/components/toast/controllers/base.controller.js +12 -0
  518. package/dist/src/components/toast/controllers/index.d.ts +8 -0
  519. package/dist/src/components/toast/controllers/index.js +7 -0
  520. package/dist/src/components/tooltips/demo/tooltips-demo.d.ts +18 -0
  521. package/dist/src/components/tooltips/demo/tooltips-demo.js +132 -0
  522. package/dist/src/components/tooltips/test/tooltips_test.d.ts +2 -0
  523. package/dist/src/components/tooltips/test/tooltips_test.js +145 -0
  524. package/package.json +27 -1
  525. package/packages/common/dist/VERSIONS.md +1 -1
@@ -0,0 +1,931 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2024 Nuraly, Laabidi Aymen
4
+ * SPDX-License-Identifier: MIT
5
+ */
6
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
7
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
8
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
9
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
10
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
11
+ };
12
+ import { LitElement, html, nothing } from 'lit';
13
+ import { customElement, property } from 'lit/decorators.js';
14
+ import { map } from 'lit/directives/map.js';
15
+ import { classMap } from 'lit/directives/class-map.js';
16
+ import { dataNodeFieldStyles } from './data-node-fields.style.js';
17
+ import { NuralyUIBaseMixin } from '@nuralyui/common/mixins';
18
+ import { FilterOperator, FILTER_OPERATORS, DataOperation, DATA_OPERATIONS, } from './data-node.types.js';
19
+ /**
20
+ * Expression Input Component
21
+ * Text input with ${...} syntax highlighting support
22
+ */
23
+ let ExpressionInputComponent = class ExpressionInputComponent extends NuralyUIBaseMixin(LitElement) {
24
+ constructor() {
25
+ super(...arguments);
26
+ this.requiredComponents = ['nr-input'];
27
+ this.value = '';
28
+ this.placeholder = '';
29
+ this.disabled = false;
30
+ this.multiline = false;
31
+ this.label = '';
32
+ }
33
+ handleInput(e) {
34
+ this.value = e.detail.value;
35
+ this.dispatchEvent(new CustomEvent('value-change', {
36
+ detail: { value: this.value },
37
+ bubbles: true,
38
+ composed: true,
39
+ }));
40
+ }
41
+ render() {
42
+ return html `
43
+ <div class="expression-input">
44
+ ${this.label ? html `<label class="field-label">${this.label}</label>` : nothing}
45
+ ${this.multiline
46
+ ? html `
47
+ <nr-textarea
48
+ .value=${this.value}
49
+ placeholder=${this.placeholder}
50
+ ?disabled=${this.disabled}
51
+ @nr-input=${this.handleInput}
52
+ rows="3"
53
+ ></nr-textarea>
54
+ `
55
+ : html `
56
+ <nr-input
57
+ .value=${this.value}
58
+ placeholder=${this.placeholder}
59
+ ?disabled=${this.disabled}
60
+ @nr-input=${this.handleInput}
61
+ ></nr-input>
62
+ `}
63
+ </div>
64
+ `;
65
+ }
66
+ };
67
+ ExpressionInputComponent.useShadowDom = true;
68
+ ExpressionInputComponent.styles = dataNodeFieldStyles;
69
+ __decorate([
70
+ property({ type: String })
71
+ ], ExpressionInputComponent.prototype, "value", void 0);
72
+ __decorate([
73
+ property({ type: String })
74
+ ], ExpressionInputComponent.prototype, "placeholder", void 0);
75
+ __decorate([
76
+ property({ type: Boolean })
77
+ ], ExpressionInputComponent.prototype, "disabled", void 0);
78
+ __decorate([
79
+ property({ type: Boolean })
80
+ ], ExpressionInputComponent.prototype, "multiline", void 0);
81
+ __decorate([
82
+ property({ type: String })
83
+ ], ExpressionInputComponent.prototype, "label", void 0);
84
+ ExpressionInputComponent = __decorate([
85
+ customElement('nr-expression-input')
86
+ ], ExpressionInputComponent);
87
+ export { ExpressionInputComponent };
88
+ /**
89
+ * Variable Name Input Component
90
+ * Input for variable names with prefix display
91
+ */
92
+ let VariableNameInputComponent = class VariableNameInputComponent extends NuralyUIBaseMixin(LitElement) {
93
+ constructor() {
94
+ super(...arguments);
95
+ this.requiredComponents = ['nr-input'];
96
+ this.value = '';
97
+ this.placeholder = 'variableName';
98
+ this.prefix = '';
99
+ this.disabled = false;
100
+ this.label = '';
101
+ this.description = '';
102
+ }
103
+ handleInput(e) {
104
+ // Only allow valid variable names (alphanumeric and underscore)
105
+ const sanitized = e.detail.value.replaceAll(/[^a-zA-Z0-9_]/g, '');
106
+ this.value = sanitized;
107
+ this.dispatchEvent(new CustomEvent('value-change', {
108
+ detail: { value: this.value },
109
+ bubbles: true,
110
+ composed: true,
111
+ }));
112
+ }
113
+ render() {
114
+ return html `
115
+ <div class="field-container">
116
+ ${this.label ? html `<label class="field-label">${this.label}</label>` : nothing}
117
+ <div class="variable-name-input">
118
+ ${this.prefix ? html `<span class="variable-name-prefix">${this.prefix}</span>` : nothing}
119
+ <nr-input
120
+ .value=${this.value}
121
+ placeholder=${this.placeholder}
122
+ ?disabled=${this.disabled}
123
+ @nr-input=${this.handleInput}
124
+ ></nr-input>
125
+ </div>
126
+ ${this.description ? html `<span class="field-description">${this.description}</span>` : nothing}
127
+ </div>
128
+ `;
129
+ }
130
+ };
131
+ VariableNameInputComponent.useShadowDom = true;
132
+ VariableNameInputComponent.styles = dataNodeFieldStyles;
133
+ __decorate([
134
+ property({ type: String })
135
+ ], VariableNameInputComponent.prototype, "value", void 0);
136
+ __decorate([
137
+ property({ type: String })
138
+ ], VariableNameInputComponent.prototype, "placeholder", void 0);
139
+ __decorate([
140
+ property({ type: String })
141
+ ], VariableNameInputComponent.prototype, "prefix", void 0);
142
+ __decorate([
143
+ property({ type: Boolean })
144
+ ], VariableNameInputComponent.prototype, "disabled", void 0);
145
+ __decorate([
146
+ property({ type: String })
147
+ ], VariableNameInputComponent.prototype, "label", void 0);
148
+ __decorate([
149
+ property({ type: String })
150
+ ], VariableNameInputComponent.prototype, "description", void 0);
151
+ VariableNameInputComponent = __decorate([
152
+ customElement('nr-variable-name-input')
153
+ ], VariableNameInputComponent);
154
+ export { VariableNameInputComponent };
155
+ /**
156
+ * Operation Select Component
157
+ * Dropdown for selecting data operations with icons
158
+ */
159
+ let OperationSelectComponent = class OperationSelectComponent extends NuralyUIBaseMixin(LitElement) {
160
+ constructor() {
161
+ super(...arguments);
162
+ this.requiredComponents = ['nr-select'];
163
+ this.value = DataOperation.QUERY;
164
+ this.disabled = false;
165
+ this.label = '';
166
+ }
167
+ handleChange(e) {
168
+ this.value = e.detail.value;
169
+ this.dispatchEvent(new CustomEvent('value-change', {
170
+ detail: { value: this.value },
171
+ bubbles: true,
172
+ composed: true,
173
+ }));
174
+ }
175
+ render() {
176
+ const options = DATA_OPERATIONS.map(op => ({
177
+ value: op.value,
178
+ label: op.label,
179
+ description: op.description,
180
+ icon: op.icon,
181
+ }));
182
+ return html `
183
+ <div class="field-container">
184
+ ${this.label ? html `<label class="field-label">${this.label}</label>` : nothing}
185
+ <nr-select
186
+ .value=${this.value}
187
+ .options=${options}
188
+ ?disabled=${this.disabled}
189
+ @nr-change=${this.handleChange}
190
+ ></nr-select>
191
+ </div>
192
+ `;
193
+ }
194
+ };
195
+ OperationSelectComponent.useShadowDom = true;
196
+ OperationSelectComponent.styles = dataNodeFieldStyles;
197
+ __decorate([
198
+ property({ type: String })
199
+ ], OperationSelectComponent.prototype, "value", void 0);
200
+ __decorate([
201
+ property({ type: Boolean })
202
+ ], OperationSelectComponent.prototype, "disabled", void 0);
203
+ __decorate([
204
+ property({ type: String })
205
+ ], OperationSelectComponent.prototype, "label", void 0);
206
+ OperationSelectComponent = __decorate([
207
+ customElement('nr-operation-select')
208
+ ], OperationSelectComponent);
209
+ export { OperationSelectComponent };
210
+ /**
211
+ * DataSource Select Component
212
+ * Dropdown for selecting configured data sources
213
+ */
214
+ let DataSourceSelectComponent = class DataSourceSelectComponent extends NuralyUIBaseMixin(LitElement) {
215
+ constructor() {
216
+ super(...arguments);
217
+ this.requiredComponents = ['nr-select'];
218
+ this.value = null;
219
+ this.dataSources = [];
220
+ this.disabled = false;
221
+ this.placeholder = 'Select data source...';
222
+ this.label = '';
223
+ this.description = '';
224
+ }
225
+ handleChange(e) {
226
+ this.value = e.detail.value || null;
227
+ this.dispatchEvent(new CustomEvent('value-change', {
228
+ detail: { value: this.value },
229
+ bubbles: true,
230
+ composed: true,
231
+ }));
232
+ }
233
+ render() {
234
+ const options = this.dataSources.map(ds => ({
235
+ value: ds.id,
236
+ label: ds.name,
237
+ description: ds.type,
238
+ icon: ds.icon || 'database',
239
+ }));
240
+ return html `
241
+ <div class="field-container">
242
+ ${this.label ? html `<label class="field-label">${this.label}</label>` : nothing}
243
+ <nr-select
244
+ .value=${this.value || ''}
245
+ .options=${options}
246
+ placeholder=${this.placeholder}
247
+ ?disabled=${this.disabled}
248
+ @nr-change=${this.handleChange}
249
+ ></nr-select>
250
+ ${this.description ? html `<span class="field-description">${this.description}</span>` : nothing}
251
+ </div>
252
+ `;
253
+ }
254
+ };
255
+ DataSourceSelectComponent.useShadowDom = true;
256
+ DataSourceSelectComponent.styles = dataNodeFieldStyles;
257
+ __decorate([
258
+ property({ type: String })
259
+ ], DataSourceSelectComponent.prototype, "value", void 0);
260
+ __decorate([
261
+ property({ type: Array })
262
+ ], DataSourceSelectComponent.prototype, "dataSources", void 0);
263
+ __decorate([
264
+ property({ type: Boolean })
265
+ ], DataSourceSelectComponent.prototype, "disabled", void 0);
266
+ __decorate([
267
+ property({ type: String })
268
+ ], DataSourceSelectComponent.prototype, "placeholder", void 0);
269
+ __decorate([
270
+ property({ type: String })
271
+ ], DataSourceSelectComponent.prototype, "label", void 0);
272
+ __decorate([
273
+ property({ type: String })
274
+ ], DataSourceSelectComponent.prototype, "description", void 0);
275
+ DataSourceSelectComponent = __decorate([
276
+ customElement('nr-datasource-select')
277
+ ], DataSourceSelectComponent);
278
+ export { DataSourceSelectComponent };
279
+ /**
280
+ * Entity Select Component
281
+ * Dropdown for selecting tables/collections from a data source
282
+ */
283
+ let EntitySelectComponent = class EntitySelectComponent extends NuralyUIBaseMixin(LitElement) {
284
+ constructor() {
285
+ super(...arguments);
286
+ this.requiredComponents = ['nr-select'];
287
+ this.value = null;
288
+ this.entities = [];
289
+ this.disabled = false;
290
+ this.loading = false;
291
+ this.placeholder = 'Select table/collection...';
292
+ this.label = '';
293
+ this.description = '';
294
+ }
295
+ handleChange(e) {
296
+ this.value = e.detail.value || null;
297
+ this.dispatchEvent(new CustomEvent('value-change', {
298
+ detail: { value: this.value },
299
+ bubbles: true,
300
+ composed: true,
301
+ }));
302
+ }
303
+ render() {
304
+ const options = this.entities.map(entity => ({
305
+ value: entity.id,
306
+ label: entity.schema ? `${entity.schema}.${entity.name}` : entity.name,
307
+ description: entity.type,
308
+ icon: entity.type === 'collection' ? 'folder' : 'table',
309
+ }));
310
+ return html `
311
+ <div class="field-container">
312
+ ${this.label ? html `<label class="field-label">${this.label}</label>` : nothing}
313
+ <nr-select
314
+ .value=${this.value || ''}
315
+ .options=${options}
316
+ placeholder=${this.loading ? 'Loading...' : this.placeholder}
317
+ ?disabled=${this.disabled || this.loading}
318
+ searchable
319
+ @nr-change=${this.handleChange}
320
+ ></nr-select>
321
+ ${this.description ? html `<span class="field-description">${this.description}</span>` : nothing}
322
+ </div>
323
+ `;
324
+ }
325
+ };
326
+ EntitySelectComponent.useShadowDom = true;
327
+ EntitySelectComponent.styles = dataNodeFieldStyles;
328
+ __decorate([
329
+ property({ type: String })
330
+ ], EntitySelectComponent.prototype, "value", void 0);
331
+ __decorate([
332
+ property({ type: Array })
333
+ ], EntitySelectComponent.prototype, "entities", void 0);
334
+ __decorate([
335
+ property({ type: Boolean })
336
+ ], EntitySelectComponent.prototype, "disabled", void 0);
337
+ __decorate([
338
+ property({ type: Boolean })
339
+ ], EntitySelectComponent.prototype, "loading", void 0);
340
+ __decorate([
341
+ property({ type: String })
342
+ ], EntitySelectComponent.prototype, "placeholder", void 0);
343
+ __decorate([
344
+ property({ type: String })
345
+ ], EntitySelectComponent.prototype, "label", void 0);
346
+ __decorate([
347
+ property({ type: String })
348
+ ], EntitySelectComponent.prototype, "description", void 0);
349
+ EntitySelectComponent = __decorate([
350
+ customElement('nr-entity-select')
351
+ ], EntitySelectComponent);
352
+ export { EntitySelectComponent };
353
+ /**
354
+ * Field Select Component
355
+ * Dropdown for selecting a single field/column
356
+ */
357
+ let FieldSelectComponent = class FieldSelectComponent extends NuralyUIBaseMixin(LitElement) {
358
+ constructor() {
359
+ super(...arguments);
360
+ this.requiredComponents = ['nr-select'];
361
+ this.value = null;
362
+ this.fields = [];
363
+ this.disabled = false;
364
+ this.placeholder = 'Select field...';
365
+ }
366
+ handleChange(e) {
367
+ this.value = e.detail.value || null;
368
+ this.dispatchEvent(new CustomEvent('value-change', {
369
+ detail: { value: this.value },
370
+ bubbles: true,
371
+ composed: true,
372
+ }));
373
+ }
374
+ render() {
375
+ const options = this.fields.map(field => ({
376
+ value: field.name,
377
+ label: field.name,
378
+ description: field.type,
379
+ }));
380
+ return html `
381
+ <nr-select
382
+ .value=${this.value || ''}
383
+ .options=${options}
384
+ placeholder=${this.placeholder}
385
+ ?disabled=${this.disabled}
386
+ size="small"
387
+ @nr-change=${this.handleChange}
388
+ ></nr-select>
389
+ `;
390
+ }
391
+ };
392
+ FieldSelectComponent.useShadowDom = true;
393
+ FieldSelectComponent.styles = dataNodeFieldStyles;
394
+ __decorate([
395
+ property({ type: String })
396
+ ], FieldSelectComponent.prototype, "value", void 0);
397
+ __decorate([
398
+ property({ type: Array })
399
+ ], FieldSelectComponent.prototype, "fields", void 0);
400
+ __decorate([
401
+ property({ type: Boolean })
402
+ ], FieldSelectComponent.prototype, "disabled", void 0);
403
+ __decorate([
404
+ property({ type: String })
405
+ ], FieldSelectComponent.prototype, "placeholder", void 0);
406
+ FieldSelectComponent = __decorate([
407
+ customElement('nr-field-select')
408
+ ], FieldSelectComponent);
409
+ export { FieldSelectComponent };
410
+ /**
411
+ * Field Multi-Select Component
412
+ * Multi-select for choosing multiple fields
413
+ */
414
+ let FieldMultiSelectComponent = class FieldMultiSelectComponent extends NuralyUIBaseMixin(LitElement) {
415
+ constructor() {
416
+ super(...arguments);
417
+ this.requiredComponents = ['nr-select'];
418
+ this.value = [];
419
+ this.fields = [];
420
+ this.disabled = false;
421
+ this.placeholder = 'All fields';
422
+ this.label = '';
423
+ this.description = '';
424
+ }
425
+ handleChange(e) {
426
+ this.value = Array.isArray(e.detail.value) ? e.detail.value : [e.detail.value].filter(Boolean);
427
+ this.dispatchEvent(new CustomEvent('value-change', {
428
+ detail: { value: this.value },
429
+ bubbles: true,
430
+ composed: true,
431
+ }));
432
+ }
433
+ render() {
434
+ const options = this.fields.map(field => ({
435
+ value: field.name,
436
+ label: field.name,
437
+ description: field.type,
438
+ }));
439
+ return html `
440
+ <div class="field-container">
441
+ ${this.label ? html `<label class="field-label">${this.label}</label>` : nothing}
442
+ <nr-select
443
+ .value=${this.value}
444
+ .options=${options}
445
+ placeholder=${this.placeholder}
446
+ ?disabled=${this.disabled}
447
+ multiple
448
+ searchable
449
+ clearable
450
+ @nr-change=${this.handleChange}
451
+ ></nr-select>
452
+ ${this.description ? html `<span class="field-description">${this.description}</span>` : nothing}
453
+ </div>
454
+ `;
455
+ }
456
+ };
457
+ FieldMultiSelectComponent.useShadowDom = true;
458
+ FieldMultiSelectComponent.styles = dataNodeFieldStyles;
459
+ __decorate([
460
+ property({ type: Array })
461
+ ], FieldMultiSelectComponent.prototype, "value", void 0);
462
+ __decorate([
463
+ property({ type: Array })
464
+ ], FieldMultiSelectComponent.prototype, "fields", void 0);
465
+ __decorate([
466
+ property({ type: Boolean })
467
+ ], FieldMultiSelectComponent.prototype, "disabled", void 0);
468
+ __decorate([
469
+ property({ type: String })
470
+ ], FieldMultiSelectComponent.prototype, "placeholder", void 0);
471
+ __decorate([
472
+ property({ type: String })
473
+ ], FieldMultiSelectComponent.prototype, "label", void 0);
474
+ __decorate([
475
+ property({ type: String })
476
+ ], FieldMultiSelectComponent.prototype, "description", void 0);
477
+ FieldMultiSelectComponent = __decorate([
478
+ customElement('nr-field-multi-select')
479
+ ], FieldMultiSelectComponent);
480
+ export { FieldMultiSelectComponent };
481
+ /**
482
+ * Filter Builder Component
483
+ * Visual AND/OR filter tree builder
484
+ */
485
+ let FilterBuilderComponent = class FilterBuilderComponent extends NuralyUIBaseMixin(LitElement) {
486
+ constructor() {
487
+ super(...arguments);
488
+ this.requiredComponents = ['nr-select', 'nr-input', 'nr-icon'];
489
+ this.value = null;
490
+ this.fields = [];
491
+ this.disabled = false;
492
+ this.label = '';
493
+ this.description = '';
494
+ this.allowExpressions = true;
495
+ }
496
+ getEmptyGroup(logic = 'and') {
497
+ return { [logic]: [] };
498
+ }
499
+ getEmptyCondition() {
500
+ return { field: '', op: FilterOperator.EQUALS, value: '' };
501
+ }
502
+ updateValue(newValue) {
503
+ this.value = newValue;
504
+ this.dispatchEvent(new CustomEvent('value-change', {
505
+ detail: { value: this.value },
506
+ bubbles: true,
507
+ composed: true,
508
+ }));
509
+ }
510
+ toggleLogic(group) {
511
+ if (group.and) {
512
+ return { or: group.and };
513
+ }
514
+ else if (group.or) {
515
+ return { and: group.or };
516
+ }
517
+ return group;
518
+ }
519
+ addCondition() {
520
+ if (!this.value) {
521
+ this.updateValue({ and: [this.getEmptyCondition()] });
522
+ }
523
+ else {
524
+ const logic = this.value.and ? 'and' : 'or';
525
+ const conditions = this.value[logic] || [];
526
+ this.updateValue({
527
+ [logic]: [...conditions, this.getEmptyCondition()],
528
+ });
529
+ }
530
+ }
531
+ addGroup() {
532
+ if (!this.value) {
533
+ this.updateValue({ and: [this.getEmptyGroup('and')] });
534
+ }
535
+ else {
536
+ const logic = this.value.and ? 'and' : 'or';
537
+ const conditions = this.value[logic] || [];
538
+ this.updateValue({
539
+ [logic]: [...conditions, this.getEmptyGroup('and')],
540
+ });
541
+ }
542
+ }
543
+ removeCondition(index) {
544
+ if (!this.value)
545
+ return;
546
+ const logic = this.value.and ? 'and' : 'or';
547
+ const conditions = this.value[logic] || [];
548
+ const newConditions = conditions.filter((_, i) => i !== index);
549
+ if (newConditions.length === 0) {
550
+ this.updateValue(null);
551
+ }
552
+ else {
553
+ this.updateValue({ [logic]: newConditions });
554
+ }
555
+ }
556
+ updateCondition(index, updates) {
557
+ if (!this.value)
558
+ return;
559
+ const logic = this.value.and ? 'and' : 'or';
560
+ const conditions = [...(this.value[logic] || [])];
561
+ conditions[index] = Object.assign(Object.assign({}, conditions[index]), updates);
562
+ this.updateValue({ [logic]: conditions });
563
+ }
564
+ renderCondition(condition, index) {
565
+ const operator = FILTER_OPERATORS.find(op => op.value === condition.op);
566
+ const needsValue = (operator === null || operator === void 0 ? void 0 : operator.requiresValue) !== false;
567
+ const fieldOptions = this.fields.map(field => ({
568
+ value: field.name,
569
+ label: field.name,
570
+ }));
571
+ const operatorOptions = FILTER_OPERATORS.map(op => ({
572
+ value: op.value,
573
+ label: op.label,
574
+ }));
575
+ return html `
576
+ <div class="filter-condition">
577
+ <nr-select
578
+ .value=${condition.field}
579
+ .options=${fieldOptions}
580
+ placeholder="Select field..."
581
+ ?disabled=${this.disabled}
582
+ size="small"
583
+ @nr-change=${(e) => this.updateCondition(index, { field: e.detail.value })}
584
+ ></nr-select>
585
+ <nr-select
586
+ .value=${condition.op}
587
+ .options=${operatorOptions}
588
+ ?disabled=${this.disabled}
589
+ size="small"
590
+ @nr-change=${(e) => this.updateCondition(index, { op: e.detail.value })}
591
+ ></nr-select>
592
+ ${needsValue ? html `
593
+ <nr-input
594
+ .value=${String(condition.value || '')}
595
+ placeholder=${this.allowExpressions ? 'Value or ${expression}' : 'Value'}
596
+ ?disabled=${this.disabled}
597
+ size="small"
598
+ @nr-input=${(e) => this.updateCondition(index, { value: e.detail.value })}
599
+ ></nr-input>
600
+ ` : html `<div></div>`}
601
+ <button
602
+ class="filter-remove-btn"
603
+ ?disabled=${this.disabled}
604
+ @click=${() => this.removeCondition(index)}
605
+ >
606
+ <nr-icon name="x" size="small"></nr-icon>
607
+ </button>
608
+ </div>
609
+ `;
610
+ }
611
+ renderGroup(group) {
612
+ const logic = group.and ? 'and' : 'or';
613
+ const conditions = group[logic] || [];
614
+ return html `
615
+ <div class="filter-group">
616
+ <div class="filter-group-header">
617
+ <div class="filter-group-logic">
618
+ <button
619
+ class=${classMap({ active: logic === 'and' })}
620
+ ?disabled=${this.disabled}
621
+ @click=${() => this.updateValue(this.toggleLogic(group))}
622
+ >AND</button>
623
+ <button
624
+ class=${classMap({ active: logic === 'or' })}
625
+ ?disabled=${this.disabled}
626
+ @click=${() => this.updateValue(this.toggleLogic(group))}
627
+ >OR</button>
628
+ </div>
629
+ </div>
630
+ <div class="filter-conditions">
631
+ ${map(conditions, (item, index) => {
632
+ if ('and' in item || 'or' in item) {
633
+ return this.renderGroup(item);
634
+ }
635
+ return this.renderCondition(item, index);
636
+ })}
637
+ </div>
638
+ <div class="filter-actions">
639
+ <button class="filter-add-btn" ?disabled=${this.disabled} @click=${() => this.addCondition()}>
640
+ <nr-icon name="plus" size="small"></nr-icon>
641
+ Add condition
642
+ </button>
643
+ <button class="filter-add-btn" ?disabled=${this.disabled} @click=${() => this.addGroup()}>
644
+ <nr-icon name="folder-plus" size="small"></nr-icon>
645
+ Add group
646
+ </button>
647
+ </div>
648
+ </div>
649
+ `;
650
+ }
651
+ render() {
652
+ return html `
653
+ <div class="field-container">
654
+ ${this.label ? html `<label class="field-label">${this.label}</label>` : nothing}
655
+ <div class="filter-builder">
656
+ ${this.value
657
+ ? this.renderGroup(this.value)
658
+ : html `
659
+ <div class="empty-state">
660
+ <nr-icon name="filter" size="large"></nr-icon>
661
+ <span class="empty-state-text">No filter conditions</span>
662
+ <button class="filter-add-btn" ?disabled=${this.disabled} @click=${() => this.addCondition()}>
663
+ <nr-icon name="plus" size="small"></nr-icon>
664
+ Add condition
665
+ </button>
666
+ </div>
667
+ `}
668
+ </div>
669
+ ${this.description ? html `<span class="field-description">${this.description}</span>` : nothing}
670
+ </div>
671
+ `;
672
+ }
673
+ };
674
+ FilterBuilderComponent.useShadowDom = true;
675
+ FilterBuilderComponent.styles = dataNodeFieldStyles;
676
+ __decorate([
677
+ property({ type: Object })
678
+ ], FilterBuilderComponent.prototype, "value", void 0);
679
+ __decorate([
680
+ property({ type: Array })
681
+ ], FilterBuilderComponent.prototype, "fields", void 0);
682
+ __decorate([
683
+ property({ type: Boolean })
684
+ ], FilterBuilderComponent.prototype, "disabled", void 0);
685
+ __decorate([
686
+ property({ type: String })
687
+ ], FilterBuilderComponent.prototype, "label", void 0);
688
+ __decorate([
689
+ property({ type: String })
690
+ ], FilterBuilderComponent.prototype, "description", void 0);
691
+ __decorate([
692
+ property({ type: Boolean })
693
+ ], FilterBuilderComponent.prototype, "allowExpressions", void 0);
694
+ FilterBuilderComponent = __decorate([
695
+ customElement('nr-filter-builder')
696
+ ], FilterBuilderComponent);
697
+ export { FilterBuilderComponent };
698
+ /**
699
+ * Field Mapper Component
700
+ * Key-value mapper with expression support
701
+ */
702
+ let FieldMapperComponent = class FieldMapperComponent extends NuralyUIBaseMixin(LitElement) {
703
+ constructor() {
704
+ super(...arguments);
705
+ this.requiredComponents = ['nr-select', 'nr-input', 'nr-icon'];
706
+ this.value = {};
707
+ this.fields = [];
708
+ this.disabled = false;
709
+ this.label = '';
710
+ this.description = '';
711
+ this.allowExpressions = true;
712
+ }
713
+ updateValue(newValue) {
714
+ this.value = newValue;
715
+ this.dispatchEvent(new CustomEvent('value-change', {
716
+ detail: { value: this.value },
717
+ bubbles: true,
718
+ composed: true,
719
+ }));
720
+ }
721
+ addMapping() {
722
+ const usedFields = Object.keys(this.value);
723
+ const availableField = this.fields.find(f => !usedFields.includes(f.name));
724
+ if (availableField) {
725
+ this.updateValue(Object.assign(Object.assign({}, this.value), { [availableField.name]: '' }));
726
+ }
727
+ }
728
+ removeMapping(fieldName) {
729
+ const newValue = Object.assign({}, this.value);
730
+ delete newValue[fieldName];
731
+ this.updateValue(newValue);
732
+ }
733
+ updateMapping(oldKey, newKey, newVal) {
734
+ const newValue = Object.assign({}, this.value);
735
+ if (oldKey !== newKey) {
736
+ delete newValue[oldKey];
737
+ }
738
+ newValue[newKey] = newVal;
739
+ this.updateValue(newValue);
740
+ }
741
+ render() {
742
+ const mappings = Object.entries(this.value);
743
+ const fieldOptions = this.fields.map(f => ({
744
+ value: f.name,
745
+ label: f.name,
746
+ }));
747
+ return html `
748
+ <div class="field-container">
749
+ ${this.label ? html `<label class="field-label">${this.label}</label>` : nothing}
750
+ <div class="field-mapper">
751
+ <div class="field-mapper-header">
752
+ <span>Field</span>
753
+ <span>Value</span>
754
+ <span></span>
755
+ </div>
756
+ ${mappings.length === 0
757
+ ? html `
758
+ <div class="empty-state">
759
+ <nr-icon name="table" size="large"></nr-icon>
760
+ <span class="empty-state-text">No field mappings</span>
761
+ </div>
762
+ `
763
+ : map(mappings, ([field, val]) => html `
764
+ <div class="field-mapper-row">
765
+ <nr-select
766
+ .value=${field}
767
+ .options=${fieldOptions}
768
+ ?disabled=${this.disabled}
769
+ size="small"
770
+ @nr-change=${(e) => this.updateMapping(field, e.detail.value, val)}
771
+ ></nr-select>
772
+ <nr-input
773
+ .value=${String(val || '')}
774
+ placeholder=${this.allowExpressions ? 'Value or ${expression}' : 'Value'}
775
+ ?disabled=${this.disabled}
776
+ size="small"
777
+ @nr-input=${(e) => this.updateMapping(field, field, e.detail.value)}
778
+ ></nr-input>
779
+ <button
780
+ class="filter-remove-btn"
781
+ ?disabled=${this.disabled}
782
+ @click=${() => this.removeMapping(field)}
783
+ >
784
+ <nr-icon name="x" size="small"></nr-icon>
785
+ </button>
786
+ </div>
787
+ `)}
788
+ <button class="filter-add-btn" ?disabled=${this.disabled} @click=${() => this.addMapping()}>
789
+ <nr-icon name="plus" size="small"></nr-icon>
790
+ Add field mapping
791
+ </button>
792
+ </div>
793
+ ${this.description ? html `<span class="field-description">${this.description}</span>` : nothing}
794
+ </div>
795
+ `;
796
+ }
797
+ };
798
+ FieldMapperComponent.useShadowDom = true;
799
+ FieldMapperComponent.styles = dataNodeFieldStyles;
800
+ __decorate([
801
+ property({ type: Object })
802
+ ], FieldMapperComponent.prototype, "value", void 0);
803
+ __decorate([
804
+ property({ type: Array })
805
+ ], FieldMapperComponent.prototype, "fields", void 0);
806
+ __decorate([
807
+ property({ type: Boolean })
808
+ ], FieldMapperComponent.prototype, "disabled", void 0);
809
+ __decorate([
810
+ property({ type: String })
811
+ ], FieldMapperComponent.prototype, "label", void 0);
812
+ __decorate([
813
+ property({ type: String })
814
+ ], FieldMapperComponent.prototype, "description", void 0);
815
+ __decorate([
816
+ property({ type: Boolean })
817
+ ], FieldMapperComponent.prototype, "allowExpressions", void 0);
818
+ FieldMapperComponent = __decorate([
819
+ customElement('nr-field-mapper')
820
+ ], FieldMapperComponent);
821
+ export { FieldMapperComponent };
822
+ /**
823
+ * Sort Builder Component
824
+ * Sortable list of field + direction
825
+ */
826
+ let SortBuilderComponent = class SortBuilderComponent extends NuralyUIBaseMixin(LitElement) {
827
+ constructor() {
828
+ super(...arguments);
829
+ this.requiredComponents = ['nr-select', 'nr-icon'];
830
+ this.value = [];
831
+ this.fields = [];
832
+ this.disabled = false;
833
+ this.label = '';
834
+ }
835
+ updateValue(newValue) {
836
+ this.value = newValue;
837
+ this.dispatchEvent(new CustomEvent('value-change', {
838
+ detail: { value: this.value },
839
+ bubbles: true,
840
+ composed: true,
841
+ }));
842
+ }
843
+ addSort() {
844
+ const usedFields = this.value.map(s => s.field);
845
+ const availableField = this.fields.find(f => !usedFields.includes(f.name));
846
+ if (availableField) {
847
+ this.updateValue([...this.value, { field: availableField.name, dir: 'ASC' }]);
848
+ }
849
+ }
850
+ removeSort(index) {
851
+ this.updateValue(this.value.filter((_, i) => i !== index));
852
+ }
853
+ updateSort(index, updates) {
854
+ const newValue = [...this.value];
855
+ newValue[index] = Object.assign(Object.assign({}, newValue[index]), updates);
856
+ this.updateValue(newValue);
857
+ }
858
+ toggleDirection(index) {
859
+ const current = this.value[index].dir;
860
+ this.updateSort(index, { dir: current === 'ASC' ? 'DESC' : 'ASC' });
861
+ }
862
+ render() {
863
+ const fieldOptions = this.fields.map(f => ({
864
+ value: f.name,
865
+ label: f.name,
866
+ }));
867
+ return html `
868
+ <div class="field-container">
869
+ ${this.label ? html `<label class="field-label">${this.label}</label>` : nothing}
870
+ <div class="sort-builder">
871
+ ${this.value.length === 0
872
+ ? html `
873
+ <div class="empty-state">
874
+ <nr-icon name="arrow-up-down" size="large"></nr-icon>
875
+ <span class="empty-state-text">No sorting defined</span>
876
+ </div>
877
+ `
878
+ : map(this.value, (sort, index) => html `
879
+ <div class="sort-item">
880
+ <nr-select
881
+ .value=${sort.field}
882
+ .options=${fieldOptions}
883
+ ?disabled=${this.disabled}
884
+ size="small"
885
+ @nr-change=${(e) => this.updateSort(index, { field: e.detail.value })}
886
+ ></nr-select>
887
+ <button
888
+ class="sort-direction-btn ${sort.dir.toLowerCase()}"
889
+ ?disabled=${this.disabled}
890
+ @click=${() => this.toggleDirection(index)}
891
+ title=${sort.dir === 'ASC' ? 'Ascending' : 'Descending'}
892
+ >
893
+ <nr-icon name=${sort.dir === 'ASC' ? 'arrow-up' : 'arrow-down'} size="small"></nr-icon>
894
+ </button>
895
+ <button
896
+ class="filter-remove-btn"
897
+ ?disabled=${this.disabled}
898
+ @click=${() => this.removeSort(index)}
899
+ >
900
+ <nr-icon name="x" size="small"></nr-icon>
901
+ </button>
902
+ </div>
903
+ `)}
904
+ <button class="filter-add-btn" ?disabled=${this.disabled} @click=${() => this.addSort()}>
905
+ <nr-icon name="plus" size="small"></nr-icon>
906
+ Add sort
907
+ </button>
908
+ </div>
909
+ </div>
910
+ `;
911
+ }
912
+ };
913
+ SortBuilderComponent.useShadowDom = true;
914
+ SortBuilderComponent.styles = dataNodeFieldStyles;
915
+ __decorate([
916
+ property({ type: Array })
917
+ ], SortBuilderComponent.prototype, "value", void 0);
918
+ __decorate([
919
+ property({ type: Array })
920
+ ], SortBuilderComponent.prototype, "fields", void 0);
921
+ __decorate([
922
+ property({ type: Boolean })
923
+ ], SortBuilderComponent.prototype, "disabled", void 0);
924
+ __decorate([
925
+ property({ type: String })
926
+ ], SortBuilderComponent.prototype, "label", void 0);
927
+ SortBuilderComponent = __decorate([
928
+ customElement('nr-sort-builder')
929
+ ], SortBuilderComponent);
930
+ export { SortBuilderComponent };
931
+ //# sourceMappingURL=data-node-fields.component.js.map