ngx-tethys 17.0.6 → 18.0.0-next.0

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 (489) hide show
  1. package/CHANGELOG.md +15 -0
  2. package/esm2022/action/action.component.mjs +3 -3
  3. package/esm2022/action/action.module.mjs +4 -4
  4. package/esm2022/action/actions.component.mjs +3 -3
  5. package/esm2022/affix/affix.component.mjs +3 -3
  6. package/esm2022/affix/affix.module.mjs +4 -4
  7. package/esm2022/alert/alert.component.mjs +3 -3
  8. package/esm2022/alert/alert.directive.mjs +3 -3
  9. package/esm2022/alert/alert.module.mjs +4 -4
  10. package/esm2022/anchor/anchor-link.component.mjs +3 -3
  11. package/esm2022/anchor/anchor.component.mjs +3 -3
  12. package/esm2022/anchor/anchor.module.mjs +4 -4
  13. package/esm2022/arrow-switcher/arrow-switcher.component.mjs +3 -3
  14. package/esm2022/arrow-switcher/module.mjs +4 -4
  15. package/esm2022/autocomplete/autocomplete.component.mjs +3 -3
  16. package/esm2022/autocomplete/autocomplete.trigger.directive.mjs +3 -3
  17. package/esm2022/autocomplete/module.mjs +4 -4
  18. package/esm2022/autocomplete/overlay/autocomplete-container.component.mjs +3 -3
  19. package/esm2022/autocomplete/overlay/autocomplete.service.mjs +3 -3
  20. package/esm2022/avatar/avatar-list/avatar-list.component.mjs +3 -3
  21. package/esm2022/avatar/avatar.component.mjs +3 -3
  22. package/esm2022/avatar/avatar.module.mjs +4 -4
  23. package/esm2022/avatar/avatar.pipe.mjs +9 -9
  24. package/esm2022/avatar/avatar.service.mjs +3 -3
  25. package/esm2022/back-top/back-top.component.mjs +3 -3
  26. package/esm2022/back-top/back-top.module.mjs +4 -4
  27. package/esm2022/badge/badge.component.mjs +3 -3
  28. package/esm2022/badge/badge.module.mjs +4 -4
  29. package/esm2022/breadcrumb/breadcrumb-item.component.mjs +3 -3
  30. package/esm2022/breadcrumb/breadcrumb.component.mjs +3 -3
  31. package/esm2022/breadcrumb/module.mjs +4 -4
  32. package/esm2022/button/button-group.component.mjs +3 -3
  33. package/esm2022/button/button-icon.component.mjs +3 -3
  34. package/esm2022/button/button.component.mjs +3 -3
  35. package/esm2022/button/button.module.mjs +4 -4
  36. package/esm2022/calendar/calendar-cells.mjs +6 -6
  37. package/esm2022/calendar/calendar-header.component.mjs +3 -3
  38. package/esm2022/calendar/calendar.component.mjs +3 -3
  39. package/esm2022/calendar/module.mjs +4 -4
  40. package/esm2022/card/card.component.mjs +3 -3
  41. package/esm2022/card/card.module.mjs +4 -4
  42. package/esm2022/card/content.component.mjs +3 -3
  43. package/esm2022/card/header.component.mjs +3 -3
  44. package/esm2022/carousel/carousel-item.directive.mjs +3 -3
  45. package/esm2022/carousel/carousel.component.mjs +3 -3
  46. package/esm2022/carousel/carousel.service.mjs +3 -3
  47. package/esm2022/carousel/module.mjs +4 -4
  48. package/esm2022/cascader/cascader-li.component.mjs +3 -3
  49. package/esm2022/cascader/cascader-search-option.component.mjs +3 -3
  50. package/esm2022/cascader/cascader.component.mjs +6 -6
  51. package/esm2022/cascader/cascader.service.mjs +3 -3
  52. package/esm2022/cascader/module.mjs +4 -4
  53. package/esm2022/checkbox/checkbox.component.mjs +3 -3
  54. package/esm2022/checkbox/module.mjs +4 -4
  55. package/esm2022/collapse/collapse-item.component.mjs +3 -3
  56. package/esm2022/collapse/collapse.component.mjs +3 -3
  57. package/esm2022/collapse/module.mjs +4 -4
  58. package/esm2022/color-picker/color-picker-custom-panel.component.mjs +3 -3
  59. package/esm2022/color-picker/color-picker-panel.component.mjs +3 -3
  60. package/esm2022/color-picker/color-picker.component.mjs +3 -3
  61. package/esm2022/color-picker/coordinates.directive.mjs +3 -3
  62. package/esm2022/color-picker/module.mjs +4 -4
  63. package/esm2022/color-picker/parts/alpha/alpha.component.mjs +3 -3
  64. package/esm2022/color-picker/parts/hue/hue.component.mjs +3 -3
  65. package/esm2022/color-picker/parts/indicator/indicator.component.mjs +3 -3
  66. package/esm2022/color-picker/parts/inputs/inputs.component.mjs +3 -3
  67. package/esm2022/color-picker/parts/saturation/saturation.component.mjs +3 -3
  68. package/esm2022/comment/comment-actions.directive.mjs +3 -3
  69. package/esm2022/comment/comment-content.directive.mjs +3 -3
  70. package/esm2022/comment/comment.component.mjs +3 -3
  71. package/esm2022/comment/comment.module.mjs +4 -4
  72. package/esm2022/copy/copy.directive.mjs +3 -3
  73. package/esm2022/copy/module.mjs +4 -4
  74. package/esm2022/core/click-positioner.mjs +3 -3
  75. package/esm2022/core/overlay/portal-directives.mjs +3 -3
  76. package/esm2022/core/scroll.mjs +3 -3
  77. package/esm2022/core/store/store.mjs +3 -3
  78. package/esm2022/core/translate.mjs +3 -3
  79. package/esm2022/core/update-host-class.service.mjs +3 -3
  80. package/esm2022/date-picker/abstract-picker.component.mjs +3 -3
  81. package/esm2022/date-picker/abstract-picker.directive.mjs +3 -3
  82. package/esm2022/date-picker/base-picker.component.mjs +3 -3
  83. package/esm2022/date-picker/date-helper.service.mjs +3 -3
  84. package/esm2022/date-picker/date-picker.component.mjs +3 -3
  85. package/esm2022/date-picker/date-picker.directive.mjs +3 -3
  86. package/esm2022/date-picker/date-picker.module.mjs +4 -4
  87. package/esm2022/date-picker/date-picker.service.mjs +3 -3
  88. package/esm2022/date-picker/lib/calendar/calendar-footer.component.mjs +3 -3
  89. package/esm2022/date-picker/lib/calendar/calendar-header.component.mjs +3 -3
  90. package/esm2022/date-picker/lib/calendar/calendar-table.component.mjs +3 -3
  91. package/esm2022/date-picker/lib/date/date-header.component.mjs +3 -3
  92. package/esm2022/date-picker/lib/date/date-table-cell.component.mjs +3 -3
  93. package/esm2022/date-picker/lib/date/date-table.component.mjs +3 -3
  94. package/esm2022/date-picker/lib/date-carousel/date-carousel.component.mjs +3 -3
  95. package/esm2022/date-picker/lib/decade/decade-header.component.mjs +3 -3
  96. package/esm2022/date-picker/lib/decade/decade-table.component.mjs +3 -3
  97. package/esm2022/date-picker/lib/lib-packer.module.mjs +4 -4
  98. package/esm2022/date-picker/lib/month/month-header.component.mjs +3 -3
  99. package/esm2022/date-picker/lib/month/month-table.component.mjs +3 -3
  100. package/esm2022/date-picker/lib/popups/date-popup.component.mjs +3 -3
  101. package/esm2022/date-picker/lib/popups/inner-popup.component.mjs +3 -3
  102. package/esm2022/date-picker/lib/quarter/quarter-table.component.mjs +3 -3
  103. package/esm2022/date-picker/lib/year/year-header.component.mjs +3 -3
  104. package/esm2022/date-picker/lib/year/year-table.component.mjs +3 -3
  105. package/esm2022/date-picker/month-picker.component.mjs +3 -3
  106. package/esm2022/date-picker/picker.component.mjs +3 -3
  107. package/esm2022/date-picker/picker.pipes.mjs +12 -12
  108. package/esm2022/date-picker/picker.validators.mjs +6 -6
  109. package/esm2022/date-picker/quarter-picker.component.mjs +3 -3
  110. package/esm2022/date-picker/range-picker.component.mjs +3 -3
  111. package/esm2022/date-picker/range-picker.directive.mjs +3 -3
  112. package/esm2022/date-picker/week-picker.component.mjs +3 -3
  113. package/esm2022/date-picker/year-picker.component.mjs +3 -3
  114. package/esm2022/date-range/date-range.component.mjs +3 -3
  115. package/esm2022/date-range/module.mjs +4 -4
  116. package/esm2022/date-range/optional-dates/optional-dates.component.mjs +3 -3
  117. package/esm2022/dialog/body/dialog-body.component.mjs +3 -3
  118. package/esm2022/dialog/confirm/confirm.component.mjs +3 -3
  119. package/esm2022/dialog/dialog-container.component.mjs +3 -3
  120. package/esm2022/dialog/dialog.module.mjs +4 -4
  121. package/esm2022/dialog/dialog.service.mjs +3 -3
  122. package/esm2022/dialog/footer/dialog-footer.component.mjs +3 -3
  123. package/esm2022/dialog/header/dialog-header.component.mjs +3 -3
  124. package/esm2022/divider/divider.component.mjs +3 -3
  125. package/esm2022/divider/divider.module.mjs +4 -4
  126. package/esm2022/dot/dot.component.mjs +3 -3
  127. package/esm2022/dot/dot.module.mjs +4 -4
  128. package/esm2022/drag-drop/drag-content.directive.mjs +3 -3
  129. package/esm2022/drag-drop/drag-drop.service.mjs +3 -3
  130. package/esm2022/drag-drop/drag-handle.directive.mjs +3 -3
  131. package/esm2022/drag-drop/drag.directive.mjs +3 -3
  132. package/esm2022/drag-drop/drop-container.directive.mjs +3 -3
  133. package/esm2022/drag-drop/module.mjs +4 -4
  134. package/esm2022/dropdown/dropdown-active.directive.mjs +3 -3
  135. package/esm2022/dropdown/dropdown-menu-item.directive.mjs +21 -21
  136. package/esm2022/dropdown/dropdown-menu.component.mjs +12 -12
  137. package/esm2022/dropdown/dropdown-submenu.component.mjs +3 -3
  138. package/esm2022/dropdown/dropdown.directive.mjs +3 -3
  139. package/esm2022/dropdown/module.mjs +4 -4
  140. package/esm2022/empty/empty.component.mjs +3 -3
  141. package/esm2022/empty/empty.config.mjs +3 -3
  142. package/esm2022/empty/empty.module.mjs +4 -4
  143. package/esm2022/flexible-text/flexible-text.component.mjs +3 -3
  144. package/esm2022/flexible-text/flexible-text.module.mjs +4 -4
  145. package/esm2022/form/form-group-error/form-group-error.component.mjs +3 -3
  146. package/esm2022/form/form-group-label.directive.mjs +3 -3
  147. package/esm2022/form/form-group.component.mjs +3 -3
  148. package/esm2022/form/form-submit.directive.mjs +3 -3
  149. package/esm2022/form/form-validator-loader.mjs +3 -3
  150. package/esm2022/form/form-validator.service.mjs +3 -3
  151. package/esm2022/form/form.directive.mjs +3 -3
  152. package/esm2022/form/from-group-footer/form-group-footer.component.mjs +3 -3
  153. package/esm2022/form/module.mjs +4 -4
  154. package/esm2022/form/validator/confirm-validator.directive.mjs +3 -3
  155. package/esm2022/form/validator/max-validator.directive.mjs +3 -3
  156. package/esm2022/form/validator/min-validator.directive.mjs +3 -3
  157. package/esm2022/form/validator/unique-validator.directive.mjs +3 -3
  158. package/esm2022/fullscreen/fullscreen-launch.directive.mjs +3 -3
  159. package/esm2022/fullscreen/fullscreen.component.mjs +3 -3
  160. package/esm2022/fullscreen/fullscreen.module.mjs +4 -4
  161. package/esm2022/fullscreen/fullscreen.service.mjs +3 -3
  162. package/esm2022/grid/flex.mjs +12 -12
  163. package/esm2022/grid/module.mjs +4 -4
  164. package/esm2022/grid/thy-col.directive.mjs +3 -3
  165. package/esm2022/grid/thy-grid-item.component.mjs +3 -3
  166. package/esm2022/grid/thy-grid.component.mjs +6 -6
  167. package/esm2022/grid/thy-row.directive.mjs +3 -3
  168. package/esm2022/guider/guider-hint/guider-hint.component.mjs +3 -3
  169. package/esm2022/guider/guider-manager.mjs +3 -3
  170. package/esm2022/guider/guider.directive.mjs +3 -3
  171. package/esm2022/guider/guider.module.mjs +4 -4
  172. package/esm2022/guider/guider.service.mjs +3 -3
  173. package/esm2022/icon/icon-registry.mjs +3 -3
  174. package/esm2022/icon/icon.component.mjs +3 -3
  175. package/esm2022/icon/icon.module.mjs +9 -8
  176. package/esm2022/image/image-group.component.mjs +3 -3
  177. package/esm2022/image/image.directive.mjs +3 -3
  178. package/esm2022/image/image.service.mjs +3 -3
  179. package/esm2022/image/module.mjs +4 -4
  180. package/esm2022/image/preview/image-preview.component.mjs +3 -3
  181. package/esm2022/input/input-count.component.mjs +3 -3
  182. package/esm2022/input/input-group.component.mjs +3 -3
  183. package/esm2022/input/input-search.component.mjs +3 -3
  184. package/esm2022/input/input.component.mjs +3 -3
  185. package/esm2022/input/input.directive.mjs +3 -3
  186. package/esm2022/input/module.mjs +4 -4
  187. package/esm2022/input-number/input-number.component.mjs +3 -3
  188. package/esm2022/input-number/module.mjs +4 -4
  189. package/esm2022/layout/content-main.component.mjs +6 -6
  190. package/esm2022/layout/content-section.component.mjs +6 -6
  191. package/esm2022/layout/content.component.mjs +6 -6
  192. package/esm2022/layout/header.component.mjs +6 -6
  193. package/esm2022/layout/layout.component.mjs +6 -6
  194. package/esm2022/layout/layout.module.mjs +4 -4
  195. package/esm2022/layout/sidebar-content.component.mjs +6 -6
  196. package/esm2022/layout/sidebar-footer.component.mjs +6 -6
  197. package/esm2022/layout/sidebar-header.component.mjs +6 -6
  198. package/esm2022/layout/sidebar.component.mjs +6 -6
  199. package/esm2022/list/list-item-meta.component.mjs +3 -3
  200. package/esm2022/list/list-item.component.mjs +3 -3
  201. package/esm2022/list/list.component.mjs +3 -3
  202. package/esm2022/list/list.module.mjs +4 -4
  203. package/esm2022/list/selection/selection-list.mjs +3 -3
  204. package/esm2022/loading/loading.component.mjs +3 -3
  205. package/esm2022/loading/loading.module.mjs +4 -4
  206. package/esm2022/mention/mention.directive.mjs +3 -3
  207. package/esm2022/mention/mention.module.mjs +4 -4
  208. package/esm2022/mention/suggestions/suggestions.component.mjs +3 -3
  209. package/esm2022/menu/divider/menu-divider.component.mjs +3 -3
  210. package/esm2022/menu/group/menu-group.component.mjs +3 -3
  211. package/esm2022/menu/item/action/menu-item-action.component.mjs +3 -3
  212. package/esm2022/menu/item/icon/menu-item-icon.component.mjs +3 -3
  213. package/esm2022/menu/item/menu-item.component.mjs +3 -3
  214. package/esm2022/menu/item/name/menu-item-name.component.mjs +3 -3
  215. package/esm2022/menu/menu.component.mjs +3 -3
  216. package/esm2022/menu/menu.module.mjs +4 -4
  217. package/esm2022/message/abstract/abstract-message-container.component.mjs +3 -3
  218. package/esm2022/message/abstract/abstract-message.component.mjs +3 -3
  219. package/esm2022/message/message-container.component.mjs +3 -3
  220. package/esm2022/message/message-queue.service.mjs +3 -3
  221. package/esm2022/message/message.component.mjs +3 -3
  222. package/esm2022/message/message.service.mjs +3 -3
  223. package/esm2022/message/module.mjs +4 -4
  224. package/esm2022/nav/icon-nav/icon-nav-link.directive.mjs +3 -3
  225. package/esm2022/nav/icon-nav/icon-nav.component.mjs +3 -3
  226. package/esm2022/nav/nav-ink-bar.directive.mjs +3 -3
  227. package/esm2022/nav/nav-item.directive.mjs +3 -3
  228. package/esm2022/nav/nav.component.mjs +3 -3
  229. package/esm2022/nav/nav.module.mjs +4 -4
  230. package/esm2022/nav/nav.pipe.mjs +3 -3
  231. package/esm2022/notify/module.mjs +4 -4
  232. package/esm2022/notify/notify-container.component.mjs +3 -3
  233. package/esm2022/notify/notify-queue.service.mjs +3 -3
  234. package/esm2022/notify/notify.component.mjs +3 -3
  235. package/esm2022/notify/notify.service.mjs +3 -3
  236. package/esm2022/pagination/pagination.component.mjs +3 -3
  237. package/esm2022/pagination/pagination.module.mjs +4 -4
  238. package/esm2022/pagination/pagination.pipe.mjs +3 -3
  239. package/esm2022/popover/body/popover-body.component.mjs +3 -3
  240. package/esm2022/popover/header/popover-header.component.mjs +3 -3
  241. package/esm2022/popover/module.mjs +4 -4
  242. package/esm2022/popover/popover-container.component.mjs +3 -3
  243. package/esm2022/popover/popover.directive.mjs +3 -3
  244. package/esm2022/popover/popover.service.mjs +3 -3
  245. package/esm2022/progress/progress-circle.component.mjs +3 -3
  246. package/esm2022/progress/progress-strip.component.mjs +3 -3
  247. package/esm2022/progress/progress.component.mjs +3 -3
  248. package/esm2022/progress/progress.module.mjs +4 -4
  249. package/esm2022/property/module.mjs +4 -4
  250. package/esm2022/property/properties.component.mjs +3 -3
  251. package/esm2022/property/property-item.component.mjs +3 -3
  252. package/esm2022/property-operation/group/property-operation-group.component.mjs +3 -3
  253. package/esm2022/property-operation/module.mjs +4 -4
  254. package/esm2022/property-operation/property-operation.component.mjs +3 -3
  255. package/esm2022/radio/button/radio-button.component.mjs +3 -3
  256. package/esm2022/radio/group/radio-group.component.mjs +3 -3
  257. package/esm2022/radio/module.mjs +4 -4
  258. package/esm2022/radio/radio.component.mjs +3 -3
  259. package/esm2022/rate/module.mjs +4 -4
  260. package/esm2022/rate/rate-item.component.mjs +3 -3
  261. package/esm2022/rate/rate.component.mjs +3 -3
  262. package/esm2022/resizable/module.mjs +4 -4
  263. package/esm2022/resizable/resizable.directive.mjs +3 -3
  264. package/esm2022/resizable/resizable.service.mjs +3 -3
  265. package/esm2022/resizable/resize-handle.component.mjs +3 -3
  266. package/esm2022/resizable/resize-handles.component.mjs +3 -3
  267. package/esm2022/result/result.component.mjs +3 -3
  268. package/esm2022/result/result.module.mjs +4 -4
  269. package/esm2022/segment/segment-item.component.mjs +3 -3
  270. package/esm2022/segment/segment.component.mjs +3 -3
  271. package/esm2022/segment/segment.module.mjs +4 -4
  272. package/esm2022/select/custom-select/custom-select.component.mjs +3 -3
  273. package/esm2022/select/module.mjs +4 -4
  274. package/esm2022/select/native-select/native-select.component.mjs +3 -3
  275. package/esm2022/shared/base-form-check.component.mjs +3 -3
  276. package/esm2022/shared/directives/string-or-template-outlet.directive.mjs +3 -3
  277. package/esm2022/shared/directives/thy-autofocus.directive.mjs +3 -3
  278. package/esm2022/shared/directives/thy-contextmenu.directive.mjs +3 -3
  279. package/esm2022/shared/directives/thy-ctrl-enter.directive.mjs +3 -3
  280. package/esm2022/shared/directives/thy-drag-drop.directive.mjs +3 -3
  281. package/esm2022/shared/directives/thy-enter.directive.mjs +3 -3
  282. package/esm2022/shared/directives/thy-scroll.directive.mjs +3 -3
  283. package/esm2022/shared/directives/thy-show.mjs +3 -3
  284. package/esm2022/shared/directives/thy-stop-propagation.directive.mjs +3 -3
  285. package/esm2022/shared/directives/view-outlet.directive.mjs +3 -3
  286. package/esm2022/shared/ng-transclude.directive.mjs +3 -3
  287. package/esm2022/shared/option/group/option-group.component.mjs +3 -3
  288. package/esm2022/shared/option/list-option/list-option.component.mjs +3 -3
  289. package/esm2022/shared/option/module.mjs +4 -4
  290. package/esm2022/shared/option/option-group.component.mjs +3 -3
  291. package/esm2022/shared/option/option.component.mjs +3 -3
  292. package/esm2022/shared/option/options-container.component.mjs +3 -3
  293. package/esm2022/shared/select/module.mjs +4 -4
  294. package/esm2022/shared/select/select-control/select-control.component.mjs +3 -3
  295. package/esm2022/shared/shared.module.mjs +4 -4
  296. package/esm2022/skeleton/module.mjs +4 -4
  297. package/esm2022/skeleton/skeleton-circle.component.mjs +3 -3
  298. package/esm2022/skeleton/skeleton-rectangle.component.mjs +3 -3
  299. package/esm2022/skeleton/skeleton.component.mjs +3 -3
  300. package/esm2022/skeleton/stylized/bullet-list.component.mjs +3 -3
  301. package/esm2022/skeleton/stylized/list.component.mjs +3 -3
  302. package/esm2022/skeleton/stylized/paragraph.component.mjs +3 -3
  303. package/esm2022/slide/drawer/drawer-container.directive.mjs +3 -3
  304. package/esm2022/slide/slide-body/slide-body-section.component.mjs +3 -3
  305. package/esm2022/slide/slide-body/slide-body.component.mjs +3 -3
  306. package/esm2022/slide/slide-container.component.mjs +3 -3
  307. package/esm2022/slide/slide-footer/slide-footer.component.mjs +3 -3
  308. package/esm2022/slide/slide-header/slide-header.component.mjs +3 -3
  309. package/esm2022/slide/slide-layout/slide-layout.component.mjs +3 -3
  310. package/esm2022/slide/slide-ref.service.mjs +3 -3
  311. package/esm2022/slide/slide.module.mjs +4 -4
  312. package/esm2022/slide/slide.service.mjs +3 -3
  313. package/esm2022/slider/slider.component.mjs +3 -3
  314. package/esm2022/slider/slider.module.mjs +4 -4
  315. package/esm2022/space/space.component.mjs +6 -6
  316. package/esm2022/space/space.module.mjs +4 -4
  317. package/esm2022/statistic/statistic.component.mjs +3 -3
  318. package/esm2022/statistic/statistic.module.mjs +4 -4
  319. package/esm2022/stepper/step-header.component.mjs +3 -3
  320. package/esm2022/stepper/step.component.mjs +3 -3
  321. package/esm2022/stepper/stepper-button.directive.mjs +6 -6
  322. package/esm2022/stepper/stepper.component.mjs +3 -3
  323. package/esm2022/stepper/stepper.module.mjs +4 -4
  324. package/esm2022/strength/strength.component.mjs +3 -3
  325. package/esm2022/strength/strength.module.mjs +4 -4
  326. package/esm2022/switch/switch.component.mjs +3 -3
  327. package/esm2022/switch/switch.module.mjs +4 -4
  328. package/esm2022/table/pipes/drag.pipe.mjs +3 -3
  329. package/esm2022/table/pipes/table.pipe.mjs +3 -3
  330. package/esm2022/table/table-column.component.mjs +3 -3
  331. package/esm2022/table/table-skeleton.component.mjs +3 -3
  332. package/esm2022/table/table.component.mjs +3 -3
  333. package/esm2022/table/table.module.mjs +4 -4
  334. package/esm2022/tabs/tab-content.component.mjs +3 -3
  335. package/esm2022/tabs/tab.component.mjs +3 -3
  336. package/esm2022/tabs/tabs.component.mjs +3 -3
  337. package/esm2022/tabs/tabs.module.mjs +4 -4
  338. package/esm2022/tag/tag.component.mjs +3 -3
  339. package/esm2022/tag/tag.module.mjs +4 -4
  340. package/esm2022/tag/tags.component.mjs +3 -3
  341. package/esm2022/time-picker/inner/inner-time-picker.component.mjs +3 -3
  342. package/esm2022/time-picker/inner/inner-time-picker.config.mjs +3 -3
  343. package/esm2022/time-picker/inner/inner-time-picker.store.mjs +3 -3
  344. package/esm2022/time-picker/time-picker-panel.component.mjs +3 -3
  345. package/esm2022/time-picker/time-picker.component.mjs +3 -3
  346. package/esm2022/time-picker/time-picker.module.mjs +4 -4
  347. package/esm2022/timeline/timeline-item.component.mjs +3 -3
  348. package/esm2022/timeline/timeline.component.mjs +3 -3
  349. package/esm2022/timeline/timeline.module.mjs +4 -4
  350. package/esm2022/timeline/timeline.service.mjs +3 -3
  351. package/esm2022/tooltip/tooltip.component.mjs +3 -3
  352. package/esm2022/tooltip/tooltip.directive.mjs +3 -3
  353. package/esm2022/tooltip/tooltip.module.mjs +4 -4
  354. package/esm2022/tooltip/tooltip.service.mjs +3 -3
  355. package/esm2022/transfer/transfer-list.component.mjs +3 -3
  356. package/esm2022/transfer/transfer.component.mjs +3 -3
  357. package/esm2022/transfer/transfer.module.mjs +4 -4
  358. package/esm2022/tree/tree-node.component.mjs +3 -3
  359. package/esm2022/tree/tree.component.mjs +3 -3
  360. package/esm2022/tree/tree.module.mjs +4 -4
  361. package/esm2022/tree/tree.pipe.mjs +3 -3
  362. package/esm2022/tree/tree.service.mjs +3 -3
  363. package/esm2022/tree-select/module.mjs +4 -4
  364. package/esm2022/tree-select/tree-select.component.mjs +6 -6
  365. package/esm2022/typography/bg-color.directive.mjs +3 -3
  366. package/esm2022/typography/module.mjs +4 -4
  367. package/esm2022/typography/text/text.component.mjs +3 -3
  368. package/esm2022/typography/text-color.directive.mjs +3 -3
  369. package/esm2022/upload/file-drop.directive.mjs +3 -3
  370. package/esm2022/upload/file-select-base.mjs +3 -3
  371. package/esm2022/upload/file-select.component.mjs +3 -3
  372. package/esm2022/upload/module.mjs +9 -9
  373. package/esm2022/upload/upload.service.mjs +3 -3
  374. package/esm2022/util/helpers/helpers.mjs +2 -2
  375. package/esm2022/version.mjs +2 -2
  376. package/esm2022/vote/vote.component.mjs +3 -3
  377. package/esm2022/vote/vote.module.mjs +4 -4
  378. package/esm2022/watermark/watermark.directive.mjs +3 -3
  379. package/esm2022/watermark/watermark.module.mjs +4 -4
  380. package/fesm2022/ngx-tethys-action.mjs +10 -10
  381. package/fesm2022/ngx-tethys-affix.mjs +7 -7
  382. package/fesm2022/ngx-tethys-alert.mjs +10 -10
  383. package/fesm2022/ngx-tethys-anchor.mjs +10 -10
  384. package/fesm2022/ngx-tethys-arrow-switcher.mjs +7 -7
  385. package/fesm2022/ngx-tethys-autocomplete.mjs +16 -16
  386. package/fesm2022/ngx-tethys-avatar.mjs +22 -22
  387. package/fesm2022/ngx-tethys-back-top.mjs +7 -7
  388. package/fesm2022/ngx-tethys-badge.mjs +7 -7
  389. package/fesm2022/ngx-tethys-breadcrumb.mjs +10 -10
  390. package/fesm2022/ngx-tethys-button.mjs +13 -13
  391. package/fesm2022/ngx-tethys-calendar.mjs +16 -16
  392. package/fesm2022/ngx-tethys-card.mjs +13 -13
  393. package/fesm2022/ngx-tethys-carousel.mjs +13 -13
  394. package/fesm2022/ngx-tethys-cascader.mjs +18 -18
  395. package/fesm2022/ngx-tethys-cascader.mjs.map +1 -1
  396. package/fesm2022/ngx-tethys-checkbox.mjs +7 -7
  397. package/fesm2022/ngx-tethys-collapse.mjs +10 -10
  398. package/fesm2022/ngx-tethys-color-picker.mjs +31 -31
  399. package/fesm2022/ngx-tethys-comment.mjs +13 -13
  400. package/fesm2022/ngx-tethys-copy.mjs +7 -7
  401. package/fesm2022/ngx-tethys-core.mjs +18 -18
  402. package/fesm2022/ngx-tethys-date-picker.mjs +116 -116
  403. package/fesm2022/ngx-tethys-date-range.mjs +10 -10
  404. package/fesm2022/ngx-tethys-dialog.mjs +22 -22
  405. package/fesm2022/ngx-tethys-divider.mjs +7 -7
  406. package/fesm2022/ngx-tethys-dot.mjs +7 -7
  407. package/fesm2022/ngx-tethys-drag-drop.mjs +19 -19
  408. package/fesm2022/ngx-tethys-dropdown.mjs +46 -46
  409. package/fesm2022/ngx-tethys-empty.mjs +10 -10
  410. package/fesm2022/ngx-tethys-flexible-text.mjs +7 -7
  411. package/fesm2022/ngx-tethys-form.mjs +40 -40
  412. package/fesm2022/ngx-tethys-fullscreen.mjs +13 -13
  413. package/fesm2022/ngx-tethys-grid.mjs +31 -31
  414. package/fesm2022/ngx-tethys-guider.mjs +16 -16
  415. package/fesm2022/ngx-tethys-icon.mjs +14 -13
  416. package/fesm2022/ngx-tethys-icon.mjs.map +1 -1
  417. package/fesm2022/ngx-tethys-image.mjs +16 -16
  418. package/fesm2022/ngx-tethys-input-number.mjs +7 -7
  419. package/fesm2022/ngx-tethys-input.mjs +19 -19
  420. package/fesm2022/ngx-tethys-layout.mjs +58 -58
  421. package/fesm2022/ngx-tethys-list.mjs +16 -16
  422. package/fesm2022/ngx-tethys-loading.mjs +7 -7
  423. package/fesm2022/ngx-tethys-mention.mjs +10 -10
  424. package/fesm2022/ngx-tethys-menu.mjs +25 -25
  425. package/fesm2022/ngx-tethys-message.mjs +22 -22
  426. package/fesm2022/ngx-tethys-nav.mjs +22 -22
  427. package/fesm2022/ngx-tethys-notify.mjs +16 -16
  428. package/fesm2022/ngx-tethys-pagination.mjs +10 -10
  429. package/fesm2022/ngx-tethys-popover.mjs +19 -19
  430. package/fesm2022/ngx-tethys-progress.mjs +13 -13
  431. package/fesm2022/ngx-tethys-property-operation.mjs +10 -10
  432. package/fesm2022/ngx-tethys-property.mjs +10 -10
  433. package/fesm2022/ngx-tethys-radio.mjs +13 -13
  434. package/fesm2022/ngx-tethys-rate.mjs +10 -10
  435. package/fesm2022/ngx-tethys-resizable.mjs +16 -16
  436. package/fesm2022/ngx-tethys-result.mjs +7 -7
  437. package/fesm2022/ngx-tethys-segment.mjs +10 -10
  438. package/fesm2022/ngx-tethys-select.mjs +10 -10
  439. package/fesm2022/ngx-tethys-shared.mjs +66 -66
  440. package/fesm2022/ngx-tethys-skeleton.mjs +22 -22
  441. package/fesm2022/ngx-tethys-slide.mjs +31 -31
  442. package/fesm2022/ngx-tethys-slider.mjs +7 -7
  443. package/fesm2022/ngx-tethys-space.mjs +10 -10
  444. package/fesm2022/ngx-tethys-statistic.mjs +7 -7
  445. package/fesm2022/ngx-tethys-stepper.mjs +19 -19
  446. package/fesm2022/ngx-tethys-strength.mjs +7 -7
  447. package/fesm2022/ngx-tethys-switch.mjs +7 -7
  448. package/fesm2022/ngx-tethys-table.mjs +19 -19
  449. package/fesm2022/ngx-tethys-tabs.mjs +13 -13
  450. package/fesm2022/ngx-tethys-tag.mjs +10 -10
  451. package/fesm2022/ngx-tethys-time-picker.mjs +19 -19
  452. package/fesm2022/ngx-tethys-timeline.mjs +13 -13
  453. package/fesm2022/ngx-tethys-tooltip.mjs +13 -13
  454. package/fesm2022/ngx-tethys-transfer.mjs +10 -10
  455. package/fesm2022/ngx-tethys-tree-select.mjs +10 -10
  456. package/fesm2022/ngx-tethys-tree.mjs +16 -16
  457. package/fesm2022/ngx-tethys-typography.mjs +13 -13
  458. package/fesm2022/ngx-tethys-upload.mjs +20 -20
  459. package/fesm2022/ngx-tethys-upload.mjs.map +1 -1
  460. package/fesm2022/ngx-tethys-util.mjs +1 -1
  461. package/fesm2022/ngx-tethys-util.mjs.map +1 -1
  462. package/fesm2022/ngx-tethys-vote.mjs +7 -7
  463. package/fesm2022/ngx-tethys-watermark.mjs +7 -7
  464. package/fesm2022/ngx-tethys.mjs +1 -1
  465. package/fesm2022/ngx-tethys.mjs.map +1 -1
  466. package/icon/icon.module.d.ts +1 -2
  467. package/package.json +4 -4
  468. package/schematics/dependencies.js +1 -1
  469. package/schematics/ng-update/migration-collection.json +4 -4
  470. package/schematics/ng-update/{update-17 → update-18}/complete.d.ts +1 -1
  471. package/schematics/ng-update/update-18/complete.js +23 -0
  472. package/schematics/ng-update/{update-17 → update-18}/index.js +1 -1
  473. package/schematics/ng-update/update-18/index.spec.js +96 -0
  474. package/schematics/ng-update/update-18/update-data.js +872 -0
  475. package/schematics/testing/test-app.js +2 -2
  476. package/schematics/testing/test-project.js +2 -2
  477. package/schematics/version.d.ts +1 -1
  478. package/schematics/version.js +1 -1
  479. package/styles/bootstrap/_functions.scss +14 -14
  480. package/upload/module.d.ts +3 -4
  481. package/util/helpers/helpers.d.ts +1 -1
  482. package/schematics/ng-update/update-17/complete.js +0 -19
  483. package/schematics/ng-update/update-17/index.spec.js +0 -93
  484. package/schematics/ng-update/update-17/update-data.js +0 -871
  485. /package/schematics/ng-update/{update-17 → update-18}/class-name-migration.d.ts +0 -0
  486. /package/schematics/ng-update/{update-17 → update-18}/class-name-migration.js +0 -0
  487. /package/schematics/ng-update/{update-17 → update-18}/index.d.ts +0 -0
  488. /package/schematics/ng-update/{update-17 → update-18}/index.spec.d.ts +0 -0
  489. /package/schematics/ng-update/{update-17 → update-18}/update-data.d.ts +0 -0
