@yuuvis/client-framework 2.20.1 → 3.0.0-beta.20.1

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 (379) hide show
  1. package/actions/index.d.ts +230 -9
  2. package/app-bar/index.d.ts +50 -1
  3. package/autocomplete/index.d.ts +89 -3
  4. package/breadcrumb/index.d.ts +112 -2
  5. package/clipboard/index.d.ts +19 -1
  6. package/common/index.d.ts +536 -7
  7. package/datepicker/index.d.ts +380 -6
  8. package/fesm2022/yuuvis-client-framework-actions.mjs +31 -32
  9. package/fesm2022/yuuvis-client-framework-actions.mjs.map +1 -1
  10. package/fesm2022/yuuvis-client-framework-app-bar.mjs +14 -17
  11. package/fesm2022/yuuvis-client-framework-app-bar.mjs.map +1 -1
  12. package/fesm2022/yuuvis-client-framework-autocomplete.mjs +23 -23
  13. package/fesm2022/yuuvis-client-framework-autocomplete.mjs.map +1 -1
  14. package/fesm2022/yuuvis-client-framework-breadcrumb.mjs +7 -8
  15. package/fesm2022/yuuvis-client-framework-breadcrumb.mjs.map +1 -1
  16. package/fesm2022/yuuvis-client-framework-clipboard.mjs +8 -10
  17. package/fesm2022/yuuvis-client-framework-clipboard.mjs.map +1 -1
  18. package/fesm2022/yuuvis-client-framework-common.mjs +191 -234
  19. package/fesm2022/yuuvis-client-framework-common.mjs.map +1 -1
  20. package/fesm2022/yuuvis-client-framework-datepicker.mjs +110 -145
  21. package/fesm2022/yuuvis-client-framework-datepicker.mjs.map +1 -1
  22. package/fesm2022/yuuvis-client-framework-forms.mjs +283 -250
  23. package/fesm2022/yuuvis-client-framework-forms.mjs.map +1 -1
  24. package/fesm2022/yuuvis-client-framework-icons.mjs +18 -19
  25. package/fesm2022/yuuvis-client-framework-icons.mjs.map +1 -1
  26. package/fesm2022/yuuvis-client-framework-list.mjs +59 -57
  27. package/fesm2022/yuuvis-client-framework-list.mjs.map +1 -1
  28. package/fesm2022/yuuvis-client-framework-master-details.mjs +23 -18
  29. package/fesm2022/yuuvis-client-framework-master-details.mjs.map +1 -1
  30. package/fesm2022/yuuvis-client-framework-metadata-form-defaults.mjs +7 -9
  31. package/fesm2022/yuuvis-client-framework-metadata-form-defaults.mjs.map +1 -1
  32. package/fesm2022/yuuvis-client-framework-metadata-form.mjs +32 -32
  33. package/fesm2022/yuuvis-client-framework-metadata-form.mjs.map +1 -1
  34. package/fesm2022/yuuvis-client-framework-object-details.mjs +129 -120
  35. package/fesm2022/yuuvis-client-framework-object-details.mjs.map +1 -1
  36. package/fesm2022/yuuvis-client-framework-object-flavor.mjs +67 -59
  37. package/fesm2022/yuuvis-client-framework-object-flavor.mjs.map +1 -1
  38. package/fesm2022/yuuvis-client-framework-object-form.mjs +58 -60
  39. package/fesm2022/yuuvis-client-framework-object-form.mjs.map +1 -1
  40. package/fesm2022/yuuvis-client-framework-object-preview.mjs +64 -47
  41. package/fesm2022/yuuvis-client-framework-object-preview.mjs.map +1 -1
  42. package/fesm2022/yuuvis-client-framework-object-relationship.mjs +206 -183
  43. package/fesm2022/yuuvis-client-framework-object-relationship.mjs.map +1 -1
  44. package/fesm2022/yuuvis-client-framework-object-summary.mjs +42 -42
  45. package/fesm2022/yuuvis-client-framework-object-summary.mjs.map +1 -1
  46. package/fesm2022/yuuvis-client-framework-object-versions.mjs +28 -29
  47. package/fesm2022/yuuvis-client-framework-object-versions.mjs.map +1 -1
  48. package/fesm2022/yuuvis-client-framework-overflow-hidden.mjs +10 -10
  49. package/fesm2022/yuuvis-client-framework-overflow-hidden.mjs.map +1 -1
  50. package/fesm2022/yuuvis-client-framework-overflow-menu.mjs +16 -16
  51. package/fesm2022/yuuvis-client-framework-overflow-menu.mjs.map +1 -1
  52. package/fesm2022/yuuvis-client-framework-pagination.mjs +7 -8
  53. package/fesm2022/yuuvis-client-framework-pagination.mjs.map +1 -1
  54. package/fesm2022/yuuvis-client-framework-popout.mjs +55 -57
  55. package/fesm2022/yuuvis-client-framework-popout.mjs.map +1 -1
  56. package/fesm2022/yuuvis-client-framework-query-list.mjs +29 -29
  57. package/fesm2022/yuuvis-client-framework-query-list.mjs.map +1 -1
  58. package/fesm2022/yuuvis-client-framework-renderer.mjs +71 -68
  59. package/fesm2022/yuuvis-client-framework-renderer.mjs.map +1 -1
  60. package/fesm2022/yuuvis-client-framework-sequence-list.mjs +20 -25
  61. package/fesm2022/yuuvis-client-framework-sequence-list.mjs.map +1 -1
  62. package/fesm2022/yuuvis-client-framework-simple-search.mjs +31 -33
  63. package/fesm2022/yuuvis-client-framework-simple-search.mjs.map +1 -1
  64. package/fesm2022/yuuvis-client-framework-sort.mjs +57 -37
  65. package/fesm2022/yuuvis-client-framework-sort.mjs.map +1 -1
  66. package/fesm2022/yuuvis-client-framework-split-view.mjs +39 -38
  67. package/fesm2022/yuuvis-client-framework-split-view.mjs.map +1 -1
  68. package/fesm2022/yuuvis-client-framework-tile-list.mjs +119 -121
  69. package/fesm2022/yuuvis-client-framework-tile-list.mjs.map +1 -1
  70. package/fesm2022/yuuvis-client-framework-token-search.mjs +22 -22
  71. package/fesm2022/yuuvis-client-framework-token-search.mjs.map +1 -1
  72. package/fesm2022/yuuvis-client-framework-tree.mjs +32 -44
  73. package/fesm2022/yuuvis-client-framework-tree.mjs.map +1 -1
  74. package/fesm2022/yuuvis-client-framework-upload-progress.mjs +22 -26
  75. package/fesm2022/yuuvis-client-framework-upload-progress.mjs.map +1 -1
  76. package/fesm2022/yuuvis-client-framework-widget-grid.mjs +80 -77
  77. package/fesm2022/yuuvis-client-framework-widget-grid.mjs.map +1 -1
  78. package/fesm2022/yuuvis-client-framework.mjs +23 -23
  79. package/fesm2022/yuuvis-client-framework.mjs.map +1 -1
  80. package/forms/index.d.ts +633 -13
  81. package/icons/index.d.ts +79 -4
  82. package/index.d.ts +909 -6
  83. package/list/index.d.ts +380 -4
  84. package/master-details/index.d.ts +69 -3
  85. package/metadata-form/index.d.ts +189 -6
  86. package/metadata-form-defaults/index.d.ts +14 -2
  87. package/object-details/index.d.ts +321 -9
  88. package/object-flavor/index.d.ts +86 -6
  89. package/object-form/index.d.ts +288 -4
  90. package/object-preview/index.d.ts +82 -2
  91. package/object-relationship/index.d.ts +120 -5
  92. package/object-summary/index.d.ts +105 -4
  93. package/object-versions/index.d.ts +43 -2
  94. package/overflow-hidden/index.d.ts +28 -2
  95. package/overflow-menu/index.d.ts +52 -3
  96. package/package.json +12 -12
  97. package/pagination/index.d.ts +31 -2
  98. package/popout/index.d.ts +106 -5
  99. package/query-list/index.d.ts +497 -2
  100. package/renderer/index.d.ts +117 -10
  101. package/sequence-list/index.d.ts +60 -2
  102. package/simple-search/index.d.ts +57 -1
  103. package/sort/index.d.ts +36 -2
  104. package/split-view/index.d.ts +197 -4
  105. package/tile-list/index.d.ts +789 -10
  106. package/token-search/index.d.ts +72 -3
  107. package/tree/index.d.ts +68 -2
  108. package/upload-progress/index.d.ts +44 -2
  109. package/widget-grid/index.d.ts +299 -7
  110. package/actions/lib/actions/copy-action/copy-action.d.ts +0 -17
  111. package/actions/lib/actions/cut-action/cut-action.d.ts +0 -17
  112. package/actions/lib/actions/delete-action/delete/delete.component.d.ts +0 -22
  113. package/actions/lib/actions/delete-action/delete-action.d.ts +0 -18
  114. package/actions/lib/actions/download-action/download-action.d.ts +0 -17
  115. package/actions/lib/actions.icon.d.ts +0 -7
  116. package/actions/lib/actions.interface.d.ts +0 -86
  117. package/actions/lib/actions.module.d.ts +0 -11
  118. package/actions/lib/actions.service.d.ts +0 -58
  119. package/actions/lib/components/contextmenu/contextmenu.component.d.ts +0 -16
  120. package/actions/lib/components/contextmenu/contextmenu.model.d.ts +0 -9
  121. package/actions/lib/components/contextmenu/contextmenuTrigger.directive.d.ts +0 -12
  122. package/app-bar/lib/app-bar.component.d.ts +0 -47
  123. package/autocomplete/lib/autocomplete.component.d.ts +0 -74
  124. package/autocomplete/lib/autocomplete.interface.d.ts +0 -4
  125. package/autocomplete/lib/autocomplete.module.d.ts +0 -7
  126. package/breadcrumb/lib/breadcrumb/breadcrumb.component.d.ts +0 -94
  127. package/breadcrumb/lib/models/breadcrumb-item.model.d.ts +0 -14
  128. package/breadcrumb/lib/models/index.d.ts +0 -1
  129. package/clipboard/lib/clipboard.component.d.ts +0 -16
  130. package/common/lib/common.module.d.ts +0 -21
  131. package/common/lib/common.utils.d.ts +0 -2
  132. package/common/lib/components/busy-overlay/busy-overlay.component.d.ts +0 -9
  133. package/common/lib/components/busy-overlay/busy-overlay.interface.d.ts +0 -4
  134. package/common/lib/components/confirm/confirm.component.d.ts +0 -8
  135. package/common/lib/components/confirm/confirm.interface.d.ts +0 -9
  136. package/common/lib/components/confirm/confirm.service.d.ts +0 -9
  137. package/common/lib/components/dialog/dialog.component.d.ts +0 -10
  138. package/common/lib/components/dialog/dialog.options.d.ts +0 -7
  139. package/common/lib/components/halo-focus/halo-focus.component.d.ts +0 -5
  140. package/common/lib/components/index.d.ts +0 -8
  141. package/common/lib/components/retention-badge/retention-badge.component.d.ts +0 -9
  142. package/common/lib/components/scroll-buttons/scroll-buttons.component.d.ts +0 -25
  143. package/common/lib/directives/autofocus-child.directive.d.ts +0 -13
  144. package/common/lib/directives/autofocus-delayed.directive.d.ts +0 -18
  145. package/common/lib/directives/busy-overlay.directive.d.ts +0 -68
  146. package/common/lib/directives/click-double.directive.d.ts +0 -17
  147. package/common/lib/directives/container-size.directive.d.ts +0 -30
  148. package/common/lib/directives/drag-scroll.directive.d.ts +0 -20
  149. package/common/lib/directives/drag-select.directive.d.ts +0 -21
  150. package/common/lib/directives/file-drop-zone/file-drop-zone.directive.d.ts +0 -17
  151. package/common/lib/directives/file-drop-zone/file-drop-zone.interface.d.ts +0 -5
  152. package/common/lib/directives/focus-within.directive.d.ts +0 -36
  153. package/common/lib/directives/index.d.ts +0 -13
  154. package/common/lib/directives/light-dismiss.directive.d.ts +0 -19
  155. package/common/lib/directives/longpress.directive.d.ts +0 -13
  156. package/common/lib/directives/noop-value-accessor.directive.d.ts +0 -10
  157. package/common/lib/directives/scroll-buttons.directive.d.ts +0 -20
  158. package/common/lib/mat-form-field.abstract.d.ts +0 -41
  159. package/common/lib/services/file-drop/file-drop.service.d.ts +0 -7
  160. package/common/lib/services/form-translate/form-translate.service.d.ts +0 -15
  161. package/common/lib/services/index.d.ts +0 -4
  162. package/common/lib/services/layout-settings/layout-settings.interface.d.ts +0 -1
  163. package/common/lib/services/layout-settings/layout-settings.service.d.ts +0 -40
  164. package/common/lib/services/theme/index.d.ts +0 -3
  165. package/common/lib/services/theme/theme.models.d.ts +0 -16
  166. package/common/lib/services/theme/theme.provider.d.ts +0 -4
  167. package/common/lib/services/theme/theme.service.d.ts +0 -16
  168. package/datepicker/lib/calendar/calendar.component.d.ts +0 -70
  169. package/datepicker/lib/date-input/date-input-element/date-input-element.component.d.ts +0 -44
  170. package/datepicker/lib/date-input/date-input-hour-element/date-input-hour-element.component.d.ts +0 -11
  171. package/datepicker/lib/date-input/date-input.component.d.ts +0 -60
  172. package/datepicker/lib/datepicker-calendar/datepicker-calendar-trigger.component.d.ts +0 -7
  173. package/datepicker/lib/datepicker-calendar/datepicker-calendar.component.d.ts +0 -12
  174. package/datepicker/lib/datepicker.component.d.ts +0 -80
  175. package/datepicker/lib/datepicker.interface.d.ts +0 -34
  176. package/datepicker/lib/datepicker.module.d.ts +0 -9
  177. package/datepicker/lib/datepicker.service.d.ts +0 -46
  178. package/datepicker/lib/datepicker.utils.d.ts +0 -23
  179. package/datepicker/lib/time-input/time-input.component.d.ts +0 -32
  180. package/datepicker/lib/time-input/time-input.interface.d.ts +0 -6
  181. package/forms/lib/elements/catalog/catalog.component.d.ts +0 -34
  182. package/forms/lib/elements/data-grid/data-grid/data-grid.component.d.ts +0 -46
  183. package/forms/lib/elements/data-grid/edit-table-data/edit-data.component.d.ts +0 -22
  184. package/forms/lib/elements/data-grid/model/data-grid.interface.d.ts +0 -20
  185. package/forms/lib/elements/datetime/datetime.component.d.ts +0 -41
  186. package/forms/lib/elements/datetime-range/datetime-range.component.d.ts +0 -38
  187. package/forms/lib/elements/i18n-catalog/i18n-catalog.component.d.ts +0 -43
  188. package/forms/lib/elements/index.d.ts +0 -12
  189. package/forms/lib/elements/number/number.component.d.ts +0 -69
  190. package/forms/lib/elements/number-range/number-range.component.d.ts +0 -73
  191. package/forms/lib/elements/organization/organization.component.d.ts +0 -66
  192. package/forms/lib/elements/organization-set/organization-set.component.d.ts +0 -61
  193. package/forms/lib/elements/range-select-date/date-range-picker/date-range-picker.component.d.ts +0 -13
  194. package/forms/lib/elements/range-select-date/range-select-date.component.d.ts +0 -38
  195. package/forms/lib/elements/range-select-date/range-select-date.interface.d.ts +0 -5
  196. package/forms/lib/elements/range-select-filesize/range-select-filesize.component.d.ts +0 -33
  197. package/forms/lib/elements/range-select-filesize/range-select-filesize.interface.d.ts +0 -5
  198. package/forms/lib/elements/string/string.component.d.ts +0 -100
  199. package/forms/lib/forms.module.d.ts +0 -17
  200. package/forms/lib/forms.utils.d.ts +0 -4
  201. package/icons/lib/icon.component.d.ts +0 -24
  202. package/icons/lib/icon.service.d.ts +0 -39
  203. package/icons/lib/icons.d.ts +0 -1
  204. package/icons/lib/object-type-icon/object-type-icon.component.d.ts +0 -11
  205. package/lib/config/halo-focus-defaults/halo-excluded-elements.const.d.ts +0 -26
  206. package/lib/config/halo-focus-defaults/halo-focus-navigation-keys.const.d.ts +0 -25
  207. package/lib/config/halo-focus-defaults/halo-focus-offset.const.d.ts +0 -25
  208. package/lib/config/halo-focus-defaults/halo-focus-styles.const.d.ts +0 -26
  209. package/lib/config/halo-focus-defaults/index.d.ts +0 -4
  210. package/lib/config/index.d.ts +0 -2
  211. package/lib/config/session/index.d.ts +0 -3
  212. package/lib/config/session/session-activity-window-before-end.const.d.ts +0 -43
  213. package/lib/config/session/session-default-duration.const.d.ts +0 -47
  214. package/lib/config/session/session-popup-before-end.const.d.ts +0 -47
  215. package/lib/enums/channel-message.enum.d.ts +0 -4
  216. package/lib/enums/index.d.ts +0 -1
  217. package/lib/models/halo-focus-config/halo-focus-config.model.d.ts +0 -48
  218. package/lib/models/halo-focus-config/index.d.ts +0 -1
  219. package/lib/models/index.d.ts +0 -3
  220. package/lib/models/session/channel-payload.model.d.ts +0 -5
  221. package/lib/models/session/index.d.ts +0 -1
  222. package/lib/models/snack-bar/index.d.ts +0 -3
  223. package/lib/models/snack-bar/snack-bar-data.model.d.ts +0 -6
  224. package/lib/models/snack-bar/snack-bar-level.model.d.ts +0 -1
  225. package/lib/models/snack-bar/snack-bar-options.model.d.ts +0 -9
  226. package/lib/providers/halo-focus/index.d.ts +0 -1
  227. package/lib/providers/halo-focus/provide-halo-focus.d.ts +0 -62
  228. package/lib/providers/index.d.ts +0 -2
  229. package/lib/providers/session/index.d.ts +0 -1
  230. package/lib/providers/session/provide-session.provider.d.ts +0 -43
  231. package/lib/services/halo-focus/halo-focus.service.d.ts +0 -95
  232. package/lib/services/halo-utility/halo-utility.service.d.ts +0 -245
  233. package/lib/services/index.d.ts +0 -4
  234. package/lib/services/session/session.service.d.ts +0 -113
  235. package/lib/services/snack-bar/snack-bar.service.d.ts +0 -22
  236. package/lib/yuuvis-client-framework.module.d.ts +0 -7
  237. package/list/lib/list-item.directive.d.ts +0 -40
  238. package/list/lib/list-tile/list-tile.component.d.ts +0 -14
  239. package/list/lib/list.component.d.ts +0 -320
  240. package/list/lib/list.module.d.ts +0 -9
  241. package/master-details/lib/master-details.component.d.ts +0 -52
  242. package/master-details/lib/master-details.interface.d.ts +0 -7
  243. package/master-details/lib/master-details.module.d.ts +0 -7
  244. package/metadata-form/lib/metadata-form-element-registry.service.d.ts +0 -60
  245. package/metadata-form/lib/metadata-form-field/metadata-form-field.component.d.ts +0 -25
  246. package/metadata-form/lib/metadata-form-field/metadata-form-field.interface.d.ts +0 -19
  247. package/metadata-form/lib/object-metadata-element-error.directive.d.ts +0 -17
  248. package/metadata-form/lib/object-metadata-element-label.directive.d.ts +0 -29
  249. package/metadata-form/lib/object-metadata-element-template.directive.d.ts +0 -45
  250. package/metadata-form-defaults/lib/metadata-default-templates/metadata-default-templates.component.d.ts +0 -5
  251. package/metadata-form-defaults/lib/metadata-form-defaults.module.d.ts +0 -7
  252. package/object-details/lib/object-audit/object-audit.component.d.ts +0 -49
  253. package/object-details/lib/object-details-header/object-details-header.component.d.ts +0 -43
  254. package/object-details/lib/object-details-shell/object-details-shell.component.d.ts +0 -34
  255. package/object-details/lib/object-details-shell/object-details-shell.service.d.ts +0 -14
  256. package/object-details/lib/object-details.component.d.ts +0 -47
  257. package/object-details/lib/object-details.module.d.ts +0 -12
  258. package/object-details/lib/object-metadata/form-section-group.pipe.d.ts +0 -8
  259. package/object-details/lib/object-metadata/object-metadata-section/object-metadata-section.component.d.ts +0 -19
  260. package/object-details/lib/object-metadata/object-metadata-section/object-metadata-section.interface.d.ts +0 -9
  261. package/object-details/lib/object-metadata/object-metadata.component.d.ts +0 -75
  262. package/object-details/lib/object-metadata/object-metadata.interface.d.ts +0 -26
  263. package/object-flavor/lib/abstract-apply-create-flavor/abstract-apply-create-flavor.component.d.ts +0 -11
  264. package/object-flavor/lib/abstract-apply-object-flavor/abstract-apply-object-flavor.component.d.ts +0 -13
  265. package/object-flavor/lib/default-apply-flavor/default-apply-flavor.component.d.ts +0 -19
  266. package/object-flavor/lib/flavor-chip/flavor-chip.component.d.ts +0 -13
  267. package/object-flavor/lib/object-flavor/object-flavor.component.d.ts +0 -23
  268. package/object-flavor/lib/object-flavor-picker/object-flavor-picker.component.d.ts +0 -10
  269. package/object-form/lib/form-scripting.api.interface.d.ts +0 -131
  270. package/object-form/lib/form-scripting.service.d.ts +0 -30
  271. package/object-form/lib/object-form-element/object-form-element.component.d.ts +0 -23
  272. package/object-form/lib/object-form-extension.interface.d.ts +0 -22
  273. package/object-form/lib/object-form-group/object-form-group.component.d.ts +0 -20
  274. package/object-form/lib/object-form-script/form-scripting-element-extension/form-scripting-element-extension.component.d.ts +0 -10
  275. package/object-form/lib/object-form-script/object-form-script.service.d.ts +0 -45
  276. package/object-form/lib/object-form-script/object-form-scripting-scope.d.ts +0 -50
  277. package/object-form/lib/object-form.component.d.ts +0 -61
  278. package/object-form/lib/object-form.interface.d.ts +0 -69
  279. package/object-form/lib/object-form.module.d.ts +0 -7
  280. package/object-form/lib/object-form.service.d.ts +0 -41
  281. package/object-form/lib/object-form.utils.d.ts +0 -20
  282. package/object-form/lib/object-form.validation.d.ts +0 -21
  283. package/object-preview/lib/components/index.d.ts +0 -2
  284. package/object-preview/lib/components/object-email-preview/object-email-preview.component.d.ts +0 -16
  285. package/object-preview/lib/components/object-preview/object-preview.component.d.ts +0 -24
  286. package/object-preview/lib/services/object-preview.service.d.ts +0 -40
  287. package/object-relationship/lib/actions/add-relationship/add-relationship.component.d.ts +0 -37
  288. package/object-relationship/lib/actions/relationship-target-search/relationship-target-search.component.d.ts +0 -36
  289. package/object-relationship/lib/node-summary/node-summary.component.d.ts +0 -26
  290. package/object-relationship/lib/object-relationship-graph/object-relationship-graph.component.d.ts +0 -30
  291. package/object-relationship/lib/object-relationship-list/object-relationship-list-item/object-relationship-list-item.component.d.ts +0 -14
  292. package/object-relationship/lib/object-relationship-list/object-relationship-list.component.d.ts +0 -13
  293. package/object-relationship/lib/object-relationship.component.d.ts +0 -28
  294. package/object-relationship/lib/object-relationship.const.d.ts +0 -10
  295. package/object-relationship/lib/object-relationship.interface.d.ts +0 -38
  296. package/object-relationship/lib/object-relationship.module.d.ts +0 -7
  297. package/object-relationship/lib/object-relationship.service.d.ts +0 -26
  298. package/object-summary/lib/multi-object-summary/multi-object-summary.component.d.ts +0 -7
  299. package/object-summary/lib/object-summary/object-summary.component.d.ts +0 -64
  300. package/object-summary/lib/object-summary-data/object-summary-data.component.d.ts +0 -28
  301. package/object-summary/lib/object-summary.module.d.ts +0 -9
  302. package/object-versions/lib/object-versions.component.d.ts +0 -34
  303. package/object-versions/lib/object-versions.module.d.ts +0 -7
  304. package/overflow-hidden/lib/overflow-hidden.component.d.ts +0 -19
  305. package/overflow-hidden/lib/overflow-hidden.module.d.ts +0 -7
  306. package/overflow-menu/lib/overflow-menu.component.d.ts +0 -33
  307. package/overflow-menu/lib/overflow-menu.interface.d.ts +0 -10
  308. package/overflow-menu/lib/overflow-menu.module.d.ts +0 -7
  309. package/pagination/lib/pagination.component.d.ts +0 -21
  310. package/pagination/lib/pagination.interface.d.ts +0 -5
  311. package/popout/lib/fullscreen.directive.d.ts +0 -4
  312. package/popout/lib/popout-trigger/popout-trigger.component.d.ts +0 -13
  313. package/popout/lib/popout.component.d.ts +0 -59
  314. package/popout/lib/popout.interface.d.ts +0 -24
  315. package/popout/lib/popout.module.d.ts +0 -9
  316. package/query-list/lib/query-list.component.d.ts +0 -488
  317. package/query-list/lib/query-list.module.d.ts +0 -7
  318. package/renderer/lib/property-renderer/abstract.renderer.d.ts +0 -14
  319. package/renderer/lib/property-renderer/boolean.renderer.component.d.ts +0 -6
  320. package/renderer/lib/property-renderer/datetime.renderer.d.ts +0 -6
  321. package/renderer/lib/property-renderer/decimal.renderer.component.d.ts +0 -6
  322. package/renderer/lib/property-renderer/filesize.renderer.component.d.ts +0 -7
  323. package/renderer/lib/property-renderer/icon.renderer.component.d.ts +0 -8
  324. package/renderer/lib/property-renderer/index.d.ts +0 -11
  325. package/renderer/lib/property-renderer/integer.renderer.component.d.ts +0 -6
  326. package/renderer/lib/property-renderer/organization.renderer.d.ts +0 -13
  327. package/renderer/lib/property-renderer/string.renderer.component.d.ts +0 -6
  328. package/renderer/lib/property-renderer/table.renderer.component.d.ts +0 -17
  329. package/renderer/lib/property-renderer/unknown.renderer.d.ts +0 -6
  330. package/renderer/lib/renderer.directive.d.ts +0 -13
  331. package/renderer/lib/services/renderer/renderer.interface.d.ts +0 -4
  332. package/renderer/lib/services/renderer/renderer.service.d.ts +0 -35
  333. package/sequence-list/lib/sequence-list.component.d.ts +0 -40
  334. package/sequence-list/lib/sequence-list.interface.d.ts +0 -17
  335. package/simple-search/lib/models/index.d.ts +0 -1
  336. package/simple-search/lib/models/object-type-aggregation.model.d.ts +0 -14
  337. package/simple-search/lib/simple-search/simple-search.component.d.ts +0 -40
  338. package/sort/lib/sort/models/index.d.ts +0 -1
  339. package/sort/lib/sort/models/sort.interface.d.ts +0 -7
  340. package/sort/lib/sort/sort.component.d.ts +0 -25
  341. package/split-view/lib/split-area-cover.directive.d.ts +0 -15
  342. package/split-view/lib/split-area.directive.d.ts +0 -21
  343. package/split-view/lib/split-view.component.d.ts +0 -159
  344. package/split-view/lib/split-view.interface.d.ts +0 -11
  345. package/split-view/lib/split-view.module.d.ts +0 -8
  346. package/tile-list/lib/tile-actions-menu/tile-actions-menu.component.d.ts +0 -11
  347. package/tile-list/lib/tile-config/action-select/action-select.component.d.ts +0 -13
  348. package/tile-list/lib/tile-config/icon-select/icon-select.component.d.ts +0 -11
  349. package/tile-list/lib/tile-config/property-select/property-select.component.d.ts +0 -26
  350. package/tile-list/lib/tile-config/tile-config-tile/tile-config-tile.component.d.ts +0 -20
  351. package/tile-list/lib/tile-config/tile-config-trigger/tile-config-trigger.component.d.ts +0 -17
  352. package/tile-list/lib/tile-config/tile-config.component.d.ts +0 -48
  353. package/tile-list/lib/tile-extension/directive/tile-extension.directive.d.ts +0 -11
  354. package/tile-list/lib/tile-extension/extensions/email.extension.d.ts +0 -10
  355. package/tile-list/lib/tile-extension/tile-extension.service.d.ts +0 -16
  356. package/tile-list/lib/tile-list/tile-list.component.d.ts +0 -637
  357. package/tile-list/lib/tile-list/tile-list.interface.d.ts +0 -18
  358. package/token-search/lib/token-search.component.d.ts +0 -35
  359. package/token-search/lib/token-search.interface.d.ts +0 -27
  360. package/token-search/lib/token-search.module.d.ts +0 -7
  361. package/tree/lib/tree-node/tree-node.component.d.ts +0 -21
  362. package/tree/lib/tree.component.d.ts +0 -53
  363. package/tree/lib/tree.interface.d.ts +0 -11
  364. package/tree/lib/tree.service.d.ts +0 -35
  365. package/upload-progress/lib/upload-progress/upload-progress-overlay/upload-progress-overlay.component.d.ts +0 -12
  366. package/upload-progress/lib/upload-progress/upload-progress.component.d.ts +0 -33
  367. package/upload-progress/lib/upload-progress/upload-progress.module.d.ts +0 -7
  368. package/widget-grid/lib/widget-grid-event.service.d.ts +0 -10
  369. package/widget-grid/lib/widget-grid-registry.service.d.ts +0 -81
  370. package/widget-grid/lib/widget-grid-workspaces/widget-grid-workspaces.component.d.ts +0 -53
  371. package/widget-grid/lib/widget-grid-workspaces/widget-grid-workspaces.interface.d.ts +0 -17
  372. package/widget-grid/lib/widget-grid-workspaces/workspace-edit/workspace-edit.component.d.ts +0 -10
  373. package/widget-grid/lib/widget-grid.component.d.ts +0 -52
  374. package/widget-grid/lib/widget-grid.interface.d.ts +0 -51
  375. package/widget-grid/lib/widget-grid.module.d.ts +0 -8
  376. package/widget-grid/lib/widget-grid.service.d.ts +0 -45
  377. package/widget-grid/lib/widget-grid.utils.d.ts +0 -18
  378. package/widget-grid/lib/widget-picker/widget-picker.component.d.ts +0 -38
  379. package/widget-grid/lib/widgets/noop/noop.component.d.ts +0 -7