@@ -6,7 +6,7 @@ import { finalize, share, map, tap, catchError, take } from 'rxjs/operators';
6
6
  import { useHostRenderer } from '@tethys/cdk/dom';
7
7
  import { of, forkJoin, throwError } from 'rxjs';
8
8
  import * as i2 from '@angular/common/http';
9
- import { HttpClientModule } from '@angular/common/http';
9
+ import { provideHttpClient, withInterceptorsFromDi } from '@angular/common/http';
10
10
  import * as i1 from '@angular/platform-browser';
11
11
  import { isString } from 'ngx-tethys/util';
12
12
 
@@ -340,10 +340,10 @@ class ThyIconRegistry {
340
340
  setIconMode(mode) {
341
341
  this.internalIconMode = mode;
342
342
  }
343
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyIconRegistry, deps: [{ token: i1.DomSanitizer }, { token: i2.HttpClient }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
344
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyIconRegistry, providedIn: 'root' }); }
343
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyIconRegistry, deps: [{ token: i1.DomSanitizer }, { token: i2.HttpClient }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
344
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyIconRegistry, providedIn: 'root' }); }
345
345
  }
346
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyIconRegistry, decorators: [{
346
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyIconRegistry, decorators: [{
347
347
  type: Injectable,
348
348
  args: [{
349
349
  providedIn: 'root'
@@ -503,10 +503,10 @@ class ThyIcon {
503
503
  const titleElement = svg.querySelector('title');
504
504
  titleElement && titleElement.remove();
505
505
  }
506
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyIcon, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: ThyIconRegistry }], target: i0.ɵɵFactoryTarget.Component }); }
507
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.2.3", type: ThyIcon, isStandalone: true, selector: "thy-icon, [thy-icon]", inputs: { iconType: ["thyIconType", "iconType"], iconTwotoneColor: ["thyTwotoneColor", "iconTwotoneColor"], iconName: ["thyIconName", "iconName"], iconRotate: ["thyIconRotate", "iconRotate", numberAttribute], iconSet: ["thyIconSet", "iconSet"], iconLegging: ["thyIconLegging", "iconLegging", booleanAttribute], iconLinearGradient: ["thyIconLinearGradient", "iconLinearGradient", booleanAttribute] }, host: { properties: { "class.thy-icon-legging": "this.iconLegging" }, classAttribute: "thy-icon" }, usesOnChanges: true, ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
506
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyIcon, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: ThyIconRegistry }], target: i0.ɵɵFactoryTarget.Component }); }
507
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.0", type: ThyIcon, isStandalone: true, selector: "thy-icon, [thy-icon]", inputs: { iconType: ["thyIconType", "iconType"], iconTwotoneColor: ["thyTwotoneColor", "iconTwotoneColor"], iconName: ["thyIconName", "iconName"], iconRotate: ["thyIconRotate", "iconRotate", numberAttribute], iconSet: ["thyIconSet", "iconSet"], iconLegging: ["thyIconLegging", "iconLegging", booleanAttribute], iconLinearGradient: ["thyIconLinearGradient", "iconLinearGradient", booleanAttribute] }, host: { properties: { "class.thy-icon-legging": "this.iconLegging" }, classAttribute: "thy-icon" }, usesOnChanges: true, ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
508
508
  }