@@ -154,24 +154,24 @@ class TokenSearchComponent {
154
154
  constructor() {
155
155
  this.#system = inject(SystemService);
156
156
  this.#host = inject((ElementRef));
157
- this.types = input([]);
157
+ this.types = input([], ...(ngDevMode ? [{ debugName: "types" }] : []));
158
158
  this.queryChange = output();
159
159
  // ── Single input control ─────────────────────────────────────────────────
160
160
  this.searchCtrl = new FormControl('');
161
- this.searchInput = viewChild('searchInput');
161
+ this.searchInput = viewChild('searchInput', ...(ngDevMode ? [{ debugName: "searchInput" }] : []));
162
162
  // ── State ────────────────────────────────────────────────────────────────
163
- this.tokens = signal([]);
164
- this.step = signal('type');
165
- this.inputTerm = signal('');
163
+ this.tokens = signal([], ...(ngDevMode ? [{ debugName: "tokens" }] : []));
164
+ this.step = signal('type', ...(ngDevMode ? [{ debugName: "step" }] : []));
165
+ this.inputTerm = signal('', ...(ngDevMode ? [{ debugName: "inputTerm" }] : []));
166
166
  /** Pending state for the group currently being built (not yet committed) */
167
- this.pendingTypeId = signal(null);
168
- this.pendingTypeLabel = signal('');
169
- this.pendingTypeIsSot = signal(false);
170
- this.pendingField = signal(null);
171
- this.pendingOperator = signal(null);
167
+ this.pendingTypeId = signal(null, ...(ngDevMode ? [{ debugName: "pendingTypeId" }] : []));
168
+ this.pendingTypeLabel = signal('', ...(ngDevMode ? [{ debugName: "pendingTypeLabel" }] : []));
169
+ this.pendingTypeIsSot = signal(false, ...(ngDevMode ? [{ debugName: "pendingTypeIsSot" }] : []));
170
+ this.pendingField = signal(null, ...(ngDevMode ? [{ debugName: "pendingField" }] : []));
171
+ this.pendingOperator = signal(null, ...(ngDevMode ? [{ debugName: "pendingOperator" }] : []));
172
172
  // ── Computed ─────────────────────────────────────────────────────────────
173
- this.objectTypes = computed(() => this.#system.getObjectTypes(true, 'search').filter((t) => this.types().includes(t.id)));
174
- this.placeholderText = computed(() => PLACEHOLDER[this.step()]);
173
+ this.objectTypes = computed(() => this.#system.getObjectTypes(true, 'search').filter((t) => this.types().includes(t.id)), ...(ngDevMode ? [{ debugName: "objectTypes" }] : []));
174
+ this.placeholderText = computed(() => PLACEHOLDER[this.step()], ...(ngDevMode ? [{ debugName: "placeholderText" }] : []));
175
175
  this.suggestions = computed(() => {
176
176
  const step = this.step();
177
177
  const term = this.inputTerm().toLowerCase();
@@ -199,8 +199,8 @@ class TokenSearchComponent {
199
199
  return field ? this.#operatorsForFieldType(field.fieldType ?? 'string') : [];
200
200
  }
201
201
  return [];
202
- });
203
- this.cmisQuery = computed(() => buildCmisFromTokens(this.tokens()));
202
+ }, ...(ngDevMode ? [{ debugName: "suggestions" }] : []));
203
+ this.cmisQuery = computed(() => buildCmisFromTokens(this.tokens()), ...(ngDevMode ? [{ debugName: "cmisQuery" }] : []));
204
204
  // ── Display function for autocomplete ────────────────────────────────────
205
205
  this.displayFn = () => '';
206
206
  this.searchCtrl.valueChanges
@@ -468,10 +468,10 @@ class TokenSearchComponent {
468
468
  return base(['contains', 'like', 'eq']);
469
469
  }
470
470
  }
471
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.20", ngImport: i0, type: TokenSearchComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
472
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.20", type: TokenSearchComponent, isStandalone: true, selector: "yuv-token-search", inputs: { types: { classPropertyName: "types", publicName: "types", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { queryChange: "queryChange" }, viewQueries: [{ propertyName: "searchInput", first: true, predicate: ["searchInput"], descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"search-bar\" (click)=\"onBarClick($event)\">\n <!-- Committed tokens -->\n @for (token of tokens(); track token.uid; let i = $index) {\n <button\n class=\"token\"\n [class.token--type]=\"token.kind === 'type'\"\n [class.token--field]=\"token.kind === 'field'\"\n [class.token--operator]=\"token.kind === 'operator'\"\n [class.token--value]=\"token.kind === 'value'\"\n [class.token--combinator]=\"token.kind === 'combinator'\"\n (click)=\"onTokenClick(i)\"\n [attr.aria-label]=\"token.label\"\n >\n @if (token.kind === 'type') {\n <mat-icon class=\"token__icon\">category</mat-icon>\n }\n @if (token.kind === 'field') {\n <mat-icon class=\"token__icon\">tune</mat-icon>\n }\n <span class=\"token__label\">{{ token.label }}</span>\n @if (token.kind !== 'combinator') {\n <span\n class=\"token__remove\"\n (click)=\"$event.stopPropagation(); removeTokenGroup(i)\"\n matTooltip=\"Remove\"\n >\n <mat-icon>close</mat-icon>\n </span>\n }\n </button>\n }\n\n <!-- Pending type pill -->\n @if (pendingTypeId()) {\n <span class=\"token token--type token--pending\">\n <mat-icon class=\"token__icon\">category</mat-icon>\n <span class=\"token__label\">{{ pendingTypeLabel() }}</span>\n </span>\n }\n\n <!-- Pending field pill -->\n @if (pendingField(); as field) {\n <span class=\"token token--field token--pending\">\n <mat-icon class=\"token__icon\">tune</mat-icon>\n <span class=\"token__label\">{{ field.label }}</span>\n </span>\n }\n\n <!-- Pending operator pill -->\n @if (pendingOperator(); as op) {\n <span class=\"token token--operator token--pending\">\n <span class=\"token__label\">{{ op.label }}</span>\n </span>\n }\n\n <!-- Single input -->\n <input\n #searchInput\n [formControl]=\"searchCtrl\"\n [matAutocomplete]=\"auto\"\n [placeholder]=\"placeholderText()\"\n (keydown)=\"onKeydown($event)\"\n />\n</div>\n\n<!-- Autocomplete panel -->\n<mat-autocomplete #auto [displayWith]=\"displayFn\" (optionSelected)=\"onSuggestionSelected($event)\">\n @for (s of suggestions(); track s.id) {\n <mat-option [value]=\"s\">\n <div class=\"suggestion\">\n <mat-icon class=\"suggestion__icon\">\n @switch (s.kind) {\n @case ('type') { category }\n @case ('field') { tune }\n @case ('date-preset') { calendar_today }\n @default { manage_search }\n }\n </mat-icon>\n <span class=\"suggestion__label\">{{ s.label }}</span>\n @if (s.fieldType) {\n <span class=\"suggestion__type\">{{ s.fieldType }}</span>\n }\n </div>\n </mat-option>\n }\n</mat-autocomplete>\n", styles: [":host{display:block}.search-bar{display:flex;flex-wrap:wrap;align-items:center;gap:var(--ymt-spacing-3xs);padding:var(--ymt-spacing-2xs) var(--ymt-spacing-s);border:1px solid var(--ymt-outline-variant);border-radius:var(--ymt-corner-l);background:var(--ymt-surface);min-height:44px;cursor:text;transition:border-color .15s}.search-bar:focus-within{border-color:var(--ymt-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--ymt-primary) 15%,transparent)}.search-bar input{flex:1 1 120px;min-width:120px;border:none;outline:none;background:transparent;font:inherit;font-size:.9em;padding:var(--ymt-spacing-2xs) 0}.search-bar input::placeholder{color:var(--ymt-text-color-subtle);opacity:.7}.token{display:inline-flex;align-items:center;gap:var(--ymt-spacing-4xs);height:28px;padding:0 var(--ymt-spacing-xs);border-radius:var(--ymt-corner-s);border:1px solid var(--ymt-outline-variant);background:var(--ymt-surface-container);font:inherit;font-size:.82em;cursor:pointer;white-space:nowrap;outline:none;transition:border-color .15s,background .15s}.token:hover{border-color:var(--ymt-outline)}.token:focus-visible{border-color:var(--ymt-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--ymt-primary) 25%,transparent)}.token--type{background:var(--ymt-primary-container);color:var(--ymt-on-primary-container);font-weight:500}.token--field{background:color-mix(in srgb,var(--ymt-primary) 10%,transparent);color:var(--ymt-primary);font-weight:500}.token--operator{background:var(--ymt-surface-container-high);color:var(--ymt-text-color-subtle);font-style:italic}.token--value{max-width:160px;overflow:hidden;text-overflow:ellipsis}.token--combinator{background:var(--ymt-surface-container-high);font-weight:600;font-size:.75em;letter-spacing:.04em;color:var(--ymt-text-color-subtle);border-color:transparent}.token--pending{opacity:.7;border-style:dashed;cursor:default}.token__icon{font-size:var(--ymt-sizing-xs);width:var(--ymt-sizing-xs);height:var(--ymt-sizing-xs);opacity:.8}.token__label{line-height:1}.token__remove{display:inline-flex;align-items:center;margin-left:var(--ymt-spacing-4xs);opacity:0;transition:opacity .1s,color .1s}.token__remove mat-icon{font-size:14px;width:14px;height:14px}.token:hover .token__remove{opacity:.6}.token__remove:hover{opacity:1;color:var(--ymt-error)}.suggestion{display:flex;align-items:center;gap:var(--ymt-spacing-xs)}.suggestion__icon{font-size:var(--ymt-sizing-s);width:var(--ymt-sizing-s);height:var(--ymt-sizing-s);opacity:.6}.suggestion__label{flex:1}.suggestion__type{font-size:.75em;opacity:.5;font-style:italic}\n"], dependencies: [{ kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatAutocompleteModule }, { kind: "component", type: i2.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i2.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i2.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
471
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: TokenSearchComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
472
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.19", type: TokenSearchComponent, isStandalone: true, selector: "yuv-token-search", inputs: { types: { classPropertyName: "types", publicName: "types", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { queryChange: "queryChange" }, viewQueries: [{ propertyName: "searchInput", first: true, predicate: ["searchInput"], descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"search-bar\" (click)=\"onBarClick($event)\">\n <!-- Committed tokens -->\n @for (token of tokens(); track token.uid; let i = $index) {\n <button\n class=\"token\"\n [class.token--type]=\"token.kind === 'type'\"\n [class.token--field]=\"token.kind === 'field'\"\n [class.token--operator]=\"token.kind === 'operator'\"\n [class.token--value]=\"token.kind === 'value'\"\n [class.token--combinator]=\"token.kind === 'combinator'\"\n (click)=\"onTokenClick(i)\"\n [attr.aria-label]=\"token.label\"\n >\n @if (token.kind === 'type') {\n <mat-icon class=\"token__icon\">category</mat-icon>\n }\n @if (token.kind === 'field') {\n <mat-icon class=\"token__icon\">tune</mat-icon>\n }\n <span class=\"token__label\">{{ token.label }}</span>\n @if (token.kind !== 'combinator') {\n <span\n class=\"token__remove\"\n (click)=\"$event.stopPropagation(); removeTokenGroup(i)\"\n matTooltip=\"Remove\"\n >\n <mat-icon>close</mat-icon>\n </span>\n }\n </button>\n }\n\n <!-- Pending type pill -->\n @if (pendingTypeId()) {\n <span class=\"token token--type token--pending\">\n <mat-icon class=\"token__icon\">category</mat-icon>\n <span class=\"token__label\">{{ pendingTypeLabel() }}</span>\n </span>\n }\n\n <!-- Pending field pill -->\n @if (pendingField(); as field) {\n <span class=\"token token--field token--pending\">\n <mat-icon class=\"token__icon\">tune</mat-icon>\n <span class=\"token__label\">{{ field.label }}</span>\n </span>\n }\n\n <!-- Pending operator pill -->\n @if (pendingOperator(); as op) {\n <span class=\"token token--operator token--pending\">\n <span class=\"token__label\">{{ op.label }}</span>\n </span>\n }\n\n <!-- Single input -->\n <input\n #searchInput\n [formControl]=\"searchCtrl\"\n [matAutocomplete]=\"auto\"\n [placeholder]=\"placeholderText()\"\n (keydown)=\"onKeydown($event)\"\n />\n</div>\n\n<!-- Autocomplete panel -->\n<mat-autocomplete #auto [displayWith]=\"displayFn\" (optionSelected)=\"onSuggestionSelected($event)\">\n @for (s of suggestions(); track s.id) {\n <mat-option [value]=\"s\">\n <div class=\"suggestion\">\n <mat-icon class=\"suggestion__icon\">\n @switch (s.kind) {\n @case ('type') { category }\n @case ('field') { tune }\n @case ('date-preset') { calendar_today }\n @default { manage_search }\n }\n </mat-icon>\n <span class=\"suggestion__label\">{{ s.label }}</span>\n @if (s.fieldType) {\n <span class=\"suggestion__type\">{{ s.fieldType }}</span>\n }\n </div>\n </mat-option>\n }\n</mat-autocomplete>\n", styles: [":host{display:block}.search-bar{display:flex;flex-wrap:wrap;align-items:center;gap:var(--ymt-spacing-3xs);padding:var(--ymt-spacing-2xs) var(--ymt-spacing-s);border:1px solid var(--ymt-outline-variant);border-radius:var(--ymt-corner-l);background:var(--ymt-surface);min-height:44px;cursor:text;transition:border-color .15s}.search-bar:focus-within{border-color:var(--ymt-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--ymt-primary) 15%,transparent)}.search-bar input{flex:1 1 120px;min-width:120px;border:none;outline:none;background:transparent;font:inherit;font-size:.9em;padding:var(--ymt-spacing-2xs) 0}.search-bar input::placeholder{color:var(--ymt-text-color-subtle);opacity:.7}.token{display:inline-flex;align-items:center;gap:var(--ymt-spacing-4xs);height:28px;padding:0 var(--ymt-spacing-xs);border-radius:var(--ymt-corner-s);border:1px solid var(--ymt-outline-variant);background:var(--ymt-surface-container);font:inherit;font-size:.82em;cursor:pointer;white-space:nowrap;outline:none;transition:border-color .15s,background .15s}.token:hover{border-color:var(--ymt-outline)}.token:focus-visible{border-color:var(--ymt-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--ymt-primary) 25%,transparent)}.token--type{background:var(--ymt-primary-container);color:var(--ymt-on-primary-container);font-weight:500}.token--field{background:color-mix(in srgb,var(--ymt-primary) 10%,transparent);color:var(--ymt-primary);font-weight:500}.token--operator{background:var(--ymt-surface-container-high);color:var(--ymt-text-color-subtle);font-style:italic}.token--value{max-width:160px;overflow:hidden;text-overflow:ellipsis}.token--combinator{background:var(--ymt-surface-container-high);font-weight:600;font-size:.75em;letter-spacing:.04em;color:var(--ymt-text-color-subtle);border-color:transparent}.token--pending{opacity:.7;border-style:dashed;cursor:default}.token__icon{font-size:var(--ymt-sizing-xs);width:var(--ymt-sizing-xs);height:var(--ymt-sizing-xs);opacity:.8}.token__label{line-height:1}.token__remove{display:inline-flex;align-items:center;margin-left:var(--ymt-spacing-4xs);opacity:0;transition:opacity .1s,color .1s}.token__remove mat-icon{font-size:14px;width:14px;height:14px}.token:hover .token__remove{opacity:.6}.token__remove:hover{opacity:1;color:var(--ymt-error)}.suggestion{display:flex;align-items:center;gap:var(--ymt-spacing-xs)}.suggestion__icon{font-size:var(--ymt-sizing-s);width:var(--ymt-sizing-s);height:var(--ymt-sizing-s);opacity:.6}.suggestion__label{flex:1}.suggestion__type{font-size:.75em;opacity:.5;font-style:italic}\n"], dependencies: [{ kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatAutocompleteModule }, { kind: "component", type: i2.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i2.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i2.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
473
473
  }
474
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.20", ngImport: i0, type: TokenSearchComponent, decorators: [{
474
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: TokenSearchComponent, decorators: [{
475
475
  type: Component,
476
476
  args: [{ selector: 'yuv-token-search', imports: [
477
477
  ReactiveFormsModule,
@@ -479,15 +479,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.20", ngImpo
479
479
  MatIconModule,
480
480
  MatTooltipModule
481
481
  ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"search-bar\" (click)=\"onBarClick($event)\">\n <!-- Committed tokens -->\n @for (token of tokens(); track token.uid; let i = $index) {\n <button\n class=\"token\"\n [class.token--type]=\"token.kind === 'type'\"\n [class.token--field]=\"token.kind === 'field'\"\n [class.token--operator]=\"token.kind === 'operator'\"\n [class.token--value]=\"token.kind === 'value'\"\n [class.token--combinator]=\"token.kind === 'combinator'\"\n (click)=\"onTokenClick(i)\"\n [attr.aria-label]=\"token.label\"\n >\n @if (token.kind === 'type') {\n <mat-icon class=\"token__icon\">category</mat-icon>\n }\n @if (token.kind === 'field') {\n <mat-icon class=\"token__icon\">tune</mat-icon>\n }\n <span class=\"token__label\">{{ token.label }}</span>\n @if (token.kind !== 'combinator') {\n <span\n class=\"token__remove\"\n (click)=\"$event.stopPropagation(); removeTokenGroup(i)\"\n matTooltip=\"Remove\"\n >\n <mat-icon>close</mat-icon>\n </span>\n }\n </button>\n }\n\n <!-- Pending type pill -->\n @if (pendingTypeId()) {\n <span class=\"token token--type token--pending\">\n <mat-icon class=\"token__icon\">category</mat-icon>\n <span class=\"token__label\">{{ pendingTypeLabel() }}</span>\n </span>\n }\n\n <!-- Pending field pill -->\n @if (pendingField(); as field) {\n <span class=\"token token--field token--pending\">\n <mat-icon class=\"token__icon\">tune</mat-icon>\n <span class=\"token__label\">{{ field.label }}</span>\n </span>\n }\n\n <!-- Pending operator pill -->\n @if (pendingOperator(); as op) {\n <span class=\"token token--operator token--pending\">\n <span class=\"token__label\">{{ op.label }}</span>\n </span>\n }\n\n <!-- Single input -->\n <input\n #searchInput\n [formControl]=\"searchCtrl\"\n [matAutocomplete]=\"auto\"\n [placeholder]=\"placeholderText()\"\n (keydown)=\"onKeydown($event)\"\n />\n</div>\n\n<!-- Autocomplete panel -->\n<mat-autocomplete #auto [displayWith]=\"displayFn\" (optionSelected)=\"onSuggestionSelected($event)\">\n @for (s of suggestions(); track s.id) {\n <mat-option [value]=\"s\">\n <div class=\"suggestion\">\n <mat-icon class=\"suggestion__icon\">\n @switch (s.kind) {\n @case ('type') { category }\n @case ('field') { tune }\n @case ('date-preset') { calendar_today }\n @default { manage_search }\n }\n </mat-icon>\n <span class=\"suggestion__label\">{{ s.label }}</span>\n @if (s.fieldType) {\n <span class=\"suggestion__type\">{{ s.fieldType }}</span>\n }\n </div>\n </mat-option>\n }\n</mat-autocomplete>\n", styles: [":host{display:block}.search-bar{display:flex;flex-wrap:wrap;align-items:center;gap:var(--ymt-spacing-3xs);padding:var(--ymt-spacing-2xs) var(--ymt-spacing-s);border:1px solid var(--ymt-outline-variant);border-radius:var(--ymt-corner-l);background:var(--ymt-surface);min-height:44px;cursor:text;transition:border-color .15s}.search-bar:focus-within{border-color:var(--ymt-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--ymt-primary) 15%,transparent)}.search-bar input{flex:1 1 120px;min-width:120px;border:none;outline:none;background:transparent;font:inherit;font-size:.9em;padding:var(--ymt-spacing-2xs) 0}.search-bar input::placeholder{color:var(--ymt-text-color-subtle);opacity:.7}.token{display:inline-flex;align-items:center;gap:var(--ymt-spacing-4xs);height:28px;padding:0 var(--ymt-spacing-xs);border-radius:var(--ymt-corner-s);border:1px solid var(--ymt-outline-variant);background:var(--ymt-surface-container);font:inherit;font-size:.82em;cursor:pointer;white-space:nowrap;outline:none;transition:border-color .15s,background .15s}.token:hover{border-color:var(--ymt-outline)}.token:focus-visible{border-color:var(--ymt-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--ymt-primary) 25%,transparent)}.token--type{background:var(--ymt-primary-container);color:var(--ymt-on-primary-container);font-weight:500}.token--field{background:color-mix(in srgb,var(--ymt-primary) 10%,transparent);color:var(--ymt-primary);font-weight:500}.token--operator{background:var(--ymt-surface-container-high);color:var(--ymt-text-color-subtle);font-style:italic}.token--value{max-width:160px;overflow:hidden;text-overflow:ellipsis}.token--combinator{background:var(--ymt-surface-container-high);font-weight:600;font-size:.75em;letter-spacing:.04em;color:var(--ymt-text-color-subtle);border-color:transparent}.token--pending{opacity:.7;border-style:dashed;cursor:default}.token__icon{font-size:var(--ymt-sizing-xs);width:var(--ymt-sizing-xs);height:var(--ymt-sizing-xs);opacity:.8}.token__label{line-height:1}.token__remove{display:inline-flex;align-items:center;margin-left:var(--ymt-spacing-4xs);opacity:0;transition:opacity .1s,color .1s}.token__remove mat-icon{font-size:14px;width:14px;height:14px}.token:hover .token__remove{opacity:.6}.token__remove:hover{opacity:1;color:var(--ymt-error)}.suggestion{display:flex;align-items:center;gap:var(--ymt-spacing-xs)}.suggestion__icon{font-size:var(--ymt-sizing-s);width:var(--ymt-sizing-s);height:var(--ymt-sizing-s);opacity:.6}.suggestion__label{flex:1}.suggestion__type{font-size:.75em;opacity:.5;font-style:italic}\n"] }]
482
- }], ctorParameters: () => [] });
482
+ }], ctorParameters: () => [], propDecorators: { types: [{ type: i0.Input, args: [{ isSignal: true, alias: "types", required: false }] }], queryChange: [{ type: i0.Output, args: ["queryChange"] }], searchInput: [{ type: i0.ViewChild, args: ['searchInput', { isSignal: true }] }] } });
483
483
 