509
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyIcon, decorators: [{
509
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyIcon, decorators: [{
510
510
  type: Component,
511
511
  args: [{
512
512
  selector: 'thy-icon, [thy-icon]',
@@ -545,16 +545,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
545
545
  }] } });
546
546
 
547
547
  class ThyIconModule {
548
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyIconModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
549
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.2.3", ngImport: i0, type: ThyIconModule, imports: [ThyIcon, CommonModule, FormsModule, HttpClientModule], exports: [ThyIcon] }); }
550
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyIconModule, imports: [CommonModule, FormsModule, HttpClientModule] }); }
548
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyIconModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
549
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.0", ngImport: i0, type: ThyIconModule, imports: [ThyIcon, CommonModule, FormsModule], exports: [ThyIcon] }); }
550
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyIconModule, providers: [provideHttpClient(withInterceptorsFromDi())], imports: [CommonModule, FormsModule] }); }
551
551
  }
552
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyIconModule, decorators: [{
552
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyIconModule, decorators: [{
553
553
  type: NgModule,
554
554
  args: [{
555
555
  declarations: [],
556
- imports: [ThyIcon, CommonModule, FormsModule, HttpClientModule],
557
- exports: [ThyIcon]
556
+ exports: [ThyIcon],
557
+ imports: [ThyIcon, CommonModule, FormsModule],
558
+ providers: [provideHttpClient(withInterceptorsFromDi())]
558
559
  }]
559
560
  }] });
560
561
 
@@ -1 +1 @@
1
- {"version":3,"file":"ngx-tethys-icon.mjs","sources":["../../../src/icon/config.ts","../../../src/icon/icon-registry.ts","../../../src/icon/icon.component.ts","../../../src/icon/icon.module.ts","../../../src/icon/ngx-tethys-icon.ts"],"sourcesContent":["let printErrorWhenNotFound = true;\n\nexport function setPrintErrorWhenIconNotFound(value: boolean) {\n printErrorWhenNotFound = value;\n}\n\nexport function getWhetherPrintErrorWhenIconNotFound() {\n return printErrorWhenNotFound;\n}\n","import { forkJoin, Observable, of, throwError } from 'rxjs';\nimport { catchError, finalize, map, share, tap } from 'rxjs/operators';\n\nimport { DOCUMENT } from '@angular/common';\nimport { HttpClient, HttpErrorResponse } from '@angular/common/http';\nimport { Inject, Injectable, SecurityContext } from '@angular/core';\nimport { DomSanitizer, SafeHtml, SafeResourceUrl } from '@angular/platform-browser';\nimport { isString } from 'ngx-tethys/util';\n\nclass SvgIconConfig {\n url: SafeResourceUrl | null;\n svgElement: SVGElement | null;\n\n constructor(data: SafeResourceUrl | SVGElement) {\n // Note that we can't use `instanceof SVGElement` here,\n // because it'll break during server-side rendering.\n if (data && !!(data as any).nodeName) {\n this.svgElement = data as SVGElement;\n } else {\n this.url = data as SafeResourceUrl;\n }\n }\n}\n\nexport type IconMode = 'font' | 'svg';\n\nexport type SvgResourceUrl = SafeResourceUrl | string;\n\nexport type SvgHtml = SafeHtml | string;\n\n/**\n * @order 20\n */\n@Injectable({\n providedIn: 'root'\n})\nexport class ThyIconRegistry {\n private defaultFontSetClass = 'wt-icon';\n private internalIconMode: IconMode = 'svg';\n private svgIconConfigs = new Map<string, SvgIconConfig>();\n private svgIconSetConfigs = new Map<string, SvgIconConfig[]>();\n private inProgressUrlFetches = new Map<string, Observable<string>>();\n\n public get iconMode() {\n return this.internalIconMode;\n }\n\n constructor(private sanitizer: DomSanitizer, private httpClient: HttpClient, @Inject(DOCUMENT) private document: any) {}\n\n private getIconNameNotFoundError(iconName: string): Error {\n return Error(`Unable to find icon with the name \"${iconName}\"`);\n }\n\n private getIconFailedToSanitizeLiteralError(literal: SvgHtml): Error {\n return Error(\n `The literal provided to ThyIconRegistry was not trusted as safe HTML by ` +\n `Angular's DomSanitizer. Attempted literal was \"${literal}\".`\n );\n }\n\n private internalAddSvgIconSet(namespace: string, config: SvgIconConfig): this {\n const configNamespace = this.svgIconSetConfigs.get(namespace);\n\n if (configNamespace) {\n configNamespace.push(config);\n } else {\n this.svgIconSetConfigs.set(namespace, [config]);\n }\n\n return this;\n }\n\n private cloneSvg(svg: SVGElement): SVGElement {\n return svg.cloneNode(true) as SVGElement;\n }\n\n private fetchUrl(safeUrl: SafeResourceUrl | null): Observable<string> {\n if (safeUrl == null) {\n throw Error(`Cannot fetch icon from URL \"${safeUrl}\".`);\n }\n\n const url = this.sanitizer.sanitize(SecurityContext.RESOURCE_URL, safeUrl);\n\n if ((typeof ngDevMode === 'undefined' || ngDevMode) && !url) {\n throw new Error(\n `The URL provided to ThyIconRegistry was not trusted as a resource URL ` +\n `via Angular's DomSanitizer. Attempted URL was \"${url}\".`\n );\n }\n\n // Store in-progress fetches to avoid sending a duplicate request for a URL when there is\n // already a request in progress for that URL. It's necessary to call share() on the\n // Observable returned by http.get() so that multiple subscribers don't cause multiple XHRs.\n const inProgressFetch = this.inProgressUrlFetches.get(url);\n\n if (inProgressFetch) {\n return inProgressFetch;\n } else {\n // TODO(jelbourn): for some reason, the `finalize` operator \"loses\" the generic type on the\n // Observable. Figure out why and fix it.\n const req = this.httpClient.get(url, { responseType: 'text' }).pipe(\n finalize(() => this.inProgressUrlFetches.delete(url)),\n share()\n );\n\n this.inProgressUrlFetches.set(url, req);\n return req;\n }\n }\n\n private toSvgElement(element: Element): SVGElement {\n const svg = this.svgElementFromString('<svg></svg>');\n\n for (let i = 0; i < element.childNodes.length; i++) {\n if (element.childNodes[i].nodeType === this.document.ELEMENT_NODE) {\n svg.appendChild(element.childNodes[i].cloneNode(true));\n }\n }\n\n return svg;\n }\n\n private extractSvgIconFromIconSet(iconSet: SVGElement, iconName: string): SVGElement | null {\n // Use the `id=\"iconName\"` syntax in order to escape special\n // characters in the ID (versus using the #iconName syntax).\n const iconSource = iconSet.querySelector(`[id=\"${iconName}\"]`);\n\n if (!iconSource) {\n return null;\n }\n\n // Clone the element and remove the ID to prevent multiple elements from being added\n // to the page with the same ID.\n const iconElement = iconSource.cloneNode(true) as Element;\n iconElement.removeAttribute('id');\n\n // If the icon node is itself an <svg> node, clone and return it directly. If not, set it as\n // the content of a new <svg> node.\n if (iconElement.nodeName.toLowerCase() === 'svg') {\n return this.setSvgAttributes(iconElement as SVGElement);\n }\n\n // If the node is a <symbol>, it won't be rendered so we have to convert it into <svg>. Note\n // that the same could be achieved by referring to it via <use href=\"#id\">, however the <use>\n // tag is problematic on Firefox, because it needs to include the current page path.\n if (iconElement.nodeName.toLowerCase() === 'symbol') {\n return this.setSvgAttributes(this.toSvgElement(iconElement));\n }\n\n // createElement('SVG') doesn't work as expected; the DOM ends up with\n // the correct nodes, but the SVG content doesn't render. Instead we\n // have to create an empty SVG node using innerHTML and append its content.\n // Elements created using DOMParser.parseFromString have the same problem.\n // http://stackoverflow.com/questions/23003278/svg-innerhtml-in-firefox-can-not-display\n const svg = this.svgElementFromString('<svg></svg>');\n // Clone the node so we don't remove it from the parent icon set element.\n svg.appendChild(iconElement);\n\n return this.setSvgAttributes(svg);\n }\n\n private extractIconWithNameFromIconSetConfigs(iconName: string, iconSetConfigs: SvgIconConfig[]): SVGElement | null {\n // Iterate backwards, so icon sets added later have precedence.\n for (let i = iconSetConfigs.length - 1; i >= 0; i--) {\n const config = iconSetConfigs[i];\n if (config.svgElement) {\n const foundIcon = this.extractSvgIconFromIconSet(config.svgElement, iconName);\n if (foundIcon) {\n return foundIcon;\n }\n }\n }\n return null;\n }\n\n private svgElementFromString(str: string): SVGElement {\n const div = this.document.createElement('DIV');\n div.innerHTML = str;\n const svg = div.querySelector('svg') as SVGElement;\n\n if (!svg) {\n throw Error('<svg> tag not found');\n }\n\n return svg;\n }\n\n private setSvgAttributes(svg: SVGElement): SVGElement {\n svg.setAttribute('fit', '');\n svg.setAttribute('height', '1em');\n svg.setAttribute('width', '1em');\n svg.setAttribute('preserveAspectRatio', 'xMidYMid meet');\n svg.setAttribute('focusable', 'false'); // Disable IE11 default behavior to make SVGs focusable.\n return svg;\n }\n\n private createSvgElementForSingleIcon(responseText: string): SVGElement {\n const svg = this.svgElementFromString(responseText);\n this.setSvgAttributes(svg);\n return svg;\n }\n\n private loadSvgIconFromConfig(config: SvgIconConfig): Observable<SVGElement> {\n return this.fetchUrl(config.url).pipe(map(svgText => this.createSvgElementForSingleIcon(svgText)));\n }\n\n private loadSvgIconSetFromConfig(config: SvgIconConfig): Observable<SVGElement> {\n // If the SVG for this icon set has already been parsed, do nothing.\n if (config.svgElement) {\n return of(config.svgElement);\n }\n\n return this.fetchUrl(config.url).pipe(\n map(svgText => {\n // It is possible that the icon set was parsed and cached by an earlier request, so parsing\n // only needs to occur if the cache is yet unset.\n if (!config.svgElement) {\n config.svgElement = this.svgElementFromString(svgText);\n }\n\n return config.svgElement;\n })\n );\n }\n\n private getSvgFromConfig(config: SvgIconConfig): Observable<SVGElement> {\n if (config.svgElement) {\n // We already have the SVG element for this icon, return a copy.\n return of(this.cloneSvg(config.svgElement));\n } else {\n // Fetch the icon from the config's URL, cache it, and return a copy.\n return this.loadSvgIconFromConfig(config).pipe(\n tap(svg => (config.svgElement = svg)),\n map(svg => this.cloneSvg(svg))\n );\n }\n }\n\n private getSvgFromIconSetConfigs(name: string, iconSetConfigs: SvgIconConfig[]): Observable<SVGElement> {\n // For all the icon set SVG elements we've fetched, see if any contain an icon with the\n // requested name.\n const namedIcon = this.extractIconWithNameFromIconSetConfigs(name, iconSetConfigs);\n\n if (namedIcon) {\n // We could cache namedIcon in svgIconConfigs, but since we have to make a copy every\n // time anyway, there's probably not much advantage compared to just always extracting\n // it from the icon set.\n return of(namedIcon);\n }\n\n // Not found in any cached icon sets. If there are icon sets with URLs that we haven't\n // fetched, fetch them now and look for iconName in the results.\n const iconSetFetchRequests: Observable<SVGElement | null>[] = iconSetConfigs\n .filter(iconSetConfig => !iconSetConfig.svgElement)\n .map(iconSetConfig => {\n return this.loadSvgIconSetFromConfig(iconSetConfig).pipe(\n catchError((err: HttpErrorResponse): Observable<SVGElement | null> => {\n const url = this.sanitizer.sanitize(SecurityContext.RESOURCE_URL, iconSetConfig.url);\n\n // Swallow errors fetching individual URLs so the\n // combined Observable won't necessarily fail.\n console.error(`Loading icon set URL: ${url} failed: ${err.message}`);\n return of(null);\n })\n );\n });\n\n // Fetch all the icon set URLs. When the requests complete, every IconSet should have a\n // cached SVG element (unless the request failed), and we can check again for the icon.\n return forkJoin(iconSetFetchRequests).pipe(\n map(() => {\n const foundIcon = this.extractIconWithNameFromIconSetConfigs(name, iconSetConfigs);\n\n if (!foundIcon) {\n throw this.getIconNameNotFoundError(name);\n }\n\n return foundIcon;\n })\n );\n }\n\n private internalAddSvgIconConfig(namespace: string, iconName: string, config: SvgIconConfig): this {\n this.svgIconConfigs.set(this.buildIconKey(namespace, iconName), config);\n return this;\n }\n\n public buildIconKey(namespace: string, name: string) {\n return namespace + ':' + name;\n }\n\n public splitIconName(iconName: string): [string, string] {\n if (!iconName) {\n return ['', ''];\n }\n const parts = iconName.split(':');\n switch (parts.length) {\n case 1:\n return ['', parts[0]]; // Use default namespace.\n case 2:\n return <[string, string]>parts;\n default:\n throw Error(`Invalid icon name: \"${iconName}\"`);\n }\n }\n\n public addSvgIconSetInNamespace(namespace: string, url: SvgResourceUrl): this {\n url = isString(url) ? this.sanitizer.bypassSecurityTrustResourceUrl(url) : url;\n return this.internalAddSvgIconSet(namespace, new SvgIconConfig(url));\n }\n\n /**\n * 添加SVG图标集,添加到默认命名空间\n */\n public addSvgIconSet(url: SvgResourceUrl): this {\n return this.addSvgIconSetInNamespace('', url);\n }\n\n public addSvgIconSetLiteralInNamespace(namespace: string, literal: SafeHtml): this {\n const sanitizedLiteral = this.sanitizer.sanitize(SecurityContext.HTML, literal);\n\n if (!sanitizedLiteral) {\n throw this.getIconFailedToSanitizeLiteralError(literal);\n }\n\n const svgElement = this.svgElementFromString(sanitizedLiteral);\n return this.internalAddSvgIconSet(namespace, new SvgIconConfig(svgElement));\n }\n\n public addSvgIconSetLiteral(literal: SafeHtml): this {\n return this.addSvgIconSetLiteralInNamespace('', literal);\n }\n\n /**\n * @description.en-us Registers an icon by URL in the specified namespace.\n * @description 添加单个SVG图标到指定的命名空间\n * @param namespace Namespace in which the icon should be registered.\n * @param iconName Name under which the icon should be registered.\n * @param url\n */\n public addSvgIconInNamespace(namespace: string, iconName: string, url: SvgResourceUrl): this {\n url = isString(url) ? this.sanitizer.bypassSecurityTrustResourceUrl(url) : url;\n return this.internalAddSvgIconConfig(namespace, iconName, new SvgIconConfig(url));\n }\n\n /**\n * @description.en-us Registers an icon by URL in the default namespace.\n * @description 添加单个SVG图标\n * @param iconName Name under which the icon should be registered.\n * @param url\n */\n public addSvgIcon(iconName: string, url: SvgResourceUrl): this {\n return this.addSvgIconInNamespace('', iconName, url);\n }\n\n /**\n * @description.en-us Registers an icon using an HTML string in the default namespace.\n * @description 添加单个SVG图标字符串,直接传入 SVG HTML 字符串\n * @param iconName Name under which the icon should be registered.\n * @param literal SVG source of the icon.\n */\n public addSvgIconLiteral(iconName: string, literal: SvgHtml): this {\n return this.addSvgIconLiteralInNamespace('', iconName, literal);\n }\n\n /**\n * @description.en-us Registers an icon using an HTML string in the specified namespace.\n * @description 添加单个SVG图标字符串到指定的命名空间,直接传入 SVG HTML 字符串\n * @param namespace Namespace in which the icon should be registered.\n * @param iconName Name under which the icon should be registered.\n * @param literal SVG source of the icon.\n */\n public addSvgIconLiteralInNamespace(namespace: string, iconName: string, literal: SvgHtml): this {\n literal = isString(literal) ? this.sanitizer.bypassSecurityTrustHtml(literal) : literal;\n const sanitizedLiteral = this.sanitizer.sanitize(SecurityContext.HTML, literal);\n\n if (!sanitizedLiteral) {\n throw this.getIconFailedToSanitizeLiteralError(literal);\n }\n\n const svgElement = this.createSvgElementForSingleIcon(sanitizedLiteral);\n return this.internalAddSvgIconConfig(namespace, iconName, new SvgIconConfig(svgElement));\n }\n\n public getDefaultFontSetClass() {\n return this.defaultFontSetClass;\n }\n\n public getFontSetClassByAlias(fontSet: string) {\n return fontSet;\n }\n\n /**\n * 获取某个图标\n */\n public getSvgIcon(name: string, namespace: string = ''): Observable<SVGElement> {\n // Return (copy of) cached icon if possible.\n const key = this.buildIconKey(namespace, name);\n const config = this.svgIconConfigs.get(key);\n\n if (config) {\n return this.getSvgFromConfig(config);\n }\n\n // See if we have any icon sets registered for the namespace.\n const iconSetConfigs = this.svgIconSetConfigs.get(namespace);\n\n if (iconSetConfigs) {\n return this.getSvgFromIconSetConfigs(name, iconSetConfigs);\n }\n\n return throwError(this.getIconNameNotFoundError(key));\n }\n\n public setIconMode(mode: IconMode) {\n this.internalIconMode = mode;\n }\n}\n","import { take } from 'rxjs/operators';\nimport { useHostRenderer } from '@tethys/cdk/dom';\n\nimport {\n ChangeDetectionStrategy,\n Component,\n ElementRef,\n HostBinding,\n Input,\n OnChanges,\n OnInit,\n Renderer2,\n SimpleChanges,\n ViewEncapsulation,\n booleanAttribute,\n numberAttribute\n} from '@angular/core';\n\nimport { getWhetherPrintErrorWhenIconNotFound } from './config';\nimport { ThyIconRegistry } from './icon-registry';\n\nconst iconSuffixMap = {\n fill: 'fill',\n twotone: 'tt'\n};\n\n/**\n * 图标组件\n * @name thy-icon,[thy-icon]\n * @order 10\n */\n@Component({\n selector: 'thy-icon, [thy-icon]',\n template: '<ng-content></ng-content>',\n changeDetection: ChangeDetectionStrategy.OnPush,\n encapsulation: ViewEncapsulation.None,\n standalone: true,\n host: {\n class: 'thy-icon'\n }\n})\nexport class ThyIcon implements OnInit, OnChanges {\n private initialized = false;\n\n /**\n * 图标的类型\n * @type outline | fill | twotone\n */\n @Input('thyIconType') iconType: 'outline' | 'fill' | 'twotone' = 'outline';\n\n @Input('thyTwotoneColor') iconTwotoneColor: string;\n\n /**\n * 图标的名字\n */\n @Input('thyIconName') iconName: string;\n\n /**\n * 图标的旋转角度\n * @default 0\n */\n @Input({ alias: 'thyIconRotate', transform: numberAttribute }) iconRotate: number;\n\n @Input('thyIconSet') iconSet: string;\n\n /**\n * 图标打底色,镂空的图标,会透过颜色来\n * @default false\n */\n @HostBinding(`class.thy-icon-legging`)\n @Input({ alias: 'thyIconLegging', transform: booleanAttribute })\n iconLegging: boolean;\n\n @Input({ alias: 'thyIconLinearGradient', transform: booleanAttribute })\n iconLinearGradient: boolean;\n\n private hostRenderer = useHostRenderer();\n\n constructor(private render: Renderer2, private elementRef: ElementRef, private iconRegistry: ThyIconRegistry) {}\n\n ngOnInit() {\n this.updateClasses();\n this.initialized = true;\n }\n\n ngOnChanges(changes: SimpleChanges) {\n if (this.initialized) {\n if (\n changes['iconName'] ||\n changes['iconSet'] ||\n changes['iconTwotoneColor'] ||\n changes['iconType'] ||\n changes['iconLinearGradient']\n ) {\n this.updateClasses();\n } else if (changes['iconRotate']) {\n this.setStyleRotate();\n }\n }\n }\n\n private updateClasses() {\n const [namespace, iconName] = this.iconRegistry.splitIconName(this.iconName);\n if (iconName) {\n if (this.iconRegistry.iconMode === 'svg') {\n this.iconRegistry\n .getSvgIcon(this.buildIconNameByType(iconName), namespace)\n .pipe(take(1))\n .subscribe(\n svg => {\n this.setSvgElement(svg);\n },\n (error: Error) => {\n if (getWhetherPrintErrorWhenIconNotFound()) {\n console.error(`Error retrieving icon: ${error.message}`);\n }\n }\n );\n this.hostRenderer.updateClass([`thy-icon${namespace ? `-${namespace}` : ``}-${this.buildIconNameByType(iconName)}`]);\n } else {\n const fontSetClass = this.iconSet\n ? this.iconRegistry.getFontSetClassByAlias(this.iconSet)\n : this.iconRegistry.getDefaultFontSetClass();\n this.hostRenderer.updateClass([fontSetClass, `${fontSetClass}-${this.iconName}`]);\n }\n }\n }\n\n private setStyleRotate() {\n if (this.iconRotate !== undefined) {\n this.render.setStyle(this.elementRef.nativeElement.querySelector('svg'), 'transform', `rotate(${this.iconRotate}deg)`);\n }\n }\n\n //#region svg element\n\n private setSvgElement(svg: SVGElement) {\n this.clearSvgElement();\n\n // Workaround for IE11 and Edge ignoring `style` tags inside dynamically-created SVGs.\n // See: https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/10898469/\n // Do this before inserting the element into the DOM, in order to avoid a style recalculation.\n const styleTags = svg.querySelectorAll('style') as NodeListOf<HTMLStyleElement>;\n\n for (let i = 0; i < styleTags.length; i++) {\n styleTags[i].textContent += ' ';\n }\n\n if (this.iconType === 'twotone') {\n const allPaths = svg.querySelectorAll('path');\n if (allPaths.length > 1) {\n allPaths.forEach((child, index: number) => {\n if (child.getAttribute('id').includes('secondary-color')) {\n child.setAttribute('fill', this.iconTwotoneColor);\n }\n });\n }\n }\n\n // Note: we do this fix here, rather than the icon registry, because the\n // references have to point to the URL at the time that the icon was created.\n // if (this._location) {\n // const path = this._location.getPathname();\n // this._previousPath = path;\n // this._cacheChildrenWithExternalReferences(svg);\n // this._prependPathToReferences(path);\n // }\n if (this.iconLinearGradient) {\n this.setBaseUrl(svg);\n this.clearTitleElement(svg);\n }\n\n this.elementRef.nativeElement.appendChild(svg);\n this.setStyleRotate();\n }\n\n private clearSvgElement() {\n const layoutElement: HTMLElement = this.elementRef.nativeElement;\n let childCount = layoutElement.childNodes.length;\n\n // if (this._elementsWithExternalReferences) {\n // this._elementsWithExternalReferences.clear();\n // }\n\n // Remove existing non-element child nodes and SVGs, and add the new SVG element. Note that\n // we can't use innerHTML, because IE will throw if the element has a data binding.\n while (childCount--) {\n const child = layoutElement.childNodes[childCount];\n\n // 1 corresponds to Node.ELEMENT_NODE. We remove all non-element nodes in order to get rid\n // of any loose text nodes, as well as any SVG elements in order to remove any old icons.\n if (child.nodeType !== 1 || child.nodeName.toLowerCase() === 'svg') {\n layoutElement.removeChild(child);\n }\n }\n }\n\n //#endregion\n\n private buildIconNameByType(iconName: string) {\n if (this.iconType && ['fill', 'twotone'].indexOf(this.iconType) >= 0) {\n const suffix = iconSuffixMap[this.iconType];\n return iconName.includes(`-${suffix}`) ? iconName : `${iconName}-${suffix}`;\n } else {\n return iconName;\n }\n }\n\n /**\n * Support Safari SVG LinearGradient.\n * @param svg\n */\n private setBaseUrl(svg: SVGElement) {\n const styleElements = svg.querySelectorAll('style');\n styleElements.forEach((n: HTMLElement) => {\n if (n.style.cssText.includes('url')) {\n n.style.fill = n.style.fill.replace('url(\"', 'url(\"' + location.pathname);\n }\n if (n.style.cssText.includes('clip-path')) {\n n.style.clipPath = n.style.clipPath.replace('url(\"', 'url(\"' + location.pathname);\n }\n });\n }\n\n private clearTitleElement(svg: SVGElement) {\n const titleElement = svg.querySelector('title');\n titleElement && titleElement.remove();\n }\n}\n","import { NgModule } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { CommonModule } from '@angular/common';\nimport { ThyIcon } from './icon.component';\nimport { HttpClientModule } from '@angular/common/http';\n\n@NgModule({\n declarations: [],\n imports: [ThyIcon, CommonModule, FormsModule, HttpClientModule],\n exports: [ThyIcon]\n})\nexport class ThyIconModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":["i1.ThyIconRegistry"],"mappings":"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"}
1
+ {"version":3,"file":"ngx-tethys-icon.mjs","sources":["../../../src/icon/config.ts","../../../src/icon/icon-registry.ts","../../../src/icon/icon.component.ts","../../../src/icon/icon.module.ts","../../../src/icon/ngx-tethys-icon.ts"],"sourcesContent":["let printErrorWhenNotFound = true;\n\nexport function setPrintErrorWhenIconNotFound(value: boolean) {\n printErrorWhenNotFound = value;\n}\n\nexport function getWhetherPrintErrorWhenIconNotFound() {\n return printErrorWhenNotFound;\n}\n","import { forkJoin, Observable, of, throwError } from 'rxjs';\nimport { catchError, finalize, map, share, tap } from 'rxjs/operators';\n\nimport { DOCUMENT } from '@angular/common';\nimport { HttpClient, HttpErrorResponse } from '@angular/common/http';\nimport { Inject, Injectable, SecurityContext } from '@angular/core';\nimport { DomSanitizer, SafeHtml, SafeResourceUrl } from '@angular/platform-browser';\nimport { isString } from 'ngx-tethys/util';\n\nclass SvgIconConfig {\n url: SafeResourceUrl | null;\n svgElement: SVGElement | null;\n\n constructor(data: SafeResourceUrl | SVGElement) {\n // Note that we can't use `instanceof SVGElement` here,\n // because it'll break during server-side rendering.\n if (data && !!(data as any).nodeName) {\n this.svgElement = data as SVGElement;\n } else {\n this.url = data as SafeResourceUrl;\n }\n }\n}\n\nexport type IconMode = 'font' | 'svg';\n\nexport type SvgResourceUrl = SafeResourceUrl | string;\n\nexport type SvgHtml = SafeHtml | string;\n\n/**\n * @order 20\n */\n@Injectable({\n providedIn: 'root'\n})\nexport class ThyIconRegistry {\n private defaultFontSetClass = 'wt-icon';\n private internalIconMode: IconMode = 'svg';\n private svgIconConfigs = new Map<string, SvgIconConfig>();\n private svgIconSetConfigs = new Map<string, SvgIconConfig[]>();\n private inProgressUrlFetches = new Map<string, Observable<string>>();\n\n public get iconMode() {\n return this.internalIconMode;\n }\n\n constructor(private sanitizer: DomSanitizer, private httpClient: HttpClient, @Inject(DOCUMENT) private document: any) {}\n\n private getIconNameNotFoundError(iconName: string): Error {\n return Error(`Unable to find icon with the name \"${iconName}\"`);\n }\n\n private getIconFailedToSanitizeLiteralError(literal: SvgHtml): Error {\n return Error(\n `The literal provided to ThyIconRegistry was not trusted as safe HTML by ` +\n `Angular's DomSanitizer. Attempted literal was \"${literal}\".`\n );\n }\n\n private internalAddSvgIconSet(namespace: string, config: SvgIconConfig): this {\n const configNamespace = this.svgIconSetConfigs.get(namespace);\n\n if (configNamespace) {\n configNamespace.push(config);\n } else {\n this.svgIconSetConfigs.set(namespace, [config]);\n }\n\n return this;\n }\n\n private cloneSvg(svg: SVGElement): SVGElement {\n return svg.cloneNode(true) as SVGElement;\n }\n\n private fetchUrl(safeUrl: SafeResourceUrl | null): Observable<string> {\n if (safeUrl == null) {\n throw Error(`Cannot fetch icon from URL \"${safeUrl}\".`);\n }\n\n const url = this.sanitizer.sanitize(SecurityContext.RESOURCE_URL, safeUrl);\n\n if ((typeof ngDevMode === 'undefined' || ngDevMode) && !url) {\n throw new Error(\n `The URL provided to ThyIconRegistry was not trusted as a resource URL ` +\n `via Angular's DomSanitizer. Attempted URL was \"${url}\".`\n );\n }\n\n // Store in-progress fetches to avoid sending a duplicate request for a URL when there is\n // already a request in progress for that URL. It's necessary to call share() on the\n // Observable returned by http.get() so that multiple subscribers don't cause multiple XHRs.\n const inProgressFetch = this.inProgressUrlFetches.get(url);\n\n if (inProgressFetch) {\n return inProgressFetch;\n } else {\n // TODO(jelbourn): for some reason, the `finalize` operator \"loses\" the generic type on the\n // Observable. Figure out why and fix it.\n const req = this.httpClient.get(url, { responseType: 'text' }).pipe(\n finalize(() => this.inProgressUrlFetches.delete(url)),\n share()\n );\n\n this.inProgressUrlFetches.set(url, req);\n return req;\n }\n }\n\n private toSvgElement(element: Element): SVGElement {\n const svg = this.svgElementFromString('<svg></svg>');\n\n for (let i = 0; i < element.childNodes.length; i++) {\n if (element.childNodes[i].nodeType === this.document.ELEMENT_NODE) {\n svg.appendChild(element.childNodes[i].cloneNode(true));\n }\n }\n\n return svg;\n }\n\n private extractSvgIconFromIconSet(iconSet: SVGElement, iconName: string): SVGElement | null {\n // Use the `id=\"iconName\"` syntax in order to escape special\n // characters in the ID (versus using the #iconName syntax).\n const iconSource = iconSet.querySelector(`[id=\"${iconName}\"]`);\n\n if (!iconSource) {\n return null;\n }\n\n // Clone the element and remove the ID to prevent multiple elements from being added\n // to the page with the same ID.\n const iconElement = iconSource.cloneNode(true) as Element;\n iconElement.removeAttribute('id');\n\n // If the icon node is itself an <svg> node, clone and return it directly. If not, set it as\n // the content of a new <svg> node.\n if (iconElement.nodeName.toLowerCase() === 'svg') {\n return this.setSvgAttributes(iconElement as SVGElement);\n }\n\n // If the node is a <symbol>, it won't be rendered so we have to convert it into <svg>. Note\n // that the same could be achieved by referring to it via <use href=\"#id\">, however the <use>\n // tag is problematic on Firefox, because it needs to include the current page path.\n if (iconElement.nodeName.toLowerCase() === 'symbol') {\n return this.setSvgAttributes(this.toSvgElement(iconElement));\n }\n\n // createElement('SVG') doesn't work as expected; the DOM ends up with\n // the correct nodes, but the SVG content doesn't render. Instead we\n // have to create an empty SVG node using innerHTML and append its content.\n // Elements created using DOMParser.parseFromString have the same problem.\n // http://stackoverflow.com/questions/23003278/svg-innerhtml-in-firefox-can-not-display\n const svg = this.svgElementFromString('<svg></svg>');\n // Clone the node so we don't remove it from the parent icon set element.\n svg.appendChild(iconElement);\n\n return this.setSvgAttributes(svg);\n }\n\n private extractIconWithNameFromIconSetConfigs(iconName: string, iconSetConfigs: SvgIconConfig[]): SVGElement | null {\n // Iterate backwards, so icon sets added later have precedence.\n for (let i = iconSetConfigs.length - 1; i >= 0; i--) {\n const config = iconSetConfigs[i];\n if (config.svgElement) {\n const foundIcon = this.extractSvgIconFromIconSet(config.svgElement, iconName);\n if (foundIcon) {\n return foundIcon;\n }\n }\n }\n return null;\n }\n\n private svgElementFromString(str: string): SVGElement {\n const div = this.document.createElement('DIV');\n div.innerHTML = str;\n const svg = div.querySelector('svg') as SVGElement;\n\n if (!svg) {\n throw Error('<svg> tag not found');\n }\n\n return svg;\n }\n\n private setSvgAttributes(svg: SVGElement): SVGElement {\n svg.setAttribute('fit', '');\n svg.setAttribute('height', '1em');\n svg.setAttribute('width', '1em');\n svg.setAttribute('preserveAspectRatio', 'xMidYMid meet');\n svg.setAttribute('focusable', 'false'); // Disable IE11 default behavior to make SVGs focusable.\n return svg;\n }\n\n private createSvgElementForSingleIcon(responseText: string): SVGElement {\n const svg = this.svgElementFromString(responseText);\n this.setSvgAttributes(svg);\n return svg;\n }\n\n private loadSvgIconFromConfig(config: SvgIconConfig): Observable<SVGElement> {\n return this.fetchUrl(config.url).pipe(map(svgText => this.createSvgElementForSingleIcon(svgText)));\n }\n\n private loadSvgIconSetFromConfig(config: SvgIconConfig): Observable<SVGElement> {\n // If the SVG for this icon set has already been parsed, do nothing.\n if (config.svgElement) {\n return of(config.svgElement);\n }\n\n return this.fetchUrl(config.url).pipe(\n map(svgText => {\n // It is possible that the icon set was parsed and cached by an earlier request, so parsing\n // only needs to occur if the cache is yet unset.\n if (!config.svgElement) {\n config.svgElement = this.svgElementFromString(svgText);\n }\n\n return config.svgElement;\n })\n );\n }\n\n private getSvgFromConfig(config: SvgIconConfig): Observable<SVGElement> {\n if (config.svgElement) {\n // We already have the SVG element for this icon, return a copy.\n return of(this.cloneSvg(config.svgElement));\n } else {\n // Fetch the icon from the config's URL, cache it, and return a copy.\n return this.loadSvgIconFromConfig(config).pipe(\n tap(svg => (config.svgElement = svg)),\n map(svg => this.cloneSvg(svg))\n );\n }\n }\n\n private getSvgFromIconSetConfigs(name: string, iconSetConfigs: SvgIconConfig[]): Observable<SVGElement> {\n // For all the icon set SVG elements we've fetched, see if any contain an icon with the\n // requested name.\n const namedIcon = this.extractIconWithNameFromIconSetConfigs(name, iconSetConfigs);\n\n if (namedIcon) {\n // We could cache namedIcon in svgIconConfigs, but since we have to make a copy every\n // time anyway, there's probably not much advantage compared to just always extracting\n // it from the icon set.\n return of(namedIcon);\n }\n\n // Not found in any cached icon sets. If there are icon sets with URLs that we haven't\n // fetched, fetch them now and look for iconName in the results.\n const iconSetFetchRequests: Observable<SVGElement | null>[] = iconSetConfigs\n .filter(iconSetConfig => !iconSetConfig.svgElement)\n .map(iconSetConfig => {\n return this.loadSvgIconSetFromConfig(iconSetConfig).pipe(\n catchError((err: HttpErrorResponse): Observable<SVGElement | null> => {\n const url = this.sanitizer.sanitize(SecurityContext.RESOURCE_URL, iconSetConfig.url);\n\n // Swallow errors fetching individual URLs so the\n // combined Observable won't necessarily fail.\n console.error(`Loading icon set URL: ${url} failed: ${err.message}`);\n return of(null);\n })\n );\n });\n\n // Fetch all the icon set URLs. When the requests complete, every IconSet should have a\n // cached SVG element (unless the request failed), and we can check again for the icon.\n return forkJoin(iconSetFetchRequests).pipe(\n map(() => {\n const foundIcon = this.extractIconWithNameFromIconSetConfigs(name, iconSetConfigs);\n\n if (!foundIcon) {\n throw this.getIconNameNotFoundError(name);\n }\n\n return foundIcon;\n })\n );\n }\n\n private internalAddSvgIconConfig(namespace: string, iconName: string, config: SvgIconConfig): this {\n this.svgIconConfigs.set(this.buildIconKey(namespace, iconName), config);\n return this;\n }\n\n public buildIconKey(namespace: string, name: string) {\n return namespace + ':' + name;\n }\n\n public splitIconName(iconName: string): [string, string] {\n if (!iconName) {\n return ['', ''];\n }\n const parts = iconName.split(':');\n switch (parts.length) {\n case 1:\n return ['', parts[0]]; // Use default namespace.\n case 2:\n return <[string, string]>parts;\n default:\n throw Error(`Invalid icon name: \"${iconName}\"`);\n }\n }\n\n public addSvgIconSetInNamespace(namespace: string, url: SvgResourceUrl): this {\n url = isString(url) ? this.sanitizer.bypassSecurityTrustResourceUrl(url) : url;\n return this.internalAddSvgIconSet(namespace, new SvgIconConfig(url));\n }\n\n /**\n * 添加SVG图标集,添加到默认命名空间\n */\n public addSvgIconSet(url: SvgResourceUrl): this {\n return this.addSvgIconSetInNamespace('', url);\n }\n\n public addSvgIconSetLiteralInNamespace(namespace: string, literal: SafeHtml): this {\n const sanitizedLiteral = this.sanitizer.sanitize(SecurityContext.HTML, literal);\n\n if (!sanitizedLiteral) {\n throw this.getIconFailedToSanitizeLiteralError(literal);\n }\n\n const svgElement = this.svgElementFromString(sanitizedLiteral);\n return this.internalAddSvgIconSet(namespace, new SvgIconConfig(svgElement));\n }\n\n public addSvgIconSetLiteral(literal: SafeHtml): this {\n return this.addSvgIconSetLiteralInNamespace('', literal);\n }\n\n /**\n * @description.en-us Registers an icon by URL in the specified namespace.\n * @description 添加单个SVG图标到指定的命名空间\n * @param namespace Namespace in which the icon should be registered.\n * @param iconName Name under which the icon should be registered.\n * @param url\n */\n public addSvgIconInNamespace(namespace: string, iconName: string, url: SvgResourceUrl): this {\n url = isString(url) ? this.sanitizer.bypassSecurityTrustResourceUrl(url) : url;\n return this.internalAddSvgIconConfig(namespace, iconName, new SvgIconConfig(url));\n }\n\n /**\n * @description.en-us Registers an icon by URL in the default namespace.\n * @description 添加单个SVG图标\n * @param iconName Name under which the icon should be registered.\n * @param url\n */\n public addSvgIcon(iconName: string, url: SvgResourceUrl): this {\n return this.addSvgIconInNamespace('', iconName, url);\n }\n\n /**\n * @description.en-us Registers an icon using an HTML string in the default namespace.\n * @description 添加单个SVG图标字符串,直接传入 SVG HTML 字符串\n * @param iconName Name under which the icon should be registered.\n * @param literal SVG source of the icon.\n */\n public addSvgIconLiteral(iconName: string, literal: SvgHtml): this {\n return this.addSvgIconLiteralInNamespace('', iconName, literal);\n }\n\n /**\n * @description.en-us Registers an icon using an HTML string in the specified namespace.\n * @description 添加单个SVG图标字符串到指定的命名空间,直接传入 SVG HTML 字符串\n * @param namespace Namespace in which the icon should be registered.\n * @param iconName Name under which the icon should be registered.\n * @param literal SVG source of the icon.\n */\n public addSvgIconLiteralInNamespace(namespace: string, iconName: string, literal: SvgHtml): this {\n literal = isString(literal) ? this.sanitizer.bypassSecurityTrustHtml(literal) : literal;\n const sanitizedLiteral = this.sanitizer.sanitize(SecurityContext.HTML, literal);\n\n if (!sanitizedLiteral) {\n throw this.getIconFailedToSanitizeLiteralError(literal);\n }\n\n const svgElement = this.createSvgElementForSingleIcon(sanitizedLiteral);\n return this.internalAddSvgIconConfig(namespace, iconName, new SvgIconConfig(svgElement));\n }\n\n public getDefaultFontSetClass() {\n return this.defaultFontSetClass;\n }\n\n public getFontSetClassByAlias(fontSet: string) {\n return fontSet;\n }\n\n /**\n * 获取某个图标\n */\n public getSvgIcon(name: string, namespace: string = ''): Observable<SVGElement> {\n // Return (copy of) cached icon if possible.\n const key = this.buildIconKey(namespace, name);\n const config = this.svgIconConfigs.get(key);\n\n if (config) {\n return this.getSvgFromConfig(config);\n }\n\n // See if we have any icon sets registered for the namespace.\n const iconSetConfigs = this.svgIconSetConfigs.get(namespace);\n\n if (iconSetConfigs) {\n return this.getSvgFromIconSetConfigs(name, iconSetConfigs);\n }\n\n return throwError(this.getIconNameNotFoundError(key));\n }\n\n public setIconMode(mode: IconMode) {\n this.internalIconMode = mode;\n }\n}\n","import { take } from 'rxjs/operators';\nimport { useHostRenderer } from '@tethys/cdk/dom';\n\nimport {\n ChangeDetectionStrategy,\n Component,\n ElementRef,\n HostBinding,\n Input,\n OnChanges,\n OnInit,\n Renderer2,\n SimpleChanges,\n ViewEncapsulation,\n booleanAttribute,\n numberAttribute\n} from '@angular/core';\n\nimport { getWhetherPrintErrorWhenIconNotFound } from './config';\nimport { ThyIconRegistry } from './icon-registry';\n\nconst iconSuffixMap = {\n fill: 'fill',\n twotone: 'tt'\n};\n\n/**\n * 图标组件\n * @name thy-icon,[thy-icon]\n * @order 10\n */\n@Component({\n selector: 'thy-icon, [thy-icon]',\n template: '<ng-content></ng-content>',\n changeDetection: ChangeDetectionStrategy.OnPush,\n encapsulation: ViewEncapsulation.None,\n standalone: true,\n host: {\n class: 'thy-icon'\n }\n})\nexport class ThyIcon implements OnInit, OnChanges {\n private initialized = false;\n\n /**\n * 图标的类型\n * @type outline | fill | twotone\n */\n @Input('thyIconType') iconType: 'outline' | 'fill' | 'twotone' = 'outline';\n\n @Input('thyTwotoneColor') iconTwotoneColor: string;\n\n /**\n * 图标的名字\n */\n @Input('thyIconName') iconName: string;\n\n /**\n * 图标的旋转角度\n * @default 0\n */\n @Input({ alias: 'thyIconRotate', transform: numberAttribute }) iconRotate: number;\n\n @Input('thyIconSet') iconSet: string;\n\n /**\n * 图标打底色,镂空的图标,会透过颜色来\n * @default false\n */\n @HostBinding(`class.thy-icon-legging`)\n @Input({ alias: 'thyIconLegging', transform: booleanAttribute })\n iconLegging: boolean;\n\n @Input({ alias: 'thyIconLinearGradient', transform: booleanAttribute })\n iconLinearGradient: boolean;\n\n private hostRenderer = useHostRenderer();\n\n constructor(private render: Renderer2, private elementRef: ElementRef, private iconRegistry: ThyIconRegistry) {}\n\n ngOnInit() {\n this.updateClasses();\n this.initialized = true;\n }\n\n ngOnChanges(changes: SimpleChanges) {\n if (this.initialized) {\n if (\n changes['iconName'] ||\n changes['iconSet'] ||\n changes['iconTwotoneColor'] ||\n changes['iconType'] ||\n changes['iconLinearGradient']\n ) {\n this.updateClasses();\n } else if (changes['iconRotate']) {\n this.setStyleRotate();\n }\n }\n }\n\n private updateClasses() {\n const [namespace, iconName] = this.iconRegistry.splitIconName(this.iconName);\n if (iconName) {\n if (this.iconRegistry.iconMode === 'svg') {\n this.iconRegistry\n .getSvgIcon(this.buildIconNameByType(iconName), namespace)\n .pipe(take(1))\n .subscribe(\n svg => {\n this.setSvgElement(svg);\n },\n (error: Error) => {\n if (getWhetherPrintErrorWhenIconNotFound()) {\n console.error(`Error retrieving icon: ${error.message}`);\n }\n }\n );\n this.hostRenderer.updateClass([`thy-icon${namespace ? `-${namespace}` : ``}-${this.buildIconNameByType(iconName)}`]);\n } else {\n const fontSetClass = this.iconSet\n ? this.iconRegistry.getFontSetClassByAlias(this.iconSet)\n : this.iconRegistry.getDefaultFontSetClass();\n this.hostRenderer.updateClass([fontSetClass, `${fontSetClass}-${this.iconName}`]);\n }\n }\n }\n\n private setStyleRotate() {\n if (this.iconRotate !== undefined) {\n this.render.setStyle(this.elementRef.nativeElement.querySelector('svg'), 'transform', `rotate(${this.iconRotate}deg)`);\n }\n }\n\n //#region svg element\n\n private setSvgElement(svg: SVGElement) {\n this.clearSvgElement();\n\n // Workaround for IE11 and Edge ignoring `style` tags inside dynamically-created SVGs.\n // See: https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/10898469/\n // Do this before inserting the element into the DOM, in order to avoid a style recalculation.\n const styleTags = svg.querySelectorAll('style') as NodeListOf<HTMLStyleElement>;\n\n for (let i = 0; i < styleTags.length; i++) {\n styleTags[i].textContent += ' ';\n }\n\n if (this.iconType === 'twotone') {\n const allPaths = svg.querySelectorAll('path');\n if (allPaths.length > 1) {\n allPaths.forEach((child, index: number) => {\n if (child.getAttribute('id').includes('secondary-color')) {\n child.setAttribute('fill', this.iconTwotoneColor);\n }\n });\n }\n }\n\n // Note: we do this fix here, rather than the icon registry, because the\n // references have to point to the URL at the time that the icon was created.\n // if (this._location) {\n // const path = this._location.getPathname();\n // this._previousPath = path;\n // this._cacheChildrenWithExternalReferences(svg);\n // this._prependPathToReferences(path);\n // }\n if (this.iconLinearGradient) {\n this.setBaseUrl(svg);\n this.clearTitleElement(svg);\n }\n\n this.elementRef.nativeElement.appendChild(svg);\n this.setStyleRotate();\n }\n\n private clearSvgElement() {\n const layoutElement: HTMLElement = this.elementRef.nativeElement;\n let childCount = layoutElement.childNodes.length;\n\n // if (this._elementsWithExternalReferences) {\n // this._elementsWithExternalReferences.clear();\n // }\n\n // Remove existing non-element child nodes and SVGs, and add the new SVG element. Note that\n // we can't use innerHTML, because IE will throw if the element has a data binding.\n while (childCount--) {\n const child = layoutElement.childNodes[childCount];\n\n // 1 corresponds to Node.ELEMENT_NODE. We remove all non-element nodes in order to get rid\n // of any loose text nodes, as well as any SVG elements in order to remove any old icons.\n if (child.nodeType !== 1 || child.nodeName.toLowerCase() === 'svg') {\n layoutElement.removeChild(child);\n }\n }\n }\n\n //#endregion\n\n private buildIconNameByType(iconName: string) {\n if (this.iconType && ['fill', 'twotone'].indexOf(this.iconType) >= 0) {\n const suffix = iconSuffixMap[this.iconType];\n return iconName.includes(`-${suffix}`) ? iconName : `${iconName}-${suffix}`;\n } else {\n return iconName;\n }\n }\n\n /**\n * Support Safari SVG LinearGradient.\n * @param svg\n */\n private setBaseUrl(svg: SVGElement) {\n const styleElements = svg.querySelectorAll('style');\n styleElements.forEach((n: HTMLElement) => {\n if (n.style.cssText.includes('url')) {\n n.style.fill = n.style.fill.replace('url(\"', 'url(\"' + location.pathname);\n }\n if (n.style.cssText.includes('clip-path')) {\n n.style.clipPath = n.style.clipPath.replace('url(\"', 'url(\"' + location.pathname);\n }\n });\n }\n\n private clearTitleElement(svg: SVGElement) {\n const titleElement = svg.querySelector('title');\n titleElement && titleElement.remove();\n }\n}\n","import { NgModule } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { CommonModule } from '@angular/common';\nimport { ThyIcon } from './icon.component';\nimport { provideHttpClient, withInterceptorsFromDi } from '@angular/common/http';\n\n@NgModule({\n declarations: [],\n exports: [ThyIcon],\n imports: [ThyIcon, CommonModule, FormsModule],\n providers: [provideHttpClient(withInterceptorsFromDi())]\n})\nexport class ThyIconModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":["i1.ThyIconRegistry"],"mappings":";;;;;;;;;;;;AAAA,IAAI,sBAAsB,GAAG,IAAI,CAAC;AAE5B,SAAU,6BAA6B,CAAC,KAAc,EAAA;IACxD,sBAAsB,GAAG,KAAK,CAAC;AACnC,CAAC;SAEe,oCAAoC,GAAA;AAChD,IAAA,OAAO,sBAAsB,CAAC;AAClC;;ACCA,MAAM,aAAa,CAAA;AAIf,IAAA,WAAA,CAAY,IAAkC,EAAA;;;QAG1C,IAAI,IAAI,IAAI,CAAC,CAAE,IAAY,CAAC,QAAQ,EAAE;AAClC,YAAA,IAAI,CAAC,UAAU,GAAG,IAAkB,CAAC;SACxC;aAAM;AACH,YAAA,IAAI,CAAC,GAAG,GAAG,IAAuB,CAAC;SACtC;KACJ;AACJ,CAAA;AAQD;;AAEG;MAIU,eAAe,CAAA;AAOxB,IAAA,IAAW,QAAQ,GAAA;QACf,OAAO,IAAI,CAAC,gBAAgB,CAAC;KAChC;AAED,IAAA,WAAA,CAAoB,SAAuB,EAAU,UAAsB,EAA4B,QAAa,EAAA;QAAhG,IAAS,CAAA,SAAA,GAAT,SAAS,CAAc;QAAU,IAAU,CAAA,UAAA,GAAV,UAAU,CAAY;QAA4B,IAAQ,CAAA,QAAA,GAAR,QAAQ,CAAK;QAV5G,IAAmB,CAAA,mBAAA,GAAG,SAAS,CAAC;QAChC,IAAgB,CAAA,gBAAA,GAAa,KAAK,CAAC;AACnC,QAAA,IAAA,CAAA,cAAc,GAAG,IAAI,GAAG,EAAyB,CAAC;AAClD,QAAA,IAAA,CAAA,iBAAiB,GAAG,IAAI,GAAG,EAA2B,CAAC;AACvD,QAAA,IAAA,CAAA,oBAAoB,GAAG,IAAI,GAAG,EAA8B,CAAC;KAMmD;AAEhH,IAAA,wBAAwB,CAAC,QAAgB,EAAA;AAC7C,QAAA,OAAO,KAAK,CAAC,CAAA,mCAAA,EAAsC,QAAQ,CAAA,CAAA,CAAG,CAAC,CAAC;KACnE;AAEO,IAAA,mCAAmC,CAAC,OAAgB,EAAA;QACxD,OAAO,KAAK,CACR,CAA0E,wEAAA,CAAA;YACtE,CAAkD,+CAAA,EAAA,OAAO,CAAI,EAAA,CAAA,CACpE,CAAC;KACL;IAEO,qBAAqB,CAAC,SAAiB,EAAE,MAAqB,EAAA;QAClE,MAAM,eAAe,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAE9D,IAAI,eAAe,EAAE;AACjB,YAAA,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SAChC;aAAM;YACH,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;SACnD;AAED,QAAA,OAAO,IAAI,CAAC;KACf;AAEO,IAAA,QAAQ,CAAC,GAAe,EAAA;AAC5B,QAAA,OAAO,GAAG,CAAC,SAAS,CAAC,IAAI,CAAe,CAAC;KAC5C;AAEO,IAAA,QAAQ,CAAC,OAA+B,EAAA;AAC5C,QAAA,IAAI,OAAO,IAAI,IAAI,EAAE;AACjB,YAAA,MAAM,KAAK,CAAC,CAAA,4BAAA,EAA+B,OAAO,CAAA,EAAA,CAAI,CAAC,CAAC;SAC3D;AAED,QAAA,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,eAAe,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;AAE3E,QAAA,IAAI,CAAC,OAAO,SAAS,KAAK,WAAW,IAAI,SAAS,KAAK,CAAC,GAAG,EAAE;YACzD,MAAM,IAAI,KAAK,CACX,CAAwE,sEAAA,CAAA;gBACpE,CAAkD,+CAAA,EAAA,GAAG,CAAI,EAAA,CAAA,CAChE,CAAC;SACL;;;;QAKD,MAAM,eAAe,GAAG,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAE3D,IAAI,eAAe,EAAE;AACjB,YAAA,OAAO,eAAe,CAAC;SAC1B;aAAM;;;AAGH,YAAA,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,YAAY,EAAE,MAAM,EAAE,CAAC,CAAC,IAAI,CAC/D,QAAQ,CAAC,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,EACrD,KAAK,EAAE,CACV,CAAC;YAEF,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;AACxC,YAAA,OAAO,GAAG,CAAC;SACd;KACJ;AAEO,IAAA,YAAY,CAAC,OAAgB,EAAA;QACjC,MAAM,GAAG,GAAG,IAAI,CAAC,oBAAoB,CAAC,aAAa,CAAC,CAAC;AAErD,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;AAChD,YAAA,IAAI,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE;AAC/D,gBAAA,GAAG,CAAC,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;aAC1D;SACJ;AAED,QAAA,OAAO,GAAG,CAAC;KACd;IAEO,yBAAyB,CAAC,OAAmB,EAAE,QAAgB,EAAA;;;QAGnE,MAAM,UAAU,GAAG,OAAO,CAAC,aAAa,CAAC,CAAQ,KAAA,EAAA,QAAQ,CAAI,EAAA,CAAA,CAAC,CAAC;QAE/D,IAAI,CAAC,UAAU,EAAE;AACb,YAAA,OAAO,IAAI,CAAC;SACf;;;QAID,MAAM,WAAW,GAAG,UAAU,CAAC,SAAS,CAAC,IAAI,CAAY,CAAC;AAC1D,QAAA,WAAW,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;;;QAIlC,IAAI,WAAW,CAAC,QAAQ,CAAC,WAAW,EAAE,KAAK,KAAK,EAAE;AAC9C,YAAA,OAAO,IAAI,CAAC,gBAAgB,CAAC,WAAyB,CAAC,CAAC;SAC3D;;;;QAKD,IAAI,WAAW,CAAC,QAAQ,CAAC,WAAW,EAAE,KAAK,QAAQ,EAAE;YACjD,OAAO,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC,CAAC;SAChE;;;;;;QAOD,MAAM,GAAG,GAAG,IAAI,CAAC,oBAAoB,CAAC,aAAa,CAAC,CAAC;;AAErD,QAAA,GAAG,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;AAE7B,QAAA,OAAO,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;KACrC;IAEO,qCAAqC,CAAC,QAAgB,EAAE,cAA+B,EAAA;;AAE3F,QAAA,KAAK,IAAI,CAAC,GAAG,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;AACjD,YAAA,MAAM,MAAM,GAAG,cAAc,CAAC,CAAC,CAAC,CAAC;AACjC,YAAA,IAAI,MAAM,CAAC,UAAU,EAAE;AACnB,gBAAA,MAAM,SAAS,GAAG,IAAI,CAAC,yBAAyB,CAAC,MAAM,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;gBAC9E,IAAI,SAAS,EAAE;AACX,oBAAA,OAAO,SAAS,CAAC;iBACpB;aACJ;SACJ;AACD,QAAA,OAAO,IAAI,CAAC;KACf;AAEO,IAAA,oBAAoB,CAAC,GAAW,EAAA;QACpC,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;AAC/C,QAAA,GAAG,CAAC,SAAS,GAAG,GAAG,CAAC;QACpB,MAAM,GAAG,GAAG,GAAG,CAAC,aAAa,CAAC,KAAK,CAAe,CAAC;QAEnD,IAAI,CAAC,GAAG,EAAE;AACN,YAAA,MAAM,KAAK,CAAC,qBAAqB,CAAC,CAAC;SACtC;AAED,QAAA,OAAO,GAAG,CAAC;KACd;AAEO,IAAA,gBAAgB,CAAC,GAAe,EAAA;AACpC,QAAA,GAAG,CAAC,YAAY,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;AAC5B,QAAA,GAAG,CAAC,YAAY,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;AAClC,QAAA,GAAG,CAAC,YAAY,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;AACjC,QAAA,GAAG,CAAC,YAAY,CAAC,qBAAqB,EAAE,eAAe,CAAC,CAAC;QACzD,GAAG,CAAC,YAAY,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;AACvC,QAAA,OAAO,GAAG,CAAC;KACd;AAEO,IAAA,6BAA6B,CAAC,YAAoB,EAAA;QACtD,MAAM,GAAG,GAAG,IAAI,CAAC,oBAAoB,CAAC,YAAY,CAAC,CAAC;AACpD,QAAA,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;AAC3B,QAAA,OAAO,GAAG,CAAC;KACd;AAEO,IAAA,qBAAqB,CAAC,MAAqB,EAAA;QAC/C,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,IAAI,IAAI,CAAC,6BAA6B,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;KACtG;AAEO,IAAA,wBAAwB,CAAC,MAAqB,EAAA;;AAElD,QAAA,IAAI,MAAM,CAAC,UAAU,EAAE;AACnB,YAAA,OAAO,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;SAChC;AAED,QAAA,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CACjC,GAAG,CAAC,OAAO,IAAG;;;AAGV,YAAA,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;gBACpB,MAAM,CAAC,UAAU,GAAG,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC;aAC1D;YAED,OAAO,MAAM,CAAC,UAAU,CAAC;SAC5B,CAAC,CACL,CAAC;KACL;AAEO,IAAA,gBAAgB,CAAC,MAAqB,EAAA;AAC1C,QAAA,IAAI,MAAM,CAAC,UAAU,EAAE;;YAEnB,OAAO,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC;SAC/C;aAAM;;AAEH,YAAA,OAAO,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC,IAAI,CAC1C,GAAG,CAAC,GAAG,KAAK,MAAM,CAAC,UAAU,GAAG,GAAG,CAAC,CAAC,EACrC,GAAG,CAAC,GAAG,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CACjC,CAAC;SACL;KACJ;IAEO,wBAAwB,CAAC,IAAY,EAAE,cAA+B,EAAA;;;QAG1E,MAAM,SAAS,GAAG,IAAI,CAAC,qCAAqC,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC;QAEnF,IAAI,SAAS,EAAE;;;;AAIX,YAAA,OAAO,EAAE,CAAC,SAAS,CAAC,CAAC;SACxB;;;QAID,MAAM,oBAAoB,GAAoC,cAAc;aACvE,MAAM,CAAC,aAAa,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC;aAClD,GAAG,CAAC,aAAa,IAAG;AACjB,YAAA,OAAO,IAAI,CAAC,wBAAwB,CAAC,aAAa,CAAC,CAAC,IAAI,CACpD,UAAU,CAAC,CAAC,GAAsB,KAAmC;AACjE,gBAAA,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,eAAe,CAAC,YAAY,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;;;gBAIrF,OAAO,CAAC,KAAK,CAAC,CAAyB,sBAAA,EAAA,GAAG,CAAY,SAAA,EAAA,GAAG,CAAC,OAAO,CAAE,CAAA,CAAC,CAAC;AACrE,gBAAA,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;aACnB,CAAC,CACL,CAAC;AACN,SAAC,CAAC,CAAC;;;QAIP,OAAO,QAAQ,CAAC,oBAAoB,CAAC,CAAC,IAAI,CACtC,GAAG,CAAC,MAAK;YACL,MAAM,SAAS,GAAG,IAAI,CAAC,qCAAqC,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC;YAEnF,IAAI,CAAC,SAAS,EAAE;AACZ,gBAAA,MAAM,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,CAAC;aAC7C;AAED,YAAA,OAAO,SAAS,CAAC;SACpB,CAAC,CACL,CAAC;KACL;AAEO,IAAA,wBAAwB,CAAC,SAAiB,EAAE,QAAgB,EAAE,MAAqB,EAAA;AACvF,QAAA,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,QAAQ,CAAC,EAAE,MAAM,CAAC,CAAC;AACxE,QAAA,OAAO,IAAI,CAAC;KACf;IAEM,YAAY,CAAC,SAAiB,EAAE,IAAY,EAAA;AAC/C,QAAA,OAAO,SAAS,GAAG,GAAG,GAAG,IAAI,CAAC;KACjC;AAEM,IAAA,aAAa,CAAC,QAAgB,EAAA;QACjC,IAAI,CAAC,QAAQ,EAAE;AACX,YAAA,OAAO,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;SACnB;QACD,MAAM,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;AAClC,QAAA,QAAQ,KAAK,CAAC,MAAM;AAChB,YAAA,KAAK,CAAC;gBACF,OAAO,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;AAC1B,YAAA,KAAK,CAAC;AACF,gBAAA,OAAyB,KAAK,CAAC;AACnC,YAAA;AACI,gBAAA,MAAM,KAAK,CAAC,CAAA,oBAAA,EAAuB,QAAQ,CAAA,CAAA,CAAG,CAAC,CAAC;SACvD;KACJ;IAEM,wBAAwB,CAAC,SAAiB,EAAE,GAAmB,EAAA;QAClE,GAAG,GAAG,QAAQ,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,8BAA8B,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;AAC/E,QAAA,OAAO,IAAI,CAAC,qBAAqB,CAAC,SAAS,EAAE,IAAI,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC;KACxE;AAED;;AAEG;AACI,IAAA,aAAa,CAAC,GAAmB,EAAA;QACpC,OAAO,IAAI,CAAC,wBAAwB,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC;KACjD;IAEM,+BAA+B,CAAC,SAAiB,EAAE,OAAiB,EAAA;AACvE,QAAA,MAAM,gBAAgB,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QAEhF,IAAI,CAAC,gBAAgB,EAAE;AACnB,YAAA,MAAM,IAAI,CAAC,mCAAmC,CAAC,OAAO,CAAC,CAAC;SAC3D;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,oBAAoB,CAAC,gBAAgB,CAAC,CAAC;AAC/D,QAAA,OAAO,IAAI,CAAC,qBAAqB,CAAC,SAAS,EAAE,IAAI,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;KAC/E;AAEM,IAAA,oBAAoB,CAAC,OAAiB,EAAA;QACzC,OAAO,IAAI,CAAC,+BAA+B,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;KAC5D;AAED;;;;;;AAMG;AACI,IAAA,qBAAqB,CAAC,SAAiB,EAAE,QAAgB,EAAE,GAAmB,EAAA;QACjF,GAAG,GAAG,QAAQ,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,8BAA8B,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;AAC/E,QAAA,OAAO,IAAI,CAAC,wBAAwB,CAAC,SAAS,EAAE,QAAQ,EAAE,IAAI,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC;KACrF;AAED;;;;;AAKG;IACI,UAAU,CAAC,QAAgB,EAAE,GAAmB,EAAA;QACnD,OAAO,IAAI,CAAC,qBAAqB,CAAC,EAAE,EAAE,QAAQ,EAAE,GAAG,CAAC,CAAC;KACxD;AAED;;;;;AAKG;IACI,iBAAiB,CAAC,QAAgB,EAAE,OAAgB,EAAA;QACvD,OAAO,IAAI,CAAC,4BAA4B,CAAC,EAAE,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;KACnE;AAED;;;;;;AAMG;AACI,IAAA,4BAA4B,CAAC,SAAiB,EAAE,QAAgB,EAAE,OAAgB,EAAA;QACrF,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;AACxF,QAAA,MAAM,gBAAgB,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QAEhF,IAAI,CAAC,gBAAgB,EAAE;AACnB,YAAA,MAAM,IAAI,CAAC,mCAAmC,CAAC,OAAO,CAAC,CAAC;SAC3D;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,6BAA6B,CAAC,gBAAgB,CAAC,CAAC;AACxE,QAAA,OAAO,IAAI,CAAC,wBAAwB,CAAC,SAAS,EAAE,QAAQ,EAAE,IAAI,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;KAC5F;IAEM,sBAAsB,GAAA;QACzB,OAAO,IAAI,CAAC,mBAAmB,CAAC;KACnC;AAEM,IAAA,sBAAsB,CAAC,OAAe,EAAA;AACzC,QAAA,OAAO,OAAO,CAAC;KAClB;AAED;;AAEG;AACI,IAAA,UAAU,CAAC,IAAY,EAAE,SAAA,GAAoB,EAAE,EAAA;;QAElD,MAAM,GAAG,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QAC/C,MAAM,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAE5C,IAAI,MAAM,EAAE;AACR,YAAA,OAAO,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;SACxC;;QAGD,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAE7D,IAAI,cAAc,EAAE;YAChB,OAAO,IAAI,CAAC,wBAAwB,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC;SAC9D;QAED,OAAO,UAAU,CAAC,IAAI,CAAC,wBAAwB,CAAC,GAAG,CAAC,CAAC,CAAC;KACzD;AAEM,IAAA,WAAW,CAAC,IAAc,EAAA;AAC7B,QAAA,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;KAChC;AA5XQ,IAAA,SAAA,IAAA,CAAA,IAAA,GAAA,EAAA,CAAA,kBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,eAAe,wEAW6D,QAAQ,EAAA,CAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,UAAA,EAAA,CAAA,CAAA,EAAA;AAXpF,IAAA,SAAA,IAAA,CAAA,KAAA,GAAA,EAAA,CAAA,qBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,eAAe,cAFZ,MAAM,EAAA,CAAA,CAAA,EAAA;;2FAET,eAAe,EAAA,UAAA,EAAA,CAAA;kBAH3B,UAAU;AAAC,YAAA,IAAA,EAAA,CAAA;AACR,oBAAA,UAAU,EAAE,MAAM;AACrB,iBAAA,CAAA;;0BAYiF,MAAM;2BAAC,QAAQ,CAAA;;;AC1BjG,MAAM,aAAa,GAAG;AAClB,IAAA,IAAI,EAAE,MAAM;AACZ,IAAA,OAAO,EAAE,IAAI;CAChB,CAAC;AAEF;;;;AAIG;MAWU,OAAO,CAAA;AAqChB,IAAA,WAAA,CAAoB,MAAiB,EAAU,UAAsB,EAAU,YAA6B,EAAA;QAAxF,IAAM,CAAA,MAAA,GAAN,MAAM,CAAW;QAAU,IAAU,CAAA,UAAA,GAAV,UAAU,CAAY;QAAU,IAAY,CAAA,YAAA,GAAZ,YAAY,CAAiB;QApCpG,IAAW,CAAA,WAAA,GAAG,KAAK,CAAC;AAE5B;;;AAGG;QACmB,IAAQ,CAAA,QAAA,GAAmC,SAAS,CAAC;QA4BnE,IAAY,CAAA,YAAA,GAAG,eAAe,EAAE,CAAC;KAEuE;IAEhH,QAAQ,GAAA;QACJ,IAAI,CAAC,aAAa,EAAE,CAAC;AACrB,QAAA,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;KAC3B;AAED,IAAA,WAAW,CAAC,OAAsB,EAAA;AAC9B,QAAA,IAAI,IAAI,CAAC,WAAW,EAAE;YAClB,IACI,OAAO,CAAC,UAAU,CAAC;gBACnB,OAAO,CAAC,SAAS,CAAC;gBAClB,OAAO,CAAC,kBAAkB,CAAC;gBAC3B,OAAO,CAAC,UAAU,CAAC;AACnB,gBAAA,OAAO,CAAC,oBAAoB,CAAC,EAC/B;gBACE,IAAI,CAAC,aAAa,EAAE,CAAC;aACxB;AAAM,iBAAA,IAAI,OAAO,CAAC,YAAY,CAAC,EAAE;gBAC9B,IAAI,CAAC,cAAc,EAAE,CAAC;aACzB;SACJ;KACJ;IAEO,aAAa,GAAA;AACjB,QAAA,MAAM,CAAC,SAAS,EAAE,QAAQ,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC7E,IAAI,QAAQ,EAAE;YACV,IAAI,IAAI,CAAC,YAAY,CAAC,QAAQ,KAAK,KAAK,EAAE;AACtC,gBAAA,IAAI,CAAC,YAAY;qBACZ,UAAU,CAAC,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,EAAE,SAAS,CAAC;AACzD,qBAAA,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;qBACb,SAAS,CACN,GAAG,IAAG;AACF,oBAAA,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;AAC5B,iBAAC,EACD,CAAC,KAAY,KAAI;oBACb,IAAI,oCAAoC,EAAE,EAAE;wBACxC,OAAO,CAAC,KAAK,CAAC,CAAA,uBAAA,EAA0B,KAAK,CAAC,OAAO,CAAE,CAAA,CAAC,CAAC;qBAC5D;AACL,iBAAC,CACJ,CAAC;AACN,gBAAA,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC,CAAW,QAAA,EAAA,SAAS,GAAG,CAAA,CAAA,EAAI,SAAS,CAAA,CAAE,GAAG,CAAA,CAAE,CAAI,CAAA,EAAA,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAA,CAAE,CAAC,CAAC,CAAC;aACxH;iBAAM;AACH,gBAAA,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO;sBAC3B,IAAI,CAAC,YAAY,CAAC,sBAAsB,CAAC,IAAI,CAAC,OAAO,CAAC;AACxD,sBAAE,IAAI,CAAC,YAAY,CAAC,sBAAsB,EAAE,CAAC;AACjD,gBAAA,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC,YAAY,EAAE,CAAG,EAAA,YAAY,IAAI,IAAI,CAAC,QAAQ,CAAE,CAAA,CAAC,CAAC,CAAC;aACrF;SACJ;KACJ;IAEO,cAAc,GAAA;AAClB,QAAA,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,EAAE;YAC/B,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,CAAC,EAAE,WAAW,EAAE,CAAA,OAAA,EAAU,IAAI,CAAC,UAAU,CAAM,IAAA,CAAA,CAAC,CAAC;SAC1H;KACJ;;AAIO,IAAA,aAAa,CAAC,GAAe,EAAA;QACjC,IAAI,CAAC,eAAe,EAAE,CAAC;;;;QAKvB,MAAM,SAAS,GAAG,GAAG,CAAC,gBAAgB,CAAC,OAAO,CAAiC,CAAC;AAEhF,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;AACvC,YAAA,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,IAAI,GAAG,CAAC;SACnC;AAED,QAAA,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,EAAE;YAC7B,MAAM,QAAQ,GAAG,GAAG,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;AAC9C,YAAA,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;gBACrB,QAAQ,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,KAAa,KAAI;AACtC,oBAAA,IAAI,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,iBAAiB,CAAC,EAAE;wBACtD,KAAK,CAAC,YAAY,CAAC,MAAM,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;qBACrD;AACL,iBAAC,CAAC,CAAC;aACN;SACJ;;;;;;;;;AAUD,QAAA,IAAI,IAAI,CAAC,kBAAkB,EAAE;AACzB,YAAA,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;AACrB,YAAA,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;SAC/B;QAED,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAC/C,IAAI,CAAC,cAAc,EAAE,CAAC;KACzB;IAEO,eAAe,GAAA;AACnB,QAAA,MAAM,aAAa,GAAgB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;AACjE,QAAA,IAAI,UAAU,GAAG,aAAa,CAAC,UAAU,CAAC,MAAM,CAAC;;;;;;QAQjD,OAAO,UAAU,EAAE,EAAE;YACjB,MAAM,KAAK,GAAG,aAAa,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;;;AAInD,YAAA,IAAI,KAAK,CAAC,QAAQ,KAAK,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,WAAW,EAAE,KAAK,KAAK,EAAE;AAChE,gBAAA,aAAa,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;aACpC;SACJ;KACJ;;AAIO,IAAA,mBAAmB,CAAC,QAAgB,EAAA;AACxC,QAAA,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;YAClE,MAAM,MAAM,GAAG,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC5C,OAAO,QAAQ,CAAC,QAAQ,CAAC,IAAI,MAAM,CAAA,CAAE,CAAC,GAAG,QAAQ,GAAG,CAAA,EAAG,QAAQ,CAAI,CAAA,EAAA,MAAM,EAAE,CAAC;SAC/E;aAAM;AACH,YAAA,OAAO,QAAQ,CAAC;SACnB;KACJ;AAED;;;AAGG;AACK,IAAA,UAAU,CAAC,GAAe,EAAA;QAC9B,MAAM,aAAa,GAAG,GAAG,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;AACpD,QAAA,aAAa,CAAC,OAAO,CAAC,CAAC,CAAc,KAAI;YACrC,IAAI,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;gBACjC,CAAC,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,OAAO,GAAG,QAAQ,CAAC,QAAQ,CAAC,CAAC;aAC7E;YACD,IAAI,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE;gBACvC,CAAC,CAAC,KAAK,CAAC,QAAQ,GAAG,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,EAAE,OAAO,GAAG,QAAQ,CAAC,QAAQ,CAAC,CAAC;aACrF;AACL,SAAC,CAAC,CAAC;KACN;AAEO,IAAA,iBAAiB,CAAC,GAAe,EAAA;QACrC,MAAM,YAAY,GAAG,GAAG,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;AAChD,QAAA,YAAY,IAAI,YAAY,CAAC,MAAM,EAAE,CAAC;KACzC;8GA1LQ,OAAO,EAAA,IAAA,EAAA,CAAA,EAAA,KAAA,EAAA,EAAA,CAAA,SAAA,EAAA,EAAA,EAAA,KAAA,EAAA,EAAA,CAAA,UAAA,EAAA,EAAA,EAAA,KAAA,EAAAA,eAAA,EAAA,CAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA,EAAA;AAAP,IAAA,SAAA,IAAA,CAAA,IAAA,GAAA,EAAA,CAAA,oBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,IAAA,EAAA,OAAO,uPAoB4B,eAAe,CAAA,EAAA,OAAA,EAAA,CAAA,YAAA,EAAA,SAAA,CAAA,EAAA,WAAA,EAAA,CAAA,gBAAA,EAAA,aAAA,EASd,gBAAgB,CAGT,EAAA,kBAAA,EAAA,CAAA,uBAAA,EAAA,oBAAA,EAAA,gBAAgB,sJAxC1D,2BAA2B,EAAA,QAAA,EAAA,IAAA,EAAA,eAAA,EAAA,EAAA,CAAA,uBAAA,CAAA,MAAA,EAAA,aAAA,EAAA,EAAA,CAAA,iBAAA,CAAA,IAAA,EAAA,CAAA,CAAA,EAAA;;2FAQ5B,OAAO,EAAA,UAAA,EAAA,CAAA;kBAVnB,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;AACP,oBAAA,QAAQ,EAAE,sBAAsB;AAChC,oBAAA,QAAQ,EAAE,2BAA2B;oBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;AACrC,oBAAA,UAAU,EAAE,IAAI;AAChB,oBAAA,IAAI,EAAE;AACF,wBAAA,KAAK,EAAE,UAAU;AACpB,qBAAA;AACJ,iBAAA,CAAA;kIAQyB,QAAQ,EAAA,CAAA;sBAA7B,KAAK;uBAAC,aAAa,CAAA;gBAEM,gBAAgB,EAAA,CAAA;sBAAzC,KAAK;uBAAC,iBAAiB,CAAA;gBAKF,QAAQ,EAAA,CAAA;sBAA7B,KAAK;uBAAC,aAAa,CAAA;gBAM2C,UAAU,EAAA,CAAA;sBAAxE,KAAK;AAAC,gBAAA,IAAA,EAAA,CAAA,EAAE,KAAK,EAAE,eAAe,EAAE,SAAS,EAAE,eAAe,EAAE,CAAA;gBAExC,OAAO,EAAA,CAAA;sBAA3B,KAAK;uBAAC,YAAY,CAAA;gBAQnB,WAAW,EAAA,CAAA;sBAFV,WAAW;uBAAC,CAAwB,sBAAA,CAAA,CAAA;;sBACpC,KAAK;AAAC,gBAAA,IAAA,EAAA,CAAA,EAAE,KAAK,EAAE,gBAAgB,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAA;gBAI/D,kBAAkB,EAAA,CAAA;sBADjB,KAAK;AAAC,gBAAA,IAAA,EAAA,CAAA,EAAE,KAAK,EAAE,uBAAuB,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAA;;;MC7D7D,aAAa,CAAA;8GAAb,aAAa,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,QAAA,EAAA,CAAA,CAAA,EAAA;AAAb,IAAA,SAAA,IAAA,CAAA,IAAA,GAAA,EAAA,CAAA,mBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,aAAa,YAHZ,OAAO,EAAE,YAAY,EAAE,WAAW,aADlC,OAAO,CAAA,EAAA,CAAA,CAAA,EAAA;+GAIR,aAAa,EAAA,SAAA,EAFX,CAAC,iBAAiB,CAAC,sBAAsB,EAAE,CAAC,CAAC,EAAA,OAAA,EAAA,CADrC,YAAY,EAAE,WAAW,CAAA,EAAA,CAAA,CAAA,EAAA;;2FAGnC,aAAa,EAAA,UAAA,EAAA,CAAA;kBANzB,QAAQ;AAAC,YAAA,IAAA,EAAA,CAAA;AACN,oBAAA,YAAY,EAAE,EAAE;oBAChB,OAAO,EAAE,CAAC,OAAO,CAAC;AAClB,oBAAA,OAAO,EAAE,CAAC,OAAO,EAAE,YAAY,EAAE,WAAW,CAAC;AAC7C,oBAAA,SAAS,EAAE,CAAC,iBAAiB,CAAC,sBAAsB,EAAE,CAAC,CAAC;AAC3D,iBAAA,CAAA;;;ACXD;;AAEG;;;;"}
@@ -37,10 +37,10 @@ class ThyImageGroup {
37
37
  removeImage(index) {
38
38
  this.images.splice(index, 1);
39
39
  }
40
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyImageGroup, deps: [{ token: i0.Injector }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
41
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: ThyImageGroup, isStandalone: true, selector: "thy-image-group, [thyImageGroup]", ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
40
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyImageGroup, deps: [{ token: i0.Injector }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
41
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0", type: ThyImageGroup, isStandalone: true, selector: "thy-image-group, [thyImageGroup]", ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
42
42
  }
43
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyImageGroup, decorators: [{
43
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyImageGroup, decorators: [{
44
44
  type: Component,
45
45
  args: [{
46
46
  selector: 'thy-image-group, [thyImageGroup]',
@@ -450,10 +450,10 @@ class ThyImagePreview {
450
450
  updatePreviewImageWrapperTransform() {
451
451
  this.previewImageWrapperTransform = `translate3d(${this.position.x}px, ${this.position.y}px, 0)`;
452
452
  }
453
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyImagePreview, deps: [{ token: i1.ThyDialog }, { token: i2.ThyFullscreen }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i3.ThyNotifyService }, { token: i0.ElementRef }, { token: i4.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component }); }
454
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: ThyImagePreview, isStandalone: true, selector: "thy-image-preview", outputs: { downloadClicked: "downloadClicked" }, host: { properties: { "class.thy-image-preview-moving": "isDragging" }, classAttribute: "thy-image-preview-wrap" }, viewQueries: [{ propertyName: "imageRef", first: true, predicate: ["imgRef"], descendants: true }, { propertyName: "imagePreviewWrapper", first: true, predicate: ["imagePreviewWrapper"], descendants: true, static: true }], exportAs: ["thyImagePreview"], ngImport: i0, template: "<div class=\"thy-image-preview\" [class.thy-image-preview-fullscreen]=\"isFullScreen\">\n <div class=\"thy-image-preview-header pl-10 pr-8\" *ngIf=\"!isFullScreen\">\n <div class=\"thy-image-preview-header-info\">\n <p class=\"thy-image-name text-truncate\" [thyTooltipDisabled]=\"previewImage?.name?.length < 32\" [thyTooltip]=\"previewImage?.name\">\n {{ previewImage?.name }}\n </p>\n <span class=\"thy-image-size\"> {{ previewImage?.size }}</span>\n </div>\n <a thyAction thyIcon=\"close\" thyTooltip=\"\u9000\u51FA\u9884\u89C8\" href=\"javascript:;\" (click)=\"thyDialog.close()\"></a>\n </div>\n <a\n class=\"thy-image-preview-exit-fullscreen\"\n *ngIf=\"isFullScreen\"\n thyAction\n thyIcon=\"close\"\n thyTooltip=\"\u9000\u51FA\u9884\u89C8\"\n href=\"javascript:;\"\n (click)=\"thyFullscreen.exit()\"\n thyTooltip=\"\u9000\u51FA\u5168\u5C4F\"\n ></a>\n <div\n class=\"thy-image-preview-img-wrapper\"\n #imagePreviewWrapper\n cdkDrag\n [class.thy-image-preview-inside]=\"isInsideScreen\"\n [style.transform]=\"previewImageWrapperTransform\"\n [cdkDragFreeDragPosition]=\"position\"\n (cdkDragReleased)=\"dragReleased()\"\n >\n <ng-container *ngFor=\"let image of images; index as imageIndex\">\n <img\n #imgRef\n *ngIf=\"previewIndex === imageIndex && isLoadingDone\"\n class=\"thy-image-preview-img\"\n [src]=\"image.objectURL || image.src\"\n [style.transform]=\"previewImageTransform\"\n />\n </ng-container>\n <thy-loading [thyDone]=\"isLoadingDone\"></thy-loading>\n </div>\n\n <ng-container *ngIf=\"images.length > 1 && !isFullScreen\">\n <div\n class=\"thy-image-preview-switch-left\"\n [thyTooltipDisabled]=\"previewIndex <= 0\"\n thyTooltip=\"\u4E0A\u4E00\u5F20\"\n [class.thy-image-preview-switch-left-disabled]=\"previewIndex <= 0\"\n (click)=\"prev()\"\n >\n <thy-icon thyIconName=\"angle-left-bold\"></thy-icon>\n </div>\n <div\n class=\"thy-image-preview-switch-right\"\n thyTooltip=\"\u4E0B\u4E00\u5F20\"\n [thyTooltipDisabled]=\"previewIndex >= images.length - 1\"\n [class.thy-image-preview-switch-right-disabled]=\"previewIndex >= images.length - 1\"\n (click)=\"next()\"\n >\n <thy-icon thyIconName=\"angle-right-bold\"> </thy-icon>\n </div>\n </ng-container>\n <thy-actions thySize=\"xs\" class=\"thy-image-preview-operations py-3 px-4\" *ngIf=\"!isFullScreen\">\n <ng-container *ngFor=\"let option of previewOperations; let i = index\">\n <a\n *ngIf=\"!['original-scale', 'fit-screen', 'copyLink'].includes(option.type) || currentImageMode === option.type\"\n href=\"javascript:;\"\n thyAction\n [thyActionIcon]=\"option.icon\"\n [thyTooltip]=\"option.name\"\n [thyTooltipOffset]=\"13\"\n (click)=\"option.action(previewImage)\"\n ></a>\n <span class=\"mr-2\" *ngIf=\"option?.type === 'zoom-out'\"> {{ (zoom * 100).toFixed(0) + '%' }} </span>\n <thy-divider class=\"ml-2\" [thyVertical]=\"true\" *ngIf=\"option?.type === 'rotate-right'\"></thy-divider>\n <a\n *ngIf=\"option.type === 'copyLink'\"\n href=\"javascript:;\"\n thyAction\n [thyCopyTips]=\"option.name\"\n [thyActionIcon]=\"option.icon\"\n [thyCopyTipsOffset]=\"13\"\n (thyCopy)=\"copyLink($event)\"\n [thyCopyContent]=\"previewImageOriginSrc\"\n [thyShowNotify]=\"false\"\n ></a>\n </ng-container>\n <thy-divider [thyVertical]=\"true\"></thy-divider>\n <span class=\"thy-image-preview-operations-text\"> {{ previewIndex + 1 }} / {{ images.length }} </span>\n </thy-actions>\n</div>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { kind: "component", type: ThyAction, selector: "thy-action, [thyAction]", inputs: ["thyType", "thyIcon", "thyActionIcon", "thyActive", "thyActionActive", "thyTheme", "thyHoverIcon", "thyDisabled"] }, { kind: "directive", type: CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: ThyLoading, selector: "thy-loading", inputs: ["thyDone", "thyTip", "thyIsMask"] }, { kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "component", type: ThyActions, selector: "thy-actions", inputs: ["thySize"] }, { kind: "component", type: ThyDivider, selector: "thy-divider", inputs: ["thyVertical", "thyStyle", "thyColor", "thyText", "thyTextDirection", "thyDeeper"] }, { kind: "directive", type: ThyCopyDirective, selector: "[thyCopy]", inputs: ["thyCopySuccessText", "thyCopyTips", "thyCopyTipsOffset", "thyCopyContent", "thyShowNotify"], outputs: ["thyCopy"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
453
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyImagePreview, deps: [{ token: i1.ThyDialog }, { token: i2.ThyFullscreen }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i3.ThyNotifyService }, { token: i0.ElementRef }, { token: i4.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component }); }
454
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0", type: ThyImagePreview, isStandalone: true, selector: "thy-image-preview", outputs: { downloadClicked: "downloadClicked" }, host: { properties: { "class.thy-image-preview-moving": "isDragging" }, classAttribute: "thy-image-preview-wrap" }, viewQueries: [{ propertyName: "imageRef", first: true, predicate: ["imgRef"], descendants: true }, { propertyName: "imagePreviewWrapper", first: true, predicate: ["imagePreviewWrapper"], descendants: true, static: true }], exportAs: ["thyImagePreview"], ngImport: i0, template: "<div class=\"thy-image-preview\" [class.thy-image-preview-fullscreen]=\"isFullScreen\">\n <div class=\"thy-image-preview-header pl-10 pr-8\" *ngIf=\"!isFullScreen\">\n <div class=\"thy-image-preview-header-info\">\n <p class=\"thy-image-name text-truncate\" [thyTooltipDisabled]=\"previewImage?.name?.length < 32\" [thyTooltip]=\"previewImage?.name\">\n {{ previewImage?.name }}\n </p>\n <span class=\"thy-image-size\"> {{ previewImage?.size }}</span>\n </div>\n <a thyAction thyIcon=\"close\" thyTooltip=\"\u9000\u51FA\u9884\u89C8\" href=\"javascript:;\" (click)=\"thyDialog.close()\"></a>\n </div>\n <a\n class=\"thy-image-preview-exit-fullscreen\"\n *ngIf=\"isFullScreen\"\n thyAction\n thyIcon=\"close\"\n thyTooltip=\"\u9000\u51FA\u9884\u89C8\"\n href=\"javascript:;\"\n (click)=\"thyFullscreen.exit()\"\n thyTooltip=\"\u9000\u51FA\u5168\u5C4F\"\n ></a>\n <div\n class=\"thy-image-preview-img-wrapper\"\n #imagePreviewWrapper\n cdkDrag\n [class.thy-image-preview-inside]=\"isInsideScreen\"\n [style.transform]=\"previewImageWrapperTransform\"\n [cdkDragFreeDragPosition]=\"position\"\n (cdkDragReleased)=\"dragReleased()\"\n >\n <ng-container *ngFor=\"let image of images; index as imageIndex\">\n <img\n #imgRef\n *ngIf=\"previewIndex === imageIndex && isLoadingDone\"\n class=\"thy-image-preview-img\"\n [src]=\"image.objectURL || image.src\"\n [style.transform]=\"previewImageTransform\"\n />\n </ng-container>\n <thy-loading [thyDone]=\"isLoadingDone\"></thy-loading>\n </div>\n\n <ng-container *ngIf=\"images.length > 1 && !isFullScreen\">\n <div\n class=\"thy-image-preview-switch-left\"\n [thyTooltipDisabled]=\"previewIndex <= 0\"\n thyTooltip=\"\u4E0A\u4E00\u5F20\"\n [class.thy-image-preview-switch-left-disabled]=\"previewIndex <= 0\"\n (click)=\"prev()\"\n >\n <thy-icon thyIconName=\"angle-left-bold\"></thy-icon>\n </div>\n <div\n class=\"thy-image-preview-switch-right\"\n thyTooltip=\"\u4E0B\u4E00\u5F20\"\n [thyTooltipDisabled]=\"previewIndex >= images.length - 1\"\n [class.thy-image-preview-switch-right-disabled]=\"previewIndex >= images.length - 1\"\n (click)=\"next()\"\n >\n <thy-icon thyIconName=\"angle-right-bold\"> </thy-icon>\n </div>\n </ng-container>\n <thy-actions thySize=\"xs\" class=\"thy-image-preview-operations py-3 px-4\" *ngIf=\"!isFullScreen\">\n <ng-container *ngFor=\"let option of previewOperations; let i = index\">\n <a\n *ngIf=\"!['original-scale', 'fit-screen', 'copyLink'].includes(option.type) || currentImageMode === option.type\"\n href=\"javascript:;\"\n thyAction\n [thyActionIcon]=\"option.icon\"\n [thyTooltip]=\"option.name\"\n [thyTooltipOffset]=\"13\"\n (click)=\"option.action(previewImage)\"\n ></a>\n <span class=\"mr-2\" *ngIf=\"option?.type === 'zoom-out'\"> {{ (zoom * 100).toFixed(0) + '%' }} </span>\n <thy-divider class=\"ml-2\" [thyVertical]=\"true\" *ngIf=\"option?.type === 'rotate-right'\"></thy-divider>\n <a\n *ngIf=\"option.type === 'copyLink'\"\n href=\"javascript:;\"\n thyAction\n [thyCopyTips]=\"option.name\"\n [thyActionIcon]=\"option.icon\"\n [thyCopyTipsOffset]=\"13\"\n (thyCopy)=\"copyLink($event)\"\n [thyCopyContent]=\"previewImageOriginSrc\"\n [thyShowNotify]=\"false\"\n ></a>\n </ng-container>\n <thy-divider [thyVertical]=\"true\"></thy-divider>\n <span class=\"thy-image-preview-operations-text\"> {{ previewIndex + 1 }} / {{ images.length }} </span>\n </thy-actions>\n</div>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { kind: "component", type: ThyAction, selector: "thy-action, [thyAction]", inputs: ["thyType", "thyIcon", "thyActionIcon", "thyActive", "thyActionActive", "thyTheme", "thyHoverIcon", "thyDisabled"] }, { kind: "directive", type: CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: ThyLoading, selector: "thy-loading", inputs: ["thyDone", "thyTip", "thyIsMask"] }, { kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "component", type: ThyActions, selector: "thy-actions", inputs: ["thySize"] }, { kind: "component", type: ThyDivider, selector: "thy-divider", inputs: ["thyVertical", "thyStyle", "thyColor", "thyText", "thyTextDirection", "thyDeeper"] }, { kind: "directive", type: ThyCopyDirective, selector: "[thyCopy]", inputs: ["thyCopySuccessText", "thyCopyTips", "thyCopyTipsOffset", "thyCopyContent", "thyShowNotify"], outputs: ["thyCopy"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
455
455
  }
456
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyImagePreview, decorators: [{
456
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyImagePreview, decorators: [{
457
457
  type: Component,
458
458
  args: [{ selector: 'thy-image-preview', exportAs: 'thyImagePreview', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
459
459
  class: 'thy-image-preview-wrap',
@@ -542,10 +542,10 @@ class ThyImageService {
542
542
  this.ngUnsubscribe$.next();
543
543
  this.ngUnsubscribe$.complete();
544
544
  }
545
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyImageService, deps: [{ token: i1.ThyDialog }, { token: THY_IMAGE_DEFAULT_PREVIEW_OPTIONS, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
546
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyImageService }); }
545
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyImageService, deps: [{ token: i1.ThyDialog }, { token: THY_IMAGE_DEFAULT_PREVIEW_OPTIONS, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
546
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyImageService }); }
547
547
  }
548
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyImageService, decorators: [{
548
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyImageService, decorators: [{
549
549
  type: Injectable
550
550
  }], ctorParameters: () => [{ type: i1.ThyDialog }, { type: ThyImagePreviewConfig, decorators: [{
551
551
  type: Optional
@@ -648,10 +648,10 @@ class ThyImageDirective {
648
648
  this.parentGroup.removeImage(index);
649
649
  }
650
650
  }
651
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyImageDirective, deps: [{ token: ThyImageService }, { token: i0.Injector }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
652
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.2.3", type: ThyImageDirective, isStandalone: true, selector: "img[thyImage]", inputs: { thySrc: "thySrc", thyPreviewSrc: "thyPreviewSrc", thyOriginSrc: "thyOriginSrc", thyImageMeta: "thyImageMeta", thyDisablePreview: ["thyDisablePreview", "thyDisablePreview", booleanAttribute], thyResolveSize: ["thyResolveSize", "thyResolveSize", booleanAttribute] }, host: { listeners: { "click": "onPreview($event)" }, properties: { "class.thy-image-disabled": "thyDisablePreview" }, classAttribute: "thy-image" }, exportAs: ["thyImage"], usesOnChanges: true, ngImport: i0 }); }
651
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyImageDirective, deps: [{ token: ThyImageService }, { token: i0.Injector }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
652
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.0.0", type: ThyImageDirective, isStandalone: true, selector: "img[thyImage]", inputs: { thySrc: "thySrc", thyPreviewSrc: "thyPreviewSrc", thyOriginSrc: "thyOriginSrc", thyImageMeta: "thyImageMeta", thyDisablePreview: ["thyDisablePreview", "thyDisablePreview", booleanAttribute], thyResolveSize: ["thyResolveSize", "thyResolveSize", booleanAttribute] }, host: { listeners: { "click": "onPreview($event)" }, properties: { "class.thy-image-disabled": "thyDisablePreview" }, classAttribute: "thy-image" }, exportAs: ["thyImage"], usesOnChanges: true, ngImport: i0 }); }
653
653
  }
654
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyImageDirective, decorators: [{
654
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyImageDirective, decorators: [{
655
655
  type: Directive,
656
656
  args: [{
657
657
  selector: 'img[thyImage]',
@@ -680,8 +680,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
680
680
  }] } });
681
681
 
682
682
  class ThyImageModule {
683
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyImageModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
684
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.2.3", ngImport: i0, type: ThyImageModule, imports: [CommonModule,
683
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyImageModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
684
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.0", ngImport: i0, type: ThyImageModule, imports: [CommonModule,
685
685
  PortalModule,
686
686
  DragDropModule,
687
687
  ThyIconModule,
@@ -694,7 +694,7 @@ class ThyImageModule {
694
694
  ThyImageDirective,
695
695
  ThyImageGroup,
696
696
  ThyImagePreview], exports: [ThyImageDirective, ThyImageGroup, ThyImagePreview] }); }
697
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyImageModule, providers: [ThyImageService, THY_IMAGE_DEFAULT_PREVIEW_OPTIONS_PROVIDER], imports: [CommonModule,
697
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyImageModule, providers: [ThyImageService, THY_IMAGE_DEFAULT_PREVIEW_OPTIONS_PROVIDER], imports: [CommonModule,
698
698
  PortalModule,
699
699
  DragDropModule,
700
700
  ThyIconModule,
@@ -706,7 +706,7 @@ class ThyImageModule {
706
706
  ThyActionModule,
707
707
  ThyImagePreview] }); }
708
708
  }
709
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyImageModule, decorators: [{
709
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyImageModule, decorators: [{
710
710
  type: NgModule,
711
711
  args: [{
712
712
  exports: [ThyImageDirective, ThyImageGroup, ThyImagePreview],
@@ -301,8 +301,8 @@ class ThyInputNumber extends TabIndexDisabledControlValueAccessorMixin {
301
301
  ngOnDestroy() {
302
302
  this.hostFocusControl.destroy();
303
303
  }
304
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyInputNumber, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
305
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.2.3", type: ThyInputNumber, isStandalone: true, selector: "thy-input-number", inputs: { thyAutoFocus: ["thyAutoFocus", "thyAutoFocus", booleanAttribute], thyPlaceholder: "thyPlaceholder", thyDisabled: ["thyDisabled", "thyDisabled", booleanAttribute], thyMax: "thyMax", thyMin: "thyMin", thyStep: ["thyStep", "thyStep", numberAttribute], thyStepDelay: ["thyStepDelay", "thyStepDelay", numberAttribute], thySize: "thySize", thyPrecision: "thyPrecision", thySuffix: "thySuffix" }, outputs: { thyBlur: "thyBlur", thyFocus: "thyFocus" }, host: { properties: { "attr.tabindex": "tabIndex" }, classAttribute: "thy-input-number" }, providers: [
304
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyInputNumber, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
305
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.0", type: ThyInputNumber, isStandalone: true, selector: "thy-input-number", inputs: { thyAutoFocus: ["thyAutoFocus", "thyAutoFocus", booleanAttribute], thyPlaceholder: "thyPlaceholder", thyDisabled: ["thyDisabled", "thyDisabled", booleanAttribute], thyMax: "thyMax", thyMin: "thyMin", thyStep: ["thyStep", "thyStep", numberAttribute], thyStepDelay: ["thyStepDelay", "thyStepDelay", numberAttribute], thySize: "thySize", thyPrecision: "thyPrecision", thySuffix: "thySuffix" }, outputs: { thyBlur: "thyBlur", thyFocus: "thyFocus" }, host: { properties: { "attr.tabindex": "tabIndex" }, classAttribute: "thy-input-number" }, providers: [
306
306
  {
307
307
  provide: NG_VALUE_ACCESSOR,
308
308
  useExisting: forwardRef(() => ThyInputNumber),
@@ -310,7 +310,7 @@ class ThyInputNumber extends TabIndexDisabledControlValueAccessorMixin {
310
310
  }
311
311
  ], viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["input"], descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"input-number-handler-wrap\" [class.input-number-disabled]=\"thyDisabled\">\n <span\n unselectable=\"unselectable\"\n class=\"input-number-handler input-number-handler-up\"\n (mousedown)=\"up($event)\"\n (mouseup)=\"stop()\"\n (mouseleave)=\"stop()\"\n [class.disabled]=\"disabledUp\">\n <thy-icon thyIconName=\"angle-up\"></thy-icon>\n </span>\n <span\n unselectable=\"unselectable\"\n class=\"input-number-handler input-number-handler-down\"\n (mousedown)=\"down($event)\"\n (mouseup)=\"stop()\"\n (mouseleave)=\"stop()\"\n [class.disabled]=\"disabledDown\">\n <thy-icon thyIconName=\"angle-down\"></thy-icon>\n </span>\n</div>\n<input\n thyInput\n #input\n autocomplete=\"off\"\n class=\"input-number-input form-control\"\n [thySize]=\"thySize\"\n [thyAutofocus]=\"thyAutoFocus\"\n [disabled]=\"thyDisabled\"\n [attr.min]=\"thyMin\"\n [attr.max]=\"thyMax\"\n [placeholder]=\"thyPlaceholder\"\n [attr.step]=\"thyStep\"\n (keydown)=\"onKeyDown($event)\"\n (keyup)=\"stop()\"\n [(ngModel)]=\"displayValue\"\n (ngModelChange)=\"onModelChange($event)\"\n (focus)=\"onInputFocus($event)\"\n tabindex=\"-1\" />\n", dependencies: [{ kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize"], exportAs: ["thyInput"] }, { kind: "directive", type: ThyAutofocusDirective, selector: "input[thyAutofocus],textarea[thyAutofocus]", inputs: ["thyAutofocus", "thyAutoSelect"] }, { kind: "ngmodule", type: FormsModule }, { 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.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
312
312
  }
313
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyInputNumber, decorators: [{
313
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyInputNumber, decorators: [{
314
314
  type: Component,
315
315
  args: [{ selector: 'thy-input-number', providers: [
316
316
  {
@@ -356,11 +356,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
356
356
  }] } });
357
357
 
358
358
  class ThyInputNumberModule {
359
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyInputNumberModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
360
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.2.3", ngImport: i0, type: ThyInputNumberModule, imports: [CommonModule, FormsModule, ThySharedModule, ThyIconModule, ThyInputModule, ThyFormModule, ThyInputNumber], exports: [ThyInputNumber] }); }
361
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyInputNumberModule, imports: [CommonModule, FormsModule, ThySharedModule, ThyIconModule, ThyInputModule, ThyFormModule, ThyInputNumber] }); }
359
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyInputNumberModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
360
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.0", ngImport: i0, type: ThyInputNumberModule, imports: [CommonModule, FormsModule, ThySharedModule, ThyIconModule, ThyInputModule, ThyFormModule, ThyInputNumber], exports: [ThyInputNumber] }); }
361
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyInputNumberModule, imports: [CommonModule, FormsModule, ThySharedModule, ThyIconModule, ThyInputModule, ThyFormModule, ThyInputNumber] }); }
362
362
  }
363
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyInputNumberModule, decorators: [{
363
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ThyInputNumberModule, decorators: [{
364
364
  type: NgModule,
365
365
  args: [{
366
366
  imports: [CommonModule, FormsModule, ThySharedModule, ThyIconModule, ThyInputModule, ThyFormModule, ThyInputNumber],