484
484
  const cmp = [TokenSearchComponent];
485
485
  class YuvTokenSearchModule {
486
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.20", ngImport: i0, type: YuvTokenSearchModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
487
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "19.2.20", ngImport: i0, type: YuvTokenSearchModule, imports: [TokenSearchComponent], exports: [TokenSearchComponent] }); }
488
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "19.2.20", ngImport: i0, type: YuvTokenSearchModule, imports: [cmp] }); }
486
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: YuvTokenSearchModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
487
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "20.3.19", ngImport: i0, type: YuvTokenSearchModule, imports: [TokenSearchComponent], exports: [TokenSearchComponent] }); }
488
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: YuvTokenSearchModule, imports: [cmp] }); }
489
489
  }
490
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.20", ngImport: i0, type: YuvTokenSearchModule, decorators: [{
490
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: YuvTokenSearchModule, decorators: [{
491
491
  type: NgModule,
492
492
  args: [{
493
493
  imports: cmp,
@@ -1 +1 @@
1
- {"version":3,"file":"yuuvis-client-framework-token-search.mjs","sources":["../../../../../libs/yuuvis/client-framework/token-search/src/lib/token-search.component.ts","../../../../../libs/yuuvis/client-framework/token-search/src/lib/token-search.component.html","../../../../../libs/yuuvis/client-framework/token-search/src/lib/token-search.module.ts","../../../../../libs/yuuvis/client-framework/token-search/src/yuuvis-client-framework-token-search.ts"],"sourcesContent":["import {\n ChangeDetectionStrategy,\n Component,\n ElementRef,\n computed,\n effect,\n inject,\n input,\n output,\n signal,\n viewChild\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { FormControl, ReactiveFormsModule } from '@angular/forms';\nimport { MatAutocompleteModule, MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { GenericObjectType, SystemService } from '@yuuvis/client-core';\nimport { debounceTime } from 'rxjs/operators';\nimport { BuildStep, SearchToken, SuggestionItem } from './token-search.interface';\n\n// ── Constants ────────────────────────────────────────────────────────────────\n\nconst OPERATOR_LABELS: Record<string, string> = {\n contains: 'contains',\n like: 'like',\n eq: '=',\n gt: '>',\n gte: '>=',\n lt: '<',\n lte: '<='\n};\n\nconst CMIS_OPERATOR: Record<string, string> = {\n eq: '=',\n gt: '>',\n gte: '>=',\n lt: '<',\n lte: '<='\n};\n\nconst DATE_PRESETS: { id: string; label: string }[] = [\n { id: 'today', label: 'Today' },\n { id: 'thisWeek', label: 'This week' },\n { id: 'thisMonth', label: 'This month' },\n { id: 'thisYear', label: 'This year' }\n];\n\nconst PLACEHOLDER: Record<BuildStep, string> = {\n type: 'Search by type\\u2026',\n field: 'Pick a field\\u2026',\n operator: 'Select operator\\u2026',\n value: 'Enter value, press Enter\\u2026'\n};\n\n// ── CMIS helpers (pure functions) ────────────────────────────────────────────\n\nfunction escapeCmis(value: string): string {\n return value.replace(/'/g, \"''\").replace(/\\\\/g, '\\\\\\\\');\n}\n\nfunction quoteIfString(value: string, fieldType: string): string {\n if (fieldType === 'string' || fieldType === 'datetime') {\n return `'${escapeCmis(value)}'`;\n }\n return value;\n}\n\nfunction datePresetToRange(preset: string): { from: string; to: string } {\n const now = new Date();\n const startOfDay = (d: Date) => new Date(d.getFullYear(), d.getMonth(), d.getDate());\n let from: Date;\n let to: Date;\n switch (preset) {\n case 'today':\n from = startOfDay(now);\n to = new Date(from.getTime() + 86400000);\n break;\n case 'thisWeek': {\n const day = now.getDay();\n from = startOfDay(new Date(now.getTime() - day * 86400000));\n to = new Date(from.getTime() + 7 * 86400000);\n break;\n }\n case 'thisMonth':\n from = new Date(now.getFullYear(), now.getMonth(), 1);\n to = new Date(now.getFullYear(), now.getMonth() + 1, 1);\n break;\n case 'thisYear':\n default:\n from = new Date(now.getFullYear(), 0, 1);\n to = new Date(now.getFullYear() + 1, 0, 1);\n break;\n }\n return { from: from.toISOString(), to: to.toISOString() };\n}\n\ninterface ConditionParts {\n fieldId: string;\n fieldType: string;\n operator: string;\n value: string;\n}\n\nfunction buildConditionClause(c: ConditionParts): string {\n const op = c.operator;\n if (op === 'like') return `${c.fieldId} LIKE '%${escapeCmis(c.value)}%'`;\n if (op === 'contains') return `CONTAINS(${c.fieldId}, '${escapeCmis(c.value)}')`;\n if (op.startsWith('date:')) {\n const { from, to } = datePresetToRange(op.slice(5));\n return `${c.fieldId} >= '${from}' AND ${c.fieldId} < '${to}'`;\n }\n const cmisOp = CMIS_OPERATOR[op] ?? '=';\n return `${c.fieldId} ${cmisOp} ${quoteIfString(c.value, c.fieldType)}`;\n}\n\n// ── Parse tokens into groups and build CMIS ──────────────────────────────────\n\ninterface TokenGroup {\n typeId: string;\n isSot?: boolean;\n fieldId: string;\n fieldType: string;\n operator: string;\n value: string;\n}\n\nfunction parseTokenGroups(tokens: SearchToken[]): { groups: TokenGroup[]; combinators: string[] } {\n const groups: TokenGroup[] = [];\n const combinators: string[] = [];\n let i = 0;\n while (i < tokens.length) {\n const t = tokens[i];\n if (t.kind === 'combinator') {\n combinators.push(t.id);\n i++;\n continue;\n }\n if (t.kind === 'type') {\n const typeId = t.id;\n const field = tokens[i + 1];\n const op = tokens[i + 2];\n const maybeVal = tokens[i + 3];\n const hasValue = maybeVal?.kind === 'value';\n groups.push({\n typeId,\n isSot: t.isSot,\n fieldId: field?.id ?? '',\n fieldType: field?.fieldType ?? 'string',\n operator: op?.id ?? 'eq',\n value: hasValue ? maybeVal.id : ''\n });\n i += hasValue ? 4 : 3;\n continue;\n }\n i++;\n }\n return { groups, combinators };\n}\n\nfunction buildCmisFromTokens(tokens: SearchToken[]): string {\n const { groups, combinators } = parseTokenGroups(tokens);\n if (groups.length === 0) return '';\n\n const clauses = groups.map((g) => {\n const typeCond = g.isSot\n ? `system:secondaryObjectTypeIds IN ('${g.typeId}')`\n : `objectTypeId = '${g.typeId}'`;\n const fieldCond = buildConditionClause(g);\n return `(${typeCond} AND ${fieldCond})`;\n });\n\n const joined = clauses.reduce((acc, clause, idx) => {\n if (idx === 0) return clause;\n const comb = combinators[idx - 1] ?? 'AND';\n return `${acc} ${comb} ${clause}`;\n }, '');\n\n return `SELECT * FROM system:object WHERE ${joined}`;\n}\n\nlet _uid = 0;\nfunction uid(): string {\n return `t${++_uid}`;\n}\n\n// ── Component ────────────────────────────────────────────────────────────────\n\n@Component({\n selector: 'yuv-token-search',\n imports: [\n ReactiveFormsModule,\n MatAutocompleteModule,\n MatIconModule,\n MatTooltipModule\n ],\n templateUrl: './token-search.component.html',\n styleUrl: './token-search.component.scss',\n changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TokenSearchComponent {\n #system = inject(SystemService);\n #host = inject(ElementRef<HTMLElement>);\n\n types = input<string[]>([]);\n queryChange = output<string>();\n\n // ── Single input control ─────────────────────────────────────────────────\n searchCtrl = new FormControl('');\n searchInput = viewChild<ElementRef<HTMLInputElement>>('searchInput');\n\n // ── State ────────────────────────────────────────────────────────────────\n tokens = signal<SearchToken[]>([]);\n step = signal<BuildStep>('type');\n inputTerm = signal('');\n\n /** Pending state for the group currently being built (not yet committed) */\n pendingTypeId = signal<string | null>(null);\n pendingTypeLabel = signal<string>('');\n pendingTypeIsSot = signal<boolean>(false);\n pendingField = signal<SuggestionItem | null>(null);\n pendingOperator = signal<SuggestionItem | null>(null);\n\n // ── Computed ─────────────────────────────────────────────────────────────\n objectTypes = computed<GenericObjectType[]>(() =>\n this.#system.getObjectTypes(true, 'search').filter((t) => this.types().includes(t.id))\n );\n\n placeholderText = computed(() => PLACEHOLDER[this.step()]);\n\n suggestions = computed<SuggestionItem[]>(() => {\n const step = this.step();\n const term = this.inputTerm().toLowerCase();\n\n if (step === 'type') {\n const existingTypeIds = new Set(this.tokens().filter((t) => t.kind === 'type').map((t) => t.id));\n const all: SuggestionItem[] = this.objectTypes()\n .filter((t) => !existingTypeIds.has(t.id))\n .map((t) => ({ kind: 'type', id: t.id, label: t.label ?? t.id }));\n return term ? all.filter((s) => s.label.toLowerCase().includes(term) || s.id.toLowerCase().includes(term)) : all;\n }\n\n if (step === 'field') {\n const typeId = this.pendingTypeId();\n if (!typeId) return [];\n const ot = this.objectTypes().find((t) => t.id === typeId);\n if (!ot) return [];\n const all: SuggestionItem[] = ot.fields\n .filter((f) => f.queryable !== false)\n .map((f) => ({ kind: 'field' as const, id: f.id, label: f.label ?? f.name ?? f.id, fieldType: f.propertyType }));\n return term ? all.filter((s) => s.label.toLowerCase().includes(term) || s.id.toLowerCase().includes(term)) : all;\n }\n\n if (step === 'operator') {\n const field = this.pendingField();\n return field ? this.#operatorsForFieldType(field.fieldType ?? 'string') : [];\n }\n\n return [];\n });\n\n cmisQuery = computed(() => buildCmisFromTokens(this.tokens()));\n\n constructor() {\n this.searchCtrl.valueChanges\n .pipe(debounceTime(150), takeUntilDestroyed())\n .subscribe((val) => this.inputTerm.set(typeof val === 'string' ? val : ''));\n\n effect(() => {\n this.queryChange.emit(this.cmisQuery());\n });\n }\n\n // ── Display function for autocomplete ────────────────────────────────────\n displayFn = (): string => '';\n\n // ── Suggestion selected ──────────────────────────────────────────────────\n onSuggestionSelected(event: MatAutocompleteSelectedEvent): void {\n const item: SuggestionItem = event.option.value;\n\n switch (this.step()) {\n case 'type': {\n const selectedType = this.objectTypes().find((type) => type.id === item.id);\n this.pendingTypeId.set(item.id);\n this.pendingTypeLabel.set(item.label);\n this.pendingTypeIsSot.set(!!selectedType?.isSot);\n this.step.set('field');\n this.#clearInput();\n break;\n }\n\n case 'field':\n this.pendingField.set(item);\n this.step.set('operator');\n this.#clearInput();\n break;\n\n case 'operator': {\n if (item.kind === 'date-preset') {\n this.#commitGroup(item.id, item.label, item.id.slice(5));\n } else if (item.id === 'eq_true' || item.id === 'eq_false') {\n const val = item.id === 'eq_true' ? 'true' : 'false';\n this.#commitGroup(item.id, item.label, val);\n } else {\n this.pendingOperator.set(item);\n this.step.set('value');\n this.#clearInput();\n }\n break;\n }\n }\n }\n\n // ── Keyboard handler ──────────────────────────────────────────────────────\n onKeydown(event: KeyboardEvent): void {\n switch (event.key) {\n case 'Enter':\n if (this.step() !== 'value') return;\n {\n const term = (this.searchCtrl.value ?? '').trim();\n if (!term) return;\n const pendingOp = this.pendingOperator();\n if (!pendingOp) return;\n this.#commitGroup(pendingOp.id, pendingOp.label, term);\n }\n break;\n\n case 'Escape':\n this.#cancelPending();\n break;\n\n case 'Backspace':\n {\n const val = this.searchCtrl.value ?? '';\n if (val.length > 0) return; // normal text deletion\n\n event.preventDefault();\n\n const step = this.step();\n if (step === 'value') {\n this.pendingOperator.set(null);\n this.step.set('operator');\n this.#clearInput();\n } else if (step === 'operator') {\n this.pendingField.set(null);\n this.step.set('field');\n this.#clearInput();\n } else if (step === 'field') {\n this.pendingTypeId.set(null);\n this.pendingTypeLabel.set('');\n this.pendingTypeIsSot.set(false);\n this.step.set('type');\n this.#clearInput();\n } else if (this.tokens().length > 0) {\n this.#removeLastGroup();\n }\n }\n break;\n }\n }\n\n // ── Token click ──────────────────────────────────────────────────────────\n onTokenClick(index: number): void {\n const token = this.tokens()[index];\n if (token.kind === 'combinator') {\n this.#toggleCombinator(index);\n return;\n }\n // Find the group boundaries\n const { start, end } = this.#findGroupBounds(index);\n const groupTokens = this.tokens().slice(start, end);\n\n // Remove the group (and adjacent combinator)\n this.#removeGroupAt(start, end);\n\n // Pre-populate pending state from the group\n const typeToken = groupTokens.find((t) => t.kind === 'type');\n const fieldToken = groupTokens.find((t) => t.kind === 'field');\n const opToken = groupTokens.find((t) => t.kind === 'operator');\n\n if (typeToken) {\n this.pendingTypeId.set(typeToken.id);\n this.pendingTypeLabel.set(typeToken.label);\n this.pendingTypeIsSot.set(!!typeToken.isSot);\n }\n\n // Determine which step to start editing from\n if (token.kind === 'type') {\n this.step.set('type');\n } else if (token.kind === 'field') {\n if (typeToken) {\n this.pendingTypeId.set(typeToken.id);\n this.pendingTypeLabel.set(typeToken.label);\n this.pendingTypeIsSot.set(!!typeToken.isSot);\n }\n this.step.set('field');\n } else if (token.kind === 'operator') {\n if (fieldToken) this.pendingField.set({ kind: 'field', id: fieldToken.id, label: fieldToken.label, fieldType: fieldToken.fieldType });\n this.step.set('operator');\n } else if (token.kind === 'value') {\n if (fieldToken) this.pendingField.set({ kind: 'field', id: fieldToken.id, label: fieldToken.label, fieldType: fieldToken.fieldType });\n if (opToken) this.pendingOperator.set({ kind: 'operator', id: opToken.id, label: opToken.label });\n this.step.set('value');\n this.searchCtrl.setValue(token.label, { emitEvent: false });\n }\n\n this.#focusInput();\n }\n\n // ── Remove token via × button ────────────────────────────────────────────\n removeTokenGroup(index: number): void {\n const { start, end } = this.#findGroupBounds(index);\n this.#removeGroupAt(start, end);\n }\n\n // ── Click on search bar focuses input ────────────────────────────────────\n onBarClick(event: MouseEvent): void {\n if ((event.target as HTMLElement).closest('.token')) return;\n this.#focusInput();\n }\n\n // ── Private helpers ──────────────────────────────────────────────────────\n\n #commitGroup(operatorId: string, operatorLabel: string, value: string): void {\n const typeId = this.pendingTypeId()!;\n const typeLabel = this.pendingTypeLabel();\n const field = this.pendingField()!;\n\n const newTokens: SearchToken[] = [];\n\n // Combinator before group if tokens already exist\n if (this.tokens().length > 0) {\n newTokens.push({ kind: 'combinator', uid: uid(), id: 'AND', label: 'AND' });\n }\n\n // Type token\n newTokens.push({ kind: 'type', uid: uid(), id: typeId, label: typeLabel, isSot: this.pendingTypeIsSot() || undefined });\n\n // Field token\n newTokens.push({ kind: 'field', uid: uid(), id: field.id, label: field.label, typeId, fieldType: field.fieldType });\n\n // Operator token\n newTokens.push({ kind: 'operator', uid: uid(), id: operatorId, label: operatorLabel, typeId });\n\n // Value token (for non-terminal operators)\n const isTerminal = operatorId.startsWith('date:') || operatorId === 'eq_true' || operatorId === 'eq_false';\n if (!isTerminal) {\n newTokens.push({ kind: 'value', uid: uid(), id: value, label: value, typeId, fieldType: field.fieldType, operator: operatorId });\n }\n\n this.tokens.update((tokens) => [...tokens, ...newTokens]);\n this.#cancelPending();\n }\n\n #cancelPending(): void {\n this.pendingTypeId.set(null);\n this.pendingTypeLabel.set('');\n this.pendingTypeIsSot.set(false);\n this.pendingField.set(null);\n this.pendingOperator.set(null);\n this.step.set('type');\n this.#clearInput();\n }\n\n #clearInput(): void {\n this.searchCtrl.setValue('', { emitEvent: false });\n this.inputTerm.set('');\n setTimeout(() => this.#focusInput());\n }\n\n #focusInput(): void {\n this.searchInput()?.nativeElement.focus();\n }\n\n #toggleCombinator(index: number): void {\n this.tokens.update((tokens) =>\n tokens.map((t, i) => {\n if (i !== index) return t;\n const newId = t.id === 'AND' ? 'OR' : 'AND';\n return { ...t, id: newId, label: newId };\n })\n );\n }\n\n /** Find the start (inclusive) and end (exclusive) of the group containing the token at `index`. */\n #findGroupBounds(index: number): { start: number; end: number } {\n const tokens = this.tokens();\n\n // Walk backward to find the type token (or combinator boundary)\n let start = index;\n while (start > 0 && tokens[start - 1].kind !== 'combinator') {\n start--;\n }\n\n // Walk forward to find the next combinator or end\n let end = index + 1;\n while (end < tokens.length && tokens[end].kind !== 'combinator') {\n end++;\n }\n\n return { start, end };\n }\n\n /** Remove a group and its adjacent combinator. */\n #removeGroupAt(start: number, end: number): void {\n this.tokens.update((tokens) => {\n const result = [...tokens];\n // Also remove the combinator before or after the group\n if (start > 0 && result[start - 1]?.kind === 'combinator') {\n result.splice(start - 1, end - start + 1);\n } else if (end < result.length && result[end]?.kind === 'combinator') {\n result.splice(start, end - start + 1);\n } else {\n result.splice(start, end - start);\n }\n return result;\n });\n }\n\n #removeLastGroup(): void {\n const tokens = this.tokens();\n if (tokens.length === 0) return;\n\n // Find start of last group\n let start = tokens.length - 1;\n while (start > 0 && tokens[start - 1].kind !== 'combinator') {\n start--;\n }\n // Include preceding combinator if exists\n const removeFrom = start > 0 && tokens[start - 1].kind === 'combinator' ? start - 1 : start;\n this.tokens.update((t) => t.slice(0, removeFrom));\n }\n\n #operatorsForFieldType(fieldType: string): SuggestionItem[] {\n const base = (ids: string[]): SuggestionItem[] =>\n ids.map((id) => ({ kind: 'operator', id, label: OPERATOR_LABELS[id] ?? id }));\n\n switch (fieldType) {\n case 'integer':\n case 'decimal':\n return base(['eq', 'gt', 'gte', 'lt', 'lte']);\n case 'datetime':\n return [\n ...base(['eq', 'gt', 'gte', 'lt', 'lte']),\n ...DATE_PRESETS.map((p) => ({ kind: 'date-preset' as const, id: `date:${p.id}`, label: p.label }))\n ];\n case 'boolean':\n return [\n { kind: 'operator', id: 'eq_true', label: '= true' },\n { kind: 'operator', id: 'eq_false', label: '= false' }\n ];\n default:\n return base(['contains', 'like', 'eq']);\n }\n }\n}\n","<div class=\"search-bar\" (click)=\"onBarClick($event)\">\n <!-- Committed tokens -->\n @for (token of tokens(); track token.uid; let i = $index) {\n <button\n class=\"token\"\n [class.token--type]=\"token.kind === 'type'\"\n [class.token--field]=\"token.kind === 'field'\"\n [class.token--operator]=\"token.kind === 'operator'\"\n [class.token--value]=\"token.kind === 'value'\"\n [class.token--combinator]=\"token.kind === 'combinator'\"\n (click)=\"onTokenClick(i)\"\n [attr.aria-label]=\"token.label\"\n >\n @if (token.kind === 'type') {\n <mat-icon class=\"token__icon\">category</mat-icon>\n }\n @if (token.kind === 'field') {\n <mat-icon class=\"token__icon\">tune</mat-icon>\n }\n <span class=\"token__label\">{{ token.label }}</span>\n @if (token.kind !== 'combinator') {\n <span\n class=\"token__remove\"\n (click)=\"$event.stopPropagation(); removeTokenGroup(i)\"\n matTooltip=\"Remove\"\n >\n <mat-icon>close</mat-icon>\n </span>\n }\n </button>\n }\n\n <!-- Pending type pill -->\n @if (pendingTypeId()) {\n <span class=\"token token--type token--pending\">\n <mat-icon class=\"token__icon\">category</mat-icon>\n <span class=\"token__label\">{{ pendingTypeLabel() }}</span>\n </span>\n }\n\n <!-- Pending field pill -->\n @if (pendingField(); as field) {\n <span class=\"token token--field token--pending\">\n <mat-icon class=\"token__icon\">tune</mat-icon>\n <span class=\"token__label\">{{ field.label }}</span>\n </span>\n }\n\n <!-- Pending operator pill -->\n @if (pendingOperator(); as op) {\n <span class=\"token token--operator token--pending\">\n <span class=\"token__label\">{{ op.label }}</span>\n </span>\n }\n\n <!-- Single input -->\n <input\n #searchInput\n [formControl]=\"searchCtrl\"\n [matAutocomplete]=\"auto\"\n [placeholder]=\"placeholderText()\"\n (keydown)=\"onKeydown($event)\"\n />\n</div>\n\n<!-- Autocomplete panel -->\n<mat-autocomplete #auto [displayWith]=\"displayFn\" (optionSelected)=\"onSuggestionSelected($event)\">\n @for (s of suggestions(); track s.id) {\n <mat-option [value]=\"s\">\n <div class=\"suggestion\">\n <mat-icon class=\"suggestion__icon\">\n @switch (s.kind) {\n @case ('type') { category }\n @case ('field') { tune }\n @case ('date-preset') { calendar_today }\n @default { manage_search }\n }\n </mat-icon>\n <span class=\"suggestion__label\">{{ s.label }}</span>\n @if (s.fieldType) {\n <span class=\"suggestion__type\">{{ s.fieldType }}</span>\n }\n </div>\n </mat-option>\n }\n</mat-autocomplete>\n","import { NgModule } from '@angular/core';\nimport { TokenSearchComponent } from './token-search.component';\n\nconst cmp = [TokenSearchComponent];\n\n@NgModule({\n imports: cmp,\n exports: cmp\n})\nexport class YuvTokenSearchModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"yuuvis-client-framework-token-search.mjs","sources":["../../../../../libs/yuuvis/client-framework/token-search/src/lib/token-search.component.ts","../../../../../libs/yuuvis/client-framework/token-search/src/lib/token-search.component.html","../../../../../libs/yuuvis/client-framework/token-search/src/lib/token-search.module.ts","../../../../../libs/yuuvis/client-framework/token-search/src/yuuvis-client-framework-token-search.ts"],"sourcesContent":["import {\n ChangeDetectionStrategy,\n Component,\n ElementRef,\n computed,\n effect,\n inject,\n input,\n output,\n signal,\n viewChild\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { FormControl, ReactiveFormsModule } from '@angular/forms';\nimport { MatAutocompleteModule, MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { GenericObjectType, SystemService } from '@yuuvis/client-core';\nimport { debounceTime } from 'rxjs/operators';\nimport { BuildStep, SearchToken, SuggestionItem } from './token-search.interface';\n\n// ── Constants ────────────────────────────────────────────────────────────────\n\nconst OPERATOR_LABELS: Record<string, string> = {\n contains: 'contains',\n like: 'like',\n eq: '=',\n gt: '>',\n gte: '>=',\n lt: '<',\n lte: '<='\n};\n\nconst CMIS_OPERATOR: Record<string, string> = {\n eq: '=',\n gt: '>',\n gte: '>=',\n lt: '<',\n lte: '<='\n};\n\nconst DATE_PRESETS: { id: string; label: string }[] = [\n { id: 'today', label: 'Today' },\n { id: 'thisWeek', label: 'This week' },\n { id: 'thisMonth', label: 'This month' },\n { id: 'thisYear', label: 'This year' }\n];\n\nconst PLACEHOLDER: Record<BuildStep, string> = {\n type: 'Search by type\\u2026',\n field: 'Pick a field\\u2026',\n operator: 'Select operator\\u2026',\n value: 'Enter value, press Enter\\u2026'\n};\n\n// ── CMIS helpers (pure functions) ────────────────────────────────────────────\n\nfunction escapeCmis(value: string): string {\n return value.replace(/'/g, \"''\").replace(/\\\\/g, '\\\\\\\\');\n}\n\nfunction quoteIfString(value: string, fieldType: string): string {\n if (fieldType === 'string' || fieldType === 'datetime') {\n return `'${escapeCmis(value)}'`;\n }\n return value;\n}\n\nfunction datePresetToRange(preset: string): { from: string; to: string } {\n const now = new Date();\n const startOfDay = (d: Date) => new Date(d.getFullYear(), d.getMonth(), d.getDate());\n let from: Date;\n let to: Date;\n switch (preset) {\n case 'today':\n from = startOfDay(now);\n to = new Date(from.getTime() + 86400000);\n break;\n case 'thisWeek': {\n const day = now.getDay();\n from = startOfDay(new Date(now.getTime() - day * 86400000));\n to = new Date(from.getTime() + 7 * 86400000);\n break;\n }\n case 'thisMonth':\n from = new Date(now.getFullYear(), now.getMonth(), 1);\n to = new Date(now.getFullYear(), now.getMonth() + 1, 1);\n break;\n case 'thisYear':\n default:\n from = new Date(now.getFullYear(), 0, 1);\n to = new Date(now.getFullYear() + 1, 0, 1);\n break;\n }\n return { from: from.toISOString(), to: to.toISOString() };\n}\n\ninterface ConditionParts {\n fieldId: string;\n fieldType: string;\n operator: string;\n value: string;\n}\n\nfunction buildConditionClause(c: ConditionParts): string {\n const op = c.operator;\n if (op === 'like') return `${c.fieldId} LIKE '%${escapeCmis(c.value)}%'`;\n if (op === 'contains') return `CONTAINS(${c.fieldId}, '${escapeCmis(c.value)}')`;\n if (op.startsWith('date:')) {\n const { from, to } = datePresetToRange(op.slice(5));\n return `${c.fieldId} >= '${from}' AND ${c.fieldId} < '${to}'`;\n }\n const cmisOp = CMIS_OPERATOR[op] ?? '=';\n return `${c.fieldId} ${cmisOp} ${quoteIfString(c.value, c.fieldType)}`;\n}\n\n// ── Parse tokens into groups and build CMIS ──────────────────────────────────\n\ninterface TokenGroup {\n typeId: string;\n isSot?: boolean;\n fieldId: string;\n fieldType: string;\n operator: string;\n value: string;\n}\n\nfunction parseTokenGroups(tokens: SearchToken[]): { groups: TokenGroup[]; combinators: string[] } {\n const groups: TokenGroup[] = [];\n const combinators: string[] = [];\n let i = 0;\n while (i < tokens.length) {\n const t = tokens[i];\n if (t.kind === 'combinator') {\n combinators.push(t.id);\n i++;\n continue;\n }\n if (t.kind === 'type') {\n const typeId = t.id;\n const field = tokens[i + 1];\n const op = tokens[i + 2];\n const maybeVal = tokens[i + 3];\n const hasValue = maybeVal?.kind === 'value';\n groups.push({\n typeId,\n isSot: t.isSot,\n fieldId: field?.id ?? '',\n fieldType: field?.fieldType ?? 'string',\n operator: op?.id ?? 'eq',\n value: hasValue ? maybeVal.id : ''\n });\n i += hasValue ? 4 : 3;\n continue;\n }\n i++;\n }\n return { groups, combinators };\n}\n\nfunction buildCmisFromTokens(tokens: SearchToken[]): string {\n const { groups, combinators } = parseTokenGroups(tokens);\n if (groups.length === 0) return '';\n\n const clauses = groups.map((g) => {\n const typeCond = g.isSot\n ? `system:secondaryObjectTypeIds IN ('${g.typeId}')`\n : `objectTypeId = '${g.typeId}'`;\n const fieldCond = buildConditionClause(g);\n return `(${typeCond} AND ${fieldCond})`;\n });\n\n const joined = clauses.reduce((acc, clause, idx) => {\n if (idx === 0) return clause;\n const comb = combinators[idx - 1] ?? 'AND';\n return `${acc} ${comb} ${clause}`;\n }, '');\n\n return `SELECT * FROM system:object WHERE ${joined}`;\n}\n\nlet _uid = 0;\nfunction uid(): string {\n return `t${++_uid}`;\n}\n\n// ── Component ────────────────────────────────────────────────────────────────\n\n@Component({\n selector: 'yuv-token-search',\n imports: [\n ReactiveFormsModule,\n MatAutocompleteModule,\n MatIconModule,\n MatTooltipModule\n ],\n templateUrl: './token-search.component.html',\n styleUrl: './token-search.component.scss',\n changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TokenSearchComponent {\n #system = inject(SystemService);\n #host = inject(ElementRef<HTMLElement>);\n\n types = input<string[]>([]);\n queryChange = output<string>();\n\n // ── Single input control ─────────────────────────────────────────────────\n searchCtrl = new FormControl('');\n searchInput = viewChild<ElementRef<HTMLInputElement>>('searchInput');\n\n // ── State ────────────────────────────────────────────────────────────────\n tokens = signal<SearchToken[]>([]);\n step = signal<BuildStep>('type');\n inputTerm = signal('');\n\n /** Pending state for the group currently being built (not yet committed) */\n pendingTypeId = signal<string | null>(null);\n pendingTypeLabel = signal<string>('');\n pendingTypeIsSot = signal<boolean>(false);\n pendingField = signal<SuggestionItem | null>(null);\n pendingOperator = signal<SuggestionItem | null>(null);\n\n // ── Computed ─────────────────────────────────────────────────────────────\n objectTypes = computed<GenericObjectType[]>(() =>\n this.#system.getObjectTypes(true, 'search').filter((t) => this.types().includes(t.id))\n );\n\n placeholderText = computed(() => PLACEHOLDER[this.step()]);\n\n suggestions = computed<SuggestionItem[]>(() => {\n const step = this.step();\n const term = this.inputTerm().toLowerCase();\n\n if (step === 'type') {\n const existingTypeIds = new Set(this.tokens().filter((t) => t.kind === 'type').map((t) => t.id));\n const all: SuggestionItem[] = this.objectTypes()\n .filter((t) => !existingTypeIds.has(t.id))\n .map((t) => ({ kind: 'type', id: t.id, label: t.label ?? t.id }));\n return term ? all.filter((s) => s.label.toLowerCase().includes(term) || s.id.toLowerCase().includes(term)) : all;\n }\n\n if (step === 'field') {\n const typeId = this.pendingTypeId();\n if (!typeId) return [];\n const ot = this.objectTypes().find((t) => t.id === typeId);\n if (!ot) return [];\n const all: SuggestionItem[] = ot.fields\n .filter((f) => f.queryable !== false)\n .map((f) => ({ kind: 'field' as const, id: f.id, label: f.label ?? f.name ?? f.id, fieldType: f.propertyType }));\n return term ? all.filter((s) => s.label.toLowerCase().includes(term) || s.id.toLowerCase().includes(term)) : all;\n }\n\n if (step === 'operator') {\n const field = this.pendingField();\n return field ? this.#operatorsForFieldType(field.fieldType ?? 'string') : [];\n }\n\n return [];\n });\n\n cmisQuery = computed(() => buildCmisFromTokens(this.tokens()));\n\n constructor() {\n this.searchCtrl.valueChanges\n .pipe(debounceTime(150), takeUntilDestroyed())\n .subscribe((val) => this.inputTerm.set(typeof val === 'string' ? val : ''));\n\n effect(() => {\n this.queryChange.emit(this.cmisQuery());\n });\n }\n\n // ── Display function for autocomplete ────────────────────────────────────\n displayFn = (): string => '';\n\n // ── Suggestion selected ──────────────────────────────────────────────────\n onSuggestionSelected(event: MatAutocompleteSelectedEvent): void {\n const item: SuggestionItem = event.option.value;\n\n switch (this.step()) {\n case 'type': {\n const selectedType = this.objectTypes().find((type) => type.id === item.id);\n this.pendingTypeId.set(item.id);\n this.pendingTypeLabel.set(item.label);\n this.pendingTypeIsSot.set(!!selectedType?.isSot);\n this.step.set('field');\n this.#clearInput();\n break;\n }\n\n case 'field':\n this.pendingField.set(item);\n this.step.set('operator');\n this.#clearInput();\n break;\n\n case 'operator': {\n if (item.kind === 'date-preset') {\n this.#commitGroup(item.id, item.label, item.id.slice(5));\n } else if (item.id === 'eq_true' || item.id === 'eq_false') {\n const val = item.id === 'eq_true' ? 'true' : 'false';\n this.#commitGroup(item.id, item.label, val);\n } else {\n this.pendingOperator.set(item);\n this.step.set('value');\n this.#clearInput();\n }\n break;\n }\n }\n }\n\n // ── Keyboard handler ──────────────────────────────────────────────────────\n onKeydown(event: KeyboardEvent): void {\n switch (event.key) {\n case 'Enter':\n if (this.step() !== 'value') return;\n {\n const term = (this.searchCtrl.value ?? '').trim();\n if (!term) return;\n const pendingOp = this.pendingOperator();\n if (!pendingOp) return;\n this.#commitGroup(pendingOp.id, pendingOp.label, term);\n }\n break;\n\n case 'Escape':\n this.#cancelPending();\n break;\n\n case 'Backspace':\n {\n const val = this.searchCtrl.value ?? '';\n if (val.length > 0) return; // normal text deletion\n\n event.preventDefault();\n\n const step = this.step();\n if (step === 'value') {\n this.pendingOperator.set(null);\n this.step.set('operator');\n this.#clearInput();\n } else if (step === 'operator') {\n this.pendingField.set(null);\n this.step.set('field');\n this.#clearInput();\n } else if (step === 'field') {\n this.pendingTypeId.set(null);\n this.pendingTypeLabel.set('');\n this.pendingTypeIsSot.set(false);\n this.step.set('type');\n this.#clearInput();\n } else if (this.tokens().length > 0) {\n this.#removeLastGroup();\n }\n }\n break;\n }\n }\n\n // ── Token click ──────────────────────────────────────────────────────────\n onTokenClick(index: number): void {\n const token = this.tokens()[index];\n if (token.kind === 'combinator') {\n this.#toggleCombinator(index);\n return;\n }\n // Find the group boundaries\n const { start, end } = this.#findGroupBounds(index);\n const groupTokens = this.tokens().slice(start, end);\n\n // Remove the group (and adjacent combinator)\n this.#removeGroupAt(start, end);\n\n // Pre-populate pending state from the group\n const typeToken = groupTokens.find((t) => t.kind === 'type');\n const fieldToken = groupTokens.find((t) => t.kind === 'field');\n const opToken = groupTokens.find((t) => t.kind === 'operator');\n\n if (typeToken) {\n this.pendingTypeId.set(typeToken.id);\n this.pendingTypeLabel.set(typeToken.label);\n this.pendingTypeIsSot.set(!!typeToken.isSot);\n }\n\n // Determine which step to start editing from\n if (token.kind === 'type') {\n this.step.set('type');\n } else if (token.kind === 'field') {\n if (typeToken) {\n this.pendingTypeId.set(typeToken.id);\n this.pendingTypeLabel.set(typeToken.label);\n this.pendingTypeIsSot.set(!!typeToken.isSot);\n }\n this.step.set('field');\n } else if (token.kind === 'operator') {\n if (fieldToken) this.pendingField.set({ kind: 'field', id: fieldToken.id, label: fieldToken.label, fieldType: fieldToken.fieldType });\n this.step.set('operator');\n } else if (token.kind === 'value') {\n if (fieldToken) this.pendingField.set({ kind: 'field', id: fieldToken.id, label: fieldToken.label, fieldType: fieldToken.fieldType });\n if (opToken) this.pendingOperator.set({ kind: 'operator', id: opToken.id, label: opToken.label });\n this.step.set('value');\n this.searchCtrl.setValue(token.label, { emitEvent: false });\n }\n\n this.#focusInput();\n }\n\n // ── Remove token via × button ────────────────────────────────────────────\n removeTokenGroup(index: number): void {\n const { start, end } = this.#findGroupBounds(index);\n this.#removeGroupAt(start, end);\n }\n\n // ── Click on search bar focuses input ────────────────────────────────────\n onBarClick(event: MouseEvent): void {\n if ((event.target as HTMLElement).closest('.token')) return;\n this.#focusInput();\n }\n\n // ── Private helpers ──────────────────────────────────────────────────────\n\n #commitGroup(operatorId: string, operatorLabel: string, value: string): void {\n const typeId = this.pendingTypeId()!;\n const typeLabel = this.pendingTypeLabel();\n const field = this.pendingField()!;\n\n const newTokens: SearchToken[] = [];\n\n // Combinator before group if tokens already exist\n if (this.tokens().length > 0) {\n newTokens.push({ kind: 'combinator', uid: uid(), id: 'AND', label: 'AND' });\n }\n\n // Type token\n newTokens.push({ kind: 'type', uid: uid(), id: typeId, label: typeLabel, isSot: this.pendingTypeIsSot() || undefined });\n\n // Field token\n newTokens.push({ kind: 'field', uid: uid(), id: field.id, label: field.label, typeId, fieldType: field.fieldType });\n\n // Operator token\n newTokens.push({ kind: 'operator', uid: uid(), id: operatorId, label: operatorLabel, typeId });\n\n // Value token (for non-terminal operators)\n const isTerminal = operatorId.startsWith('date:') || operatorId === 'eq_true' || operatorId === 'eq_false';\n if (!isTerminal) {\n newTokens.push({ kind: 'value', uid: uid(), id: value, label: value, typeId, fieldType: field.fieldType, operator: operatorId });\n }\n\n this.tokens.update((tokens) => [...tokens, ...newTokens]);\n this.#cancelPending();\n }\n\n #cancelPending(): void {\n this.pendingTypeId.set(null);\n this.pendingTypeLabel.set('');\n this.pendingTypeIsSot.set(false);\n this.pendingField.set(null);\n this.pendingOperator.set(null);\n this.step.set('type');\n this.#clearInput();\n }\n\n #clearInput(): void {\n this.searchCtrl.setValue('', { emitEvent: false });\n this.inputTerm.set('');\n setTimeout(() => this.#focusInput());\n }\n\n #focusInput(): void {\n this.searchInput()?.nativeElement.focus();\n }\n\n #toggleCombinator(index: number): void {\n this.tokens.update((tokens) =>\n tokens.map((t, i) => {\n if (i !== index) return t;\n const newId = t.id === 'AND' ? 'OR' : 'AND';\n return { ...t, id: newId, label: newId };\n })\n );\n }\n\n /** Find the start (inclusive) and end (exclusive) of the group containing the token at `index`. */\n #findGroupBounds(index: number): { start: number; end: number } {\n const tokens = this.tokens();\n\n // Walk backward to find the type token (or combinator boundary)\n let start = index;\n while (start > 0 && tokens[start - 1].kind !== 'combinator') {\n start--;\n }\n\n // Walk forward to find the next combinator or end\n let end = index + 1;\n while (end < tokens.length && tokens[end].kind !== 'combinator') {\n end++;\n }\n\n return { start, end };\n }\n\n /** Remove a group and its adjacent combinator. */\n #removeGroupAt(start: number, end: number): void {\n this.tokens.update((tokens) => {\n const result = [...tokens];\n // Also remove the combinator before or after the group\n if (start > 0 && result[start - 1]?.kind === 'combinator') {\n result.splice(start - 1, end - start + 1);\n } else if (end < result.length && result[end]?.kind === 'combinator') {\n result.splice(start, end - start + 1);\n } else {\n result.splice(start, end - start);\n }\n return result;\n });\n }\n\n #removeLastGroup(): void {\n const tokens = this.tokens();\n if (tokens.length === 0) return;\n\n // Find start of last group\n let start = tokens.length - 1;\n while (start > 0 && tokens[start - 1].kind !== 'combinator') {\n start--;\n }\n // Include preceding combinator if exists\n const removeFrom = start > 0 && tokens[start - 1].kind === 'combinator' ? start - 1 : start;\n this.tokens.update((t) => t.slice(0, removeFrom));\n }\n\n #operatorsForFieldType(fieldType: string): SuggestionItem[] {\n const base = (ids: string[]): SuggestionItem[] =>\n ids.map((id) => ({ kind: 'operator', id, label: OPERATOR_LABELS[id] ?? id }));\n\n switch (fieldType) {\n case 'integer':\n case 'decimal':\n return base(['eq', 'gt', 'gte', 'lt', 'lte']);\n case 'datetime':\n return [\n ...base(['eq', 'gt', 'gte', 'lt', 'lte']),\n ...DATE_PRESETS.map((p) => ({ kind: 'date-preset' as const, id: `date:${p.id}`, label: p.label }))\n ];\n case 'boolean':\n return [\n { kind: 'operator', id: 'eq_true', label: '= true' },\n { kind: 'operator', id: 'eq_false', label: '= false' }\n ];\n default:\n return base(['contains', 'like', 'eq']);\n }\n }\n}\n","<div class=\"search-bar\" (click)=\"onBarClick($event)\">\n <!-- Committed tokens -->\n @for (token of tokens(); track token.uid; let i = $index) {\n <button\n class=\"token\"\n [class.token--type]=\"token.kind === 'type'\"\n [class.token--field]=\"token.kind === 'field'\"\n [class.token--operator]=\"token.kind === 'operator'\"\n [class.token--value]=\"token.kind === 'value'\"\n [class.token--combinator]=\"token.kind === 'combinator'\"\n (click)=\"onTokenClick(i)\"\n [attr.aria-label]=\"token.label\"\n >\n @if (token.kind === 'type') {\n <mat-icon class=\"token__icon\">category</mat-icon>\n }\n @if (token.kind === 'field') {\n <mat-icon class=\"token__icon\">tune</mat-icon>\n }\n <span class=\"token__label\">{{ token.label }}</span>\n @if (token.kind !== 'combinator') {\n <span\n class=\"token__remove\"\n (click)=\"$event.stopPropagation(); removeTokenGroup(i)\"\n matTooltip=\"Remove\"\n >\n <mat-icon>close</mat-icon>\n </span>\n }\n </button>\n }\n\n <!-- Pending type pill -->\n @if (pendingTypeId()) {\n <span class=\"token token--type token--pending\">\n <mat-icon class=\"token__icon\">category</mat-icon>\n <span class=\"token__label\">{{ pendingTypeLabel() }}</span>\n </span>\n }\n\n <!-- Pending field pill -->\n @if (pendingField(); as field) {\n <span class=\"token token--field token--pending\">\n <mat-icon class=\"token__icon\">tune</mat-icon>\n <span class=\"token__label\">{{ field.label }}</span>\n </span>\n }\n\n <!-- Pending operator pill -->\n @if (pendingOperator(); as op) {\n <span class=\"token token--operator token--pending\">\n <span class=\"token__label\">{{ op.label }}</span>\n </span>\n }\n\n <!-- Single input -->\n <input\n #searchInput\n [formControl]=\"searchCtrl\"\n [matAutocomplete]=\"auto\"\n [placeholder]=\"placeholderText()\"\n (keydown)=\"onKeydown($event)\"\n />\n</div>\n\n<!-- Autocomplete panel -->\n<mat-autocomplete #auto [displayWith]=\"displayFn\" (optionSelected)=\"onSuggestionSelected($event)\">\n @for (s of suggestions(); track s.id) {\n <mat-option [value]=\"s\">\n <div class=\"suggestion\">\n <mat-icon class=\"suggestion__icon\">\n @switch (s.kind) {\n @case ('type') { category }\n @case ('field') { tune }\n @case ('date-preset') { calendar_today }\n @default { manage_search }\n }\n </mat-icon>\n <span class=\"suggestion__label\">{{ s.label }}</span>\n @if (s.fieldType) {\n <span class=\"suggestion__type\">{{ s.fieldType }}</span>\n }\n </div>\n </mat-option>\n }\n</mat-autocomplete>\n","import { NgModule } from '@angular/core';\nimport { TokenSearchComponent } from './token-search.component';\n\nconst cmp = [TokenSearchComponent];\n\n@NgModule({\n imports: cmp,\n exports: cmp\n})\nexport class YuvTokenSearchModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
@@ -1,11 +1,11 @@
1
- import * as i1 from '@angular/common';
2
- import { CommonModule } from '@angular/common';
3
1
  import * as i0 from '@angular/core';
4
- import { Injectable, inject, input, effect, HostBinding, Component, ElementRef, HostAttributeToken, output, HostListener, Input } from '@angular/core';
2
+ import { Injectable, inject, input, effect, Component, ElementRef, HostAttributeToken, output, Input } from '@angular/core';
5
3
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
+ import * as i1 from '@angular/common';
5
+ import { CommonModule } from '@angular/common';
6
+ import { MatTooltipModule } from '@angular/material/tooltip';
6
7
  import { YuvIconComponent } from '@yuuvis/client-framework/icons';
7
8
  import { ReplaySubject, Subject } from 'rxjs';
8
- import { MatTooltipModule } from '@angular/material/tooltip';
9
9
 
10
10
  class TreeService {
11
11
  constructor() {
@@ -92,18 +92,18 @@ class TreeService {
92
92
  this._resolveChildren(nodeIDs, n.children);
93
93
  });
94
94
  }
95
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.20", ngImport: i0, type: TreeService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
96
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.2.20", ngImport: i0, type: TreeService }); }
95
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: TreeService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
96
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: TreeService }); }
97
97
  }
98
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.20", ngImport: i0, type: TreeService, decorators: [{
98
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: TreeService, decorators: [{
99
99
  type: Injectable
100
100
  }] });
101
101
 
102
102
  class TreeNodeComponent {
103
103
  constructor() {
104
104
  this.treeService = inject(TreeService);
105
- this.node = input.required();
106
- this.toggleIcon = input('<svg xmlns="http://www.w3.org/2000/svg" height="18px" viewBox="0 -960 960 960" width="18px"><path d="M522-480 333-669l51-51 240 240-240 240-51-51 189-189Z"/></svg>');
105
+ this.node = input.required(...(ngDevMode ? [{ debugName: "node" }] : []));
106
+ this.toggleIcon = input('<svg xmlns="http://www.w3.org/2000/svg" height="18px" viewBox="0 -960 960 960" width="18px"><path d="M522-480 333-669l51-51 240 240-240 240-51-51 189-189Z"/></svg>', ...(ngDevMode ? [{ debugName: "toggleIcon" }] : []));
107
107
  this.focused = false;
108
108
  this.selected = false;
109
109
  this.expanded = false;
@@ -112,7 +112,7 @@ class TreeNodeComponent {
112
112
  this.treeSelectEffect = effect(() => {
113
113
  this._setSelection();
114
114
  this.expanded = !!this.node().expanded;
115
- });
115
+ }, ...(ngDevMode ? [{ debugName: "treeSelectEffect" }] : []));
116
116
  }
117
117
  select(evt) {
118
118
  this.treeService.selectNode(this.node(), evt.ctrlKey);
@@ -138,24 +138,18 @@ class TreeNodeComponent {
138
138
  ngOnDestroy() {
139
139
  this._subs.forEach((s) => s.unsubscribe());
140
140
  }
141
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.20", ngImport: i0, type: TreeNodeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
142
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.20", type: TreeNodeComponent, isStandalone: true, selector: "yuv-tree-node", inputs: { node: { classPropertyName: "node", publicName: "node", isSignal: true, isRequired: true, transformFunction: null }, toggleIcon: { classPropertyName: "toggleIcon", publicName: "toggleIcon", isSignal: true, isRequired: false, transformFunction: null } }, host: { attributes: { "role": "treeitem" }, properties: { "class.focused": "this.focused", "attr.aria-selected": "this.selected", "attr.aria-expanded": "this.expanded" } }, ngImport: i0, template: "@if (node().children?.length) {\n <!-- toggle children button-->\n <!-- TODO: title should be i18n -->\n <button class=\"toggle\" (click)=\"toggleExpanded()\">\n <yuv-icon [svg]=\"toggleIcon()\"></yuv-icon>\n </button>\n}\n<div class=\"node-label\" [attr.node-id]=\"node().id\" [ngClass]=\"{ selectable: node().selectable }\" (click)=\"select($event)\">\n @if (node().icon) {\n <yuv-icon class=\"node-icon\" [svg]=\"node().icon!\"></yuv-icon>\n }\n <div class=\"label\">{{ node().label }}</div>\n</div>\n\n@if (node().expanded) {\n <div class=\"children\">\n @for (childNode of node().children; track $index) {\n <yuv-tree-node tabindex=\"0\" [toggleIcon]=\"toggleIcon()\" [node]=\"childNode\"></yuv-tree-node>\n }\n </div>\n}\n", styles: [":host-context(:focus).focused>.node-label{background-color:var(--ymt-focus-background);outline:1px solid var(--ymt-text-color-subtle);outline-offset:-3px}:host-context([selectable])[aria-selected=true]>.node-label{background-color:var(--ymt-selection-background)}:host-context([selectable])[aria-selected=true]>.node-label:hover{background-color:var(--ymt-selection-background)}:host{display:grid;grid-template-rows:auto auto;grid-template-columns:var(--toggle-icon-size) 1fr;grid-template-areas:\"toggle label\" \"child child\";align-items:center}:host .node-label{grid-area:label;display:flex;flex-flow:row nowrap;align-items:center}:host .node-label.selectable{cursor:pointer}:host .node-label:hover{background-color:var(--ymt-hover-background)}:host .node-label .label{padding:var(--node-padding);text-align:start;color:var(--ymt-text-color);background-color:transparent;-webkit-user-select:none;user-select:none;flex:1}:host .node-label .node-icon{color:var(--ymt-text-color-subtle)}:host .children{grid-area:child;padding-inline-start:var(--node-indent)}:host[aria-expanded=true] button.toggle{rotate:90deg}:host button.toggle{grid-area:toggle;border:0;padding:2px;border-radius:50%;justify-self:center;align-self:center}\n"], dependencies: [{ kind: "component", type: TreeNodeComponent, selector: "yuv-tree-node", inputs: ["node", "toggleIcon"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: YuvIconComponent, selector: "yuv-icon", inputs: ["label", "svg", "svgSrc"] }, { kind: "ngmodule", type: MatTooltipModule }] }); }
141
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: TreeNodeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
142
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.19", type: TreeNodeComponent, isStandalone: true, selector: "yuv-tree-node", inputs: { node: { classPropertyName: "node", publicName: "node", isSignal: true, isRequired: true, transformFunction: null }, toggleIcon: { classPropertyName: "toggleIcon", publicName: "toggleIcon", isSignal: true, isRequired: false, transformFunction: null } }, host: { attributes: { "role": "treeitem" }, properties: { "class.focused": "focused", "attr.aria-selected": "selected", "attr.aria-expanded": "expanded" } }, ngImport: i0, template: "@if (node().children?.length) {\n <!-- toggle children button-->\n <!-- TODO: title should be i18n -->\n <button class=\"toggle\" (click)=\"toggleExpanded()\">\n <yuv-icon [svg]=\"toggleIcon()\"></yuv-icon>\n </button>\n}\n<div class=\"node-label\" [attr.node-id]=\"node().id\" [ngClass]=\"{ selectable: node().selectable }\" (click)=\"select($event)\">\n @if (node().icon) {\n <yuv-icon class=\"node-icon\" [svg]=\"node().icon!\"></yuv-icon>\n }\n <div class=\"label\">{{ node().label }}</div>\n</div>\n\n@if (node().expanded) {\n <div class=\"children\">\n @for (childNode of node().children; track $index) {\n <yuv-tree-node tabindex=\"0\" [toggleIcon]=\"toggleIcon()\" [node]=\"childNode\"></yuv-tree-node>\n }\n </div>\n}\n", styles: [":host-context(:focus).focused>.node-label{background-color:var(--ymt-focus-background);outline:1px solid var(--ymt-text-color-subtle);outline-offset:-3px}:host-context([selectable])[aria-selected=true]>.node-label{background-color:var(--ymt-selection-background)}:host-context([selectable])[aria-selected=true]>.node-label:hover{background-color:var(--ymt-selection-background)}:host{display:grid;grid-template-rows:auto auto;grid-template-columns:var(--toggle-icon-size) 1fr;grid-template-areas:\"toggle label\" \"child child\";align-items:center}:host .node-label{grid-area:label;display:flex;flex-flow:row nowrap;align-items:center}:host .node-label.selectable{cursor:pointer}:host .node-label:hover{background-color:var(--ymt-hover-background)}:host .node-label .label{padding:var(--node-padding);text-align:start;color:var(--ymt-text-color);background-color:transparent;-webkit-user-select:none;user-select:none;flex:1}:host .node-label .node-icon{color:var(--ymt-text-color-subtle)}:host .children{grid-area:child;padding-inline-start:var(--node-indent)}:host[aria-expanded=true] button.toggle{rotate:90deg}:host button.toggle{grid-area:toggle;border:0;padding:2px;border-radius:50%;justify-self:center;align-self:center}\n"], dependencies: [{ kind: "component", type: TreeNodeComponent, selector: "yuv-tree-node", inputs: ["node", "toggleIcon"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: YuvIconComponent, selector: "yuv-icon", inputs: ["label", "svg", "svgSrc"] }, { kind: "ngmodule", type: MatTooltipModule }] }); }
143
143
  }
144
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.20", ngImport: i0, type: TreeNodeComponent, decorators: [{
144
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: TreeNodeComponent, decorators: [{
145
145
  type: Component,
146
146
  args: [{ selector: 'yuv-tree-node', standalone: true, imports: [CommonModule, YuvIconComponent, MatTooltipModule], host: {
147
- role: 'treeitem'
147
+ role: 'treeitem',
148
+ '[class.focused]': 'focused',
149
+ '[attr.aria-selected]': 'selected',
150
+ '[attr.aria-expanded]': 'expanded'
148
151
  }, template: "@if (node().children?.length) {\n <!-- toggle children button-->\n <!-- TODO: title should be i18n -->\n <button class=\"toggle\" (click)=\"toggleExpanded()\">\n <yuv-icon [svg]=\"toggleIcon()\"></yuv-icon>\n </button>\n}\n<div class=\"node-label\" [attr.node-id]=\"node().id\" [ngClass]=\"{ selectable: node().selectable }\" (click)=\"select($event)\">\n @if (node().icon) {\n <yuv-icon class=\"node-icon\" [svg]=\"node().icon!\"></yuv-icon>\n }\n <div class=\"label\">{{ node().label }}</div>\n</div>\n\n@if (node().expanded) {\n <div class=\"children\">\n @for (childNode of node().children; track $index) {\n <yuv-tree-node tabindex=\"0\" [toggleIcon]=\"toggleIcon()\" [node]=\"childNode\"></yuv-tree-node>\n }\n </div>\n}\n", styles: [":host-context(:focus).focused>.node-label{background-color:var(--ymt-focus-background);outline:1px solid var(--ymt-text-color-subtle);outline-offset:-3px}:host-context([selectable])[aria-selected=true]>.node-label{background-color:var(--ymt-selection-background)}:host-context([selectable])[aria-selected=true]>.node-label:hover{background-color:var(--ymt-selection-background)}:host{display:grid;grid-template-rows:auto auto;grid-template-columns:var(--toggle-icon-size) 1fr;grid-template-areas:\"toggle label\" \"child child\";align-items:center}:host .node-label{grid-area:label;display:flex;flex-flow:row nowrap;align-items:center}:host .node-label.selectable{cursor:pointer}:host .node-label:hover{background-color:var(--ymt-hover-background)}:host .node-label .label{padding:var(--node-padding);text-align:start;color:var(--ymt-text-color);background-color:transparent;-webkit-user-select:none;user-select:none;flex:1}:host .node-label .node-icon{color:var(--ymt-text-color-subtle)}:host .children{grid-area:child;padding-inline-start:var(--node-indent)}:host[aria-expanded=true] button.toggle{rotate:90deg}:host button.toggle{grid-area:toggle;border:0;padding:2px;border-radius:50%;justify-self:center;align-self:center}\n"] }]
149
- }], propDecorators: { focused: [{
150
- type: HostBinding,
151
- args: ['class.focused']
152
- }], selected: [{
153
- type: HostBinding,
154
- args: ['attr.aria-selected']
155
- }], expanded: [{
156
- type: HostBinding,
157
- args: ['attr.aria-expanded']
158
- }] } });
152
+ }], propDecorators: { node: [{ type: i0.Input, args: [{ isSignal: true, alias: "node", required: true }] }], toggleIcon: [{ type: i0.Input, args: [{ isSignal: true, alias: "toggleIcon", required: false }] }] } });
159
153
 
160
154
  /**
161
155
  * Component rendering a tree.
@@ -219,7 +213,7 @@ class TreeComponent {
219
213
  /**
220
214
  * The tree to be rendered
221
215
  */
222
- this.tree = input.required();
216
+ this.tree = input.required(...(ngDevMode ? [{ debugName: "tree" }] : []));
223
217
  /**
224
218
  * Whether or not multiple nodes should be selectable. Only works when selection is enableed by
225
219
  * setting 'selectable' attribute:
@@ -228,7 +222,7 @@ class TreeComponent {
228
222
  * <yuv-tree selectable [multiselect]="true"></yuv-tree
229
223
  * ```
230
224
  */
231
- this.multiselect = input(false);
225
+ this.multiselect = input(false, ...(ngDevMode ? [{ debugName: "multiselect" }] : []));
232
226
  /**
233
227
  * Host attribute to enable persistent selection of nodes.
234
228
  */
@@ -242,8 +236,8 @@ class TreeComponent {
242
236
  this.setTreeEffect = effect(() => {
243
237
  this.treeService.setTree(this.tree());
244
238
  // if (this.tree()) this.selectedNodes = [];
245
- });
246
- this.setTreeMultiselectEffect = effect(() => (this.treeService.multiselect = this.multiselect()));
239
+ }, ...(ngDevMode ? [{ debugName: "setTreeEffect" }] : []));
240
+ this.setTreeMultiselectEffect = effect(() => (this.treeService.multiselect = this.multiselect()), ...(ngDevMode ? [{ debugName: "setTreeMultiselectEffect" }] : []));
247
241
  this.treeService.nodeClick$.pipe(takeUntilDestroyed()).subscribe((node) => {
248
242
  const idx = Array.from(this.items || []).findIndex((i) => i.getAttribute('node-id') === node.id);
249
243
  if (idx !== -1)
@@ -280,27 +274,21 @@ class TreeComponent {
280
274
  ngOnDestroy() {
281
275
  this._observer.disconnect();
282
276
  }
283
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.20", ngImport: i0, type: TreeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
284
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.20", type: TreeComponent, isStandalone: true, selector: "yuv-tree", inputs: { tree: { classPropertyName: "tree", publicName: "tree", isSignal: true, isRequired: true, transformFunction: null }, multiselect: { classPropertyName: "multiselect", publicName: "multiselect", isSignal: true, isRequired: false, transformFunction: null }, selectedNodes: { classPropertyName: "selectedNodes", publicName: "selectedNodes", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { selectionChange: "selectionChange" }, host: { attributes: { "role": "tree" }, listeners: { "keydown": "onKeydown($event)" }, properties: { "class.selectable": "this.selectable", "attr.tabindex": "this.tabindex" }, classAttribute: "yuv-tree" }, providers: [TreeService], ngImport: i0, template: "@for (node of tree().nodes; track node.id) {\n <yuv-tree-node tabindex=\"0\" [node]=\"node\"></yuv-tree-node>\n}\n", styles: [":host{--toggle-icon-size: 18px;--node-padding: var(--ymt-spacing-xs);--node-indent: var(--toggle-icon-size)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: TreeNodeComponent, selector: "yuv-tree-node", inputs: ["node", "toggleIcon"] }] }); }
277
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: TreeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
278
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.19", type: TreeComponent, isStandalone: true, selector: "yuv-tree", inputs: { tree: { classPropertyName: "tree", publicName: "tree", isSignal: true, isRequired: true, transformFunction: null }, multiselect: { classPropertyName: "multiselect", publicName: "multiselect", isSignal: true, isRequired: false, transformFunction: null }, selectedNodes: { classPropertyName: "selectedNodes", publicName: "selectedNodes", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { selectionChange: "selectionChange" }, host: { attributes: { "role": "tree" }, listeners: { "keydown": "onKeydown($event)" }, properties: { "class.selectable": "selectable", "attr.tabindex": "tabindex" }, classAttribute: "yuv-tree" }, providers: [TreeService], ngImport: i0, template: "@for (node of tree().nodes; track node.id) {\n <yuv-tree-node tabindex=\"0\" [node]=\"node\"></yuv-tree-node>\n}\n", styles: [":host{--toggle-icon-size: 18px;--node-padding: var(--ymt-spacing-xs);--node-indent: var(--toggle-icon-size)}\n"], dependencies: [{ kind: "component", type: TreeNodeComponent, selector: "yuv-tree-node", inputs: ["node", "toggleIcon"] }] }); }
285
279
  }
286
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.20", ngImport: i0, type: TreeComponent, decorators: [{
280
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: TreeComponent, decorators: [{
287
281
  type: Component,
288
- args: [{ selector: 'yuv-tree', standalone: true, imports: [CommonModule, TreeNodeComponent], providers: [TreeService], host: {
282
+ args: [{ selector: 'yuv-tree', standalone: true, imports: [TreeNodeComponent], providers: [TreeService], host: {
289
283
  class: 'yuv-tree',
290
- role: 'tree'
284
+ role: 'tree',
285
+ '[class.selectable]': 'selectable',
286
+ '[attr.tabindex]': 'tabindex',
287
+ '(keydown)': 'onKeydown($event)'
291
288
  }, template: "@for (node of tree().nodes; track node.id) {\n <yuv-tree-node tabindex=\"0\" [node]=\"node\"></yuv-tree-node>\n}\n", styles: [":host{--toggle-icon-size: 18px;--node-padding: var(--ymt-spacing-xs);--node-indent: var(--toggle-icon-size)}\n"] }]
292
- }], ctorParameters: () => [], propDecorators: { selectable: [{
293
- type: HostBinding,
294
- args: ['class.selectable']
295
- }], selectedNodes: [{
289
+ }], ctorParameters: () => [], propDecorators: { tree: [{ type: i0.Input, args: [{ isSignal: true, alias: "tree", required: true }] }], multiselect: [{ type: i0.Input, args: [{ isSignal: true, alias: "multiselect", required: false }] }], selectedNodes: [{
296
290
  type: Input
297
- }], tabindex: [{
298
- type: HostBinding,
299
- args: ['attr.tabindex']
300
- }], onKeydown: [{
301
- type: HostListener,
302
- args: ['keydown', ['$event']]
303
- }] } });
291
+ }], selectionChange: [{ type: i0.Output, args: ["selectionChange"] }] } });
304
292
 
305
293
  /**
306
294
  * Generated bundle index. Do not edit.