ngx-tethys 17.0.1 → 17.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (381) hide show
  1. package/CHANGELOG.md +9 -0
  2. package/action/action.component.d.ts +3 -0
  3. package/affix/affix.component.d.ts +2 -0
  4. package/alert/alert.component.d.ts +1 -0
  5. package/anchor/anchor.component.d.ts +3 -0
  6. package/arrow-switcher/arrow-switcher.component.d.ts +1 -0
  7. package/autocomplete/autocomplete.component.d.ts +2 -3
  8. package/autocomplete/autocomplete.trigger.directive.d.ts +3 -0
  9. package/avatar/avatar.component.d.ts +4 -0
  10. package/back-top/back-top.component.d.ts +1 -0
  11. package/badge/badge.component.d.ts +5 -0
  12. package/button/button-icon.component.d.ts +2 -0
  13. package/button/button.component.d.ts +2 -0
  14. package/card/card.component.d.ts +3 -0
  15. package/card/content.component.d.ts +2 -1
  16. package/carousel/carousel.component.d.ts +5 -0
  17. package/cascader/cascader-li.component.d.ts +9 -2
  18. package/cascader/cascader-search-option.component.d.ts +7 -2
  19. package/cascader/cascader.component.d.ts +23 -2
  20. package/cascader/styles/cascader.scss +1 -0
  21. package/cascader/types.d.ts +1 -0
  22. package/checkbox/checkbox.component.d.ts +1 -0
  23. package/collapse/collapse-item.component.d.ts +2 -0
  24. package/collapse/collapse.component.d.ts +1 -0
  25. package/color-picker/color-picker-panel.component.d.ts +1 -0
  26. package/color-picker/color-picker.component.d.ts +7 -1
  27. package/copy/copy.directive.d.ts +1 -0
  28. package/core/behaviors/decorators.d.ts +6 -0
  29. package/date-picker/abstract-picker.component.d.ts +8 -1
  30. package/date-picker/abstract-picker.directive.d.ts +4 -0
  31. package/date-picker/base-picker.component.d.ts +2 -0
  32. package/date-picker/lib/calendar/calendar-footer.component.d.ts +1 -0
  33. package/date-picker/lib/popups/inner-popup.component.d.ts +1 -0
  34. package/date-picker/picker.component.d.ts +1 -0
  35. package/date-range/date-range.component.d.ts +2 -0
  36. package/dialog/body/dialog-body.component.d.ts +2 -1
  37. package/dialog/footer/dialog-footer.component.d.ts +1 -0
  38. package/dialog/header/dialog-header.component.d.ts +1 -0
  39. package/divider/divider.component.d.ts +2 -0
  40. package/drag-drop/drag-handle.directive.d.ts +1 -0
  41. package/drag-drop/drag.directive.d.ts +1 -0
  42. package/drag-drop/drop-container.directive.d.ts +1 -0
  43. package/dropdown/dropdown-menu-item.directive.d.ts +3 -1
  44. package/dropdown/dropdown-menu.component.d.ts +1 -0
  45. package/dropdown/dropdown.directive.d.ts +3 -0
  46. package/empty/empty.component.d.ts +1 -0
  47. package/esm2022/action/action.component.mjs +9 -22
  48. package/esm2022/affix/affix.component.mjs +8 -15
  49. package/esm2022/alert/alert.component.mjs +5 -10
  50. package/esm2022/anchor/anchor.component.mjs +10 -20
  51. package/esm2022/arrow-switcher/arrow-switcher.component.mjs +5 -11
  52. package/esm2022/autocomplete/autocomplete.component.mjs +5 -23
  53. package/esm2022/autocomplete/autocomplete.trigger.directive.mjs +9 -20
  54. package/esm2022/avatar/avatar.component.mjs +14 -30
  55. package/esm2022/back-top/back-top.component.mjs +6 -10
  56. package/esm2022/badge/badge.component.mjs +15 -37
  57. package/esm2022/button/button-icon.component.mjs +9 -20
  58. package/esm2022/button/button.component.mjs +7 -16
  59. package/esm2022/card/card.component.mjs +6 -20
  60. package/esm2022/card/content.component.mjs +5 -6
  61. package/esm2022/carousel/carousel.component.mjs +13 -30
  62. package/esm2022/cascader/cascader-li.component.mjs +16 -31
  63. package/esm2022/cascader/cascader-search-option.component.mjs +12 -21
  64. package/esm2022/cascader/cascader.component.mjs +32 -52
  65. package/esm2022/cascader/types.mjs +1 -1
  66. package/esm2022/checkbox/checkbox.component.mjs +7 -13
  67. package/esm2022/collapse/collapse-item.component.mjs +8 -15
  68. package/esm2022/collapse/collapse.component.mjs +5 -10
  69. package/esm2022/color-picker/color-picker-panel.component.mjs +5 -10
  70. package/esm2022/color-picker/color-picker.component.mjs +17 -37
  71. package/esm2022/copy/copy.directive.mjs +5 -10
  72. package/esm2022/core/behaviors/decorators.mjs +7 -44
  73. package/esm2022/date-picker/abstract-picker.component.mjs +21 -45
  74. package/esm2022/date-picker/abstract-picker.directive.mjs +11 -27
  75. package/esm2022/date-picker/base-picker.component.mjs +8 -15
  76. package/esm2022/date-picker/lib/calendar/calendar-footer.component.mjs +5 -10
  77. package/esm2022/date-picker/lib/popups/inner-popup.component.mjs +7 -6
  78. package/esm2022/date-picker/picker.component.mjs +6 -10
  79. package/esm2022/date-range/date-range.component.mjs +7 -15
  80. package/esm2022/dialog/body/dialog-body.component.mjs +6 -6
  81. package/esm2022/dialog/footer/dialog-footer.component.mjs +6 -13
  82. package/esm2022/dialog/header/dialog-header.component.mjs +6 -10
  83. package/esm2022/divider/divider.component.mjs +7 -15
  84. package/esm2022/drag-drop/drag-handle.directive.mjs +5 -13
  85. package/esm2022/drag-drop/drag.directive.mjs +5 -11
  86. package/esm2022/drag-drop/drop-container.directive.mjs +5 -10
  87. package/esm2022/dropdown/dropdown-menu-item.directive.mjs +9 -19
  88. package/esm2022/dropdown/dropdown-menu.component.mjs +6 -9
  89. package/esm2022/dropdown/dropdown.directive.mjs +8 -22
  90. package/esm2022/empty/empty.component.mjs +7 -13
  91. package/esm2022/flexible-text/flexible-text.component.mjs +4 -11
  92. package/esm2022/form/form-group-error/form-group-error.component.mjs +5 -10
  93. package/esm2022/form/form-group-label.directive.mjs +6 -6
  94. package/esm2022/form/form-group.component.mjs +13 -17
  95. package/esm2022/icon/icon.component.mjs +6 -20
  96. package/esm2022/image/image.directive.mjs +7 -15
  97. package/esm2022/input/input-search.component.mjs +6 -11
  98. package/esm2022/input/input.component.mjs +7 -15
  99. package/esm2022/input-number/input-number.component.mjs +12 -25
  100. package/esm2022/layout/header.component.mjs +9 -19
  101. package/esm2022/layout/sidebar-header.component.mjs +5 -10
  102. package/esm2022/layout/sidebar.component.mjs +22 -45
  103. package/esm2022/list/list.component.mjs +5 -11
  104. package/esm2022/list/selection/selection-list.mjs +13 -10
  105. package/esm2022/loading/loading.component.mjs +9 -20
  106. package/esm2022/menu/group/menu-group.component.mjs +12 -38
  107. package/esm2022/menu/item/action/menu-item-action.component.mjs +5 -10
  108. package/esm2022/menu/item/name/menu-item-name.component.mjs +5 -10
  109. package/esm2022/menu/menu.component.mjs +5 -10
  110. package/esm2022/nav/icon-nav/icon-nav-link.directive.mjs +6 -6
  111. package/esm2022/nav/nav-ink-bar.directive.mjs +7 -15
  112. package/esm2022/nav/nav-item.directive.mjs +10 -20
  113. package/esm2022/nav/nav.component.mjs +12 -25
  114. package/esm2022/pagination/pagination.component.mjs +18 -68
  115. package/esm2022/popover/popover.directive.mjs +12 -33
  116. package/esm2022/progress/progress-circle.component.mjs +9 -20
  117. package/esm2022/progress/progress-strip.component.mjs +5 -11
  118. package/esm2022/progress/progress.component.mjs +11 -23
  119. package/esm2022/property/properties.component.mjs +5 -10
  120. package/esm2022/property/property-item.component.mjs +8 -15
  121. package/esm2022/property-operation/property-operation.component.mjs +16 -37
  122. package/esm2022/radio/group/radio-group.component.mjs +6 -21
  123. package/esm2022/rate/rate-item.component.mjs +5 -10
  124. package/esm2022/rate/rate.component.mjs +16 -25
  125. package/esm2022/resizable/resizable.directive.mjs +24 -55
  126. package/esm2022/resizable/resize-handle.component.mjs +6 -10
  127. package/esm2022/resizable/resize-handles.component.mjs +5 -10
  128. package/esm2022/segment/segment-item.component.mjs +5 -10
  129. package/esm2022/segment/segment.component.mjs +7 -16
  130. package/esm2022/select/custom-select/custom-select.component.mjs +30 -65
  131. package/esm2022/select/native-select/native-select.component.mjs +6 -10
  132. package/esm2022/shared/base-form-check.component.mjs +10 -20
  133. package/esm2022/shared/directives/thy-autofocus.directive.mjs +10 -15
  134. package/esm2022/shared/directives/thy-scroll.directive.mjs +6 -13
  135. package/esm2022/shared/directives/thy-show.mjs +5 -11
  136. package/esm2022/shared/option/group/option-group.component.mjs +5 -10
  137. package/esm2022/shared/option/list-option/list-option.component.mjs +6 -13
  138. package/esm2022/shared/option/option.component.mjs +5 -11
  139. package/esm2022/shared/select/select-control/select-control.component.mjs +17 -44
  140. package/esm2022/skeleton/skeleton-circle.component.mjs +6 -9
  141. package/esm2022/skeleton/skeleton-rectangle.component.mjs +6 -9
  142. package/esm2022/skeleton/skeleton.component.mjs +5 -10
  143. package/esm2022/skeleton/stylized/bullet-list.component.mjs +6 -9
  144. package/esm2022/skeleton/stylized/list.component.mjs +6 -9
  145. package/esm2022/skeleton/stylized/paragraph.component.mjs +6 -9
  146. package/esm2022/slide/slide-body/slide-body-section.component.mjs +6 -6
  147. package/esm2022/slider/slider.component.mjs +18 -35
  148. package/esm2022/space/space.component.mjs +6 -10
  149. package/esm2022/stepper/step-header.component.mjs +9 -20
  150. package/esm2022/stepper/stepper.component.mjs +7 -16
  151. package/esm2022/switch/switch.component.mjs +12 -17
  152. package/esm2022/table/table-column.component.mjs +9 -31
  153. package/esm2022/table/table-skeleton.component.mjs +8 -14
  154. package/esm2022/table/table.component.mjs +32 -83
  155. package/esm2022/tabs/tab.component.mjs +5 -10
  156. package/esm2022/tabs/tabs.component.mjs +8 -15
  157. package/esm2022/tag/tag.component.mjs +6 -10
  158. package/esm2022/time-picker/time-picker-panel.component.mjs +8 -15
  159. package/esm2022/time-picker/time-picker.component.mjs +20 -46
  160. package/esm2022/timeline/timeline.component.mjs +5 -10
  161. package/esm2022/tooltip/tooltip.directive.mjs +11 -34
  162. package/esm2022/tree/tree-node.component.mjs +17 -40
  163. package/esm2022/tree/tree.component.mjs +19 -47
  164. package/esm2022/tree-select/tree-select.component.mjs +18 -40
  165. package/esm2022/upload/file-select-base.mjs +7 -6
  166. package/esm2022/upload/file-select.component.mjs +11 -26
  167. package/esm2022/version.mjs +2 -2
  168. package/esm2022/vote/vote.component.mjs +11 -33
  169. package/esm2022/watermark/watermark.directive.mjs +6 -10
  170. package/fesm2022/ngx-tethys-action.mjs +9 -21
  171. package/fesm2022/ngx-tethys-action.mjs.map +1 -1
  172. package/fesm2022/ngx-tethys-affix.mjs +6 -14
  173. package/fesm2022/ngx-tethys-affix.mjs.map +1 -1
  174. package/fesm2022/ngx-tethys-alert.mjs +4 -9
  175. package/fesm2022/ngx-tethys-alert.mjs.map +1 -1
  176. package/fesm2022/ngx-tethys-anchor.mjs +8 -19
  177. package/fesm2022/ngx-tethys-anchor.mjs.map +1 -1
  178. package/fesm2022/ngx-tethys-arrow-switcher.mjs +4 -10
  179. package/fesm2022/ngx-tethys-arrow-switcher.mjs.map +1 -1
  180. package/fesm2022/ngx-tethys-autocomplete.mjs +14 -39
  181. package/fesm2022/ngx-tethys-autocomplete.mjs.map +1 -1
  182. package/fesm2022/ngx-tethys-avatar.mjs +14 -29
  183. package/fesm2022/ngx-tethys-avatar.mjs.map +1 -1
  184. package/fesm2022/ngx-tethys-back-top.mjs +5 -9
  185. package/fesm2022/ngx-tethys-back-top.mjs.map +1 -1
  186. package/fesm2022/ngx-tethys-badge.mjs +14 -36
  187. package/fesm2022/ngx-tethys-badge.mjs.map +1 -1
  188. package/fesm2022/ngx-tethys-button.mjs +13 -30
  189. package/fesm2022/ngx-tethys-button.mjs.map +1 -1
  190. package/fesm2022/ngx-tethys-card.mjs +8 -23
  191. package/fesm2022/ngx-tethys-card.mjs.map +1 -1
  192. package/fesm2022/ngx-tethys-carousel.mjs +12 -29
  193. package/fesm2022/ngx-tethys-carousel.mjs.map +1 -1
  194. package/fesm2022/ngx-tethys-cascader.mjs +55 -95
  195. package/fesm2022/ngx-tethys-cascader.mjs.map +1 -1
  196. package/fesm2022/ngx-tethys-checkbox.mjs +5 -12
  197. package/fesm2022/ngx-tethys-checkbox.mjs.map +1 -1
  198. package/fesm2022/ngx-tethys-collapse.mjs +10 -20
  199. package/fesm2022/ngx-tethys-collapse.mjs.map +1 -1
  200. package/fesm2022/ngx-tethys-color-picker.mjs +19 -42
  201. package/fesm2022/ngx-tethys-color-picker.mjs.map +1 -1
  202. package/fesm2022/ngx-tethys-copy.mjs +4 -9
  203. package/fesm2022/ngx-tethys-copy.mjs.map +1 -1
  204. package/fesm2022/ngx-tethys-core.mjs +6 -43
  205. package/fesm2022/ngx-tethys-core.mjs.map +1 -1
  206. package/fesm2022/ngx-tethys-date-picker.mjs +45 -93
  207. package/fesm2022/ngx-tethys-date-picker.mjs.map +1 -1
  208. package/fesm2022/ngx-tethys-date-range.mjs +6 -14
  209. package/fesm2022/ngx-tethys-date-range.mjs.map +1 -1
  210. package/fesm2022/ngx-tethys-dialog.mjs +13 -21
  211. package/fesm2022/ngx-tethys-dialog.mjs.map +1 -1
  212. package/fesm2022/ngx-tethys-divider.mjs +6 -14
  213. package/fesm2022/ngx-tethys-divider.mjs.map +1 -1
  214. package/fesm2022/ngx-tethys-drag-drop.mjs +10 -25
  215. package/fesm2022/ngx-tethys-drag-drop.mjs.map +1 -1
  216. package/fesm2022/ngx-tethys-dropdown.mjs +19 -42
  217. package/fesm2022/ngx-tethys-dropdown.mjs.map +1 -1
  218. package/fesm2022/ngx-tethys-empty.mjs +5 -12
  219. package/fesm2022/ngx-tethys-empty.mjs.map +1 -1
  220. package/fesm2022/ngx-tethys-flexible-text.mjs +3 -10
  221. package/fesm2022/ngx-tethys-flexible-text.mjs.map +1 -1
  222. package/fesm2022/ngx-tethys-form.mjs +19 -25
  223. package/fesm2022/ngx-tethys-form.mjs.map +1 -1
  224. package/fesm2022/ngx-tethys-icon.mjs +5 -19
  225. package/fesm2022/ngx-tethys-icon.mjs.map +1 -1
  226. package/fesm2022/ngx-tethys-image.mjs +7 -14
  227. package/fesm2022/ngx-tethys-image.mjs.map +1 -1
  228. package/fesm2022/ngx-tethys-input-number.mjs +11 -24
  229. package/fesm2022/ngx-tethys-input-number.mjs.map +1 -1
  230. package/fesm2022/ngx-tethys-input.mjs +10 -21
  231. package/fesm2022/ngx-tethys-input.mjs.map +1 -1
  232. package/fesm2022/ngx-tethys-layout.mjs +31 -64
  233. package/fesm2022/ngx-tethys-layout.mjs.map +1 -1
  234. package/fesm2022/ngx-tethys-list.mjs +16 -18
  235. package/fesm2022/ngx-tethys-list.mjs.map +1 -1
  236. package/fesm2022/ngx-tethys-loading.mjs +8 -19
  237. package/fesm2022/ngx-tethys-loading.mjs.map +1 -1
  238. package/fesm2022/ngx-tethys-menu.mjs +20 -55
  239. package/fesm2022/ngx-tethys-menu.mjs.map +1 -1
  240. package/fesm2022/ngx-tethys-nav.mjs +28 -55
  241. package/fesm2022/ngx-tethys-nav.mjs.map +1 -1
  242. package/fesm2022/ngx-tethys-pagination.mjs +17 -67
  243. package/fesm2022/ngx-tethys-pagination.mjs.map +1 -1
  244. package/fesm2022/ngx-tethys-popover.mjs +11 -32
  245. package/fesm2022/ngx-tethys-popover.mjs.map +1 -1
  246. package/fesm2022/ngx-tethys-progress.mjs +20 -45
  247. package/fesm2022/ngx-tethys-progress.mjs.map +1 -1
  248. package/fesm2022/ngx-tethys-property-operation.mjs +14 -36
  249. package/fesm2022/ngx-tethys-property-operation.mjs.map +1 -1
  250. package/fesm2022/ngx-tethys-property.mjs +10 -21
  251. package/fesm2022/ngx-tethys-property.mjs.map +1 -1
  252. package/fesm2022/ngx-tethys-radio.mjs +5 -19
  253. package/fesm2022/ngx-tethys-radio.mjs.map +1 -1
  254. package/fesm2022/ngx-tethys-rate.mjs +18 -30
  255. package/fesm2022/ngx-tethys-rate.mjs.map +1 -1
  256. package/fesm2022/ngx-tethys-resizable.mjs +29 -66
  257. package/fesm2022/ngx-tethys-resizable.mjs.map +1 -1
  258. package/fesm2022/ngx-tethys-segment.mjs +10 -21
  259. package/fesm2022/ngx-tethys-segment.mjs.map +1 -1
  260. package/fesm2022/ngx-tethys-select.mjs +32 -70
  261. package/fesm2022/ngx-tethys-select.mjs.map +1 -1
  262. package/fesm2022/ngx-tethys-shared.mjs +49 -105
  263. package/fesm2022/ngx-tethys-shared.mjs.map +1 -1
  264. package/fesm2022/ngx-tethys-skeleton.mjs +20 -38
  265. package/fesm2022/ngx-tethys-skeleton.mjs.map +1 -1
  266. package/fesm2022/ngx-tethys-slide.mjs +6 -5
  267. package/fesm2022/ngx-tethys-slide.mjs.map +1 -1
  268. package/fesm2022/ngx-tethys-slider.mjs +17 -34
  269. package/fesm2022/ngx-tethys-slider.mjs.map +1 -1
  270. package/fesm2022/ngx-tethys-space.mjs +5 -9
  271. package/fesm2022/ngx-tethys-space.mjs.map +1 -1
  272. package/fesm2022/ngx-tethys-stepper.mjs +13 -31
  273. package/fesm2022/ngx-tethys-stepper.mjs.map +1 -1
  274. package/fesm2022/ngx-tethys-switch.mjs +11 -16
  275. package/fesm2022/ngx-tethys-switch.mjs.map +1 -1
  276. package/fesm2022/ngx-tethys-table.mjs +43 -120
  277. package/fesm2022/ngx-tethys-table.mjs.map +1 -1
  278. package/fesm2022/ngx-tethys-tabs.mjs +10 -20
  279. package/fesm2022/ngx-tethys-tabs.mjs.map +1 -1
  280. package/fesm2022/ngx-tethys-tag.mjs +5 -9
  281. package/fesm2022/ngx-tethys-tag.mjs.map +1 -1
  282. package/fesm2022/ngx-tethys-time-picker.mjs +24 -55
  283. package/fesm2022/ngx-tethys-time-picker.mjs.map +1 -1
  284. package/fesm2022/ngx-tethys-timeline.mjs +4 -9
  285. package/fesm2022/ngx-tethys-timeline.mjs.map +1 -1
  286. package/fesm2022/ngx-tethys-tooltip.mjs +10 -33
  287. package/fesm2022/ngx-tethys-tooltip.mjs.map +1 -1
  288. package/fesm2022/ngx-tethys-tree-select.mjs +17 -39
  289. package/fesm2022/ngx-tethys-tree-select.mjs.map +1 -1
  290. package/fesm2022/ngx-tethys-tree.mjs +33 -82
  291. package/fesm2022/ngx-tethys-tree.mjs.map +1 -1
  292. package/fesm2022/ngx-tethys-upload.mjs +15 -28
  293. package/fesm2022/ngx-tethys-upload.mjs.map +1 -1
  294. package/fesm2022/ngx-tethys-vote.mjs +10 -32
  295. package/fesm2022/ngx-tethys-vote.mjs.map +1 -1
  296. package/fesm2022/ngx-tethys-watermark.mjs +5 -9
  297. package/fesm2022/ngx-tethys-watermark.mjs.map +1 -1
  298. package/fesm2022/ngx-tethys.mjs +1 -1
  299. package/fesm2022/ngx-tethys.mjs.map +1 -1
  300. package/flexible-text/flexible-text.component.d.ts +1 -0
  301. package/form/form-group-error/form-group-error.component.d.ts +1 -0
  302. package/form/form-group-label.directive.d.ts +2 -1
  303. package/form/form-group.component.d.ts +5 -2
  304. package/icon/icon.component.d.ts +3 -0
  305. package/image/image.directive.d.ts +2 -0
  306. package/input/input-search.component.d.ts +1 -0
  307. package/input/input.component.d.ts +2 -0
  308. package/input-number/input-number.component.d.ts +4 -0
  309. package/layout/header.component.d.ts +5 -2
  310. package/layout/sidebar-header.component.d.ts +1 -0
  311. package/layout/sidebar.component.d.ts +14 -4
  312. package/list/list.component.d.ts +1 -0
  313. package/list/selection/selection-list.d.ts +4 -1
  314. package/loading/loading.component.d.ts +4 -2
  315. package/menu/group/menu-group.component.d.ts +6 -0
  316. package/menu/item/action/menu-item-action.component.d.ts +1 -0
  317. package/menu/item/name/menu-item-name.component.d.ts +1 -0
  318. package/menu/menu.component.d.ts +1 -0
  319. package/nav/icon-nav/icon-nav-link.directive.d.ts +2 -1
  320. package/nav/nav-ink-bar.directive.d.ts +2 -0
  321. package/nav/nav-item.directive.d.ts +3 -0
  322. package/nav/nav.component.d.ts +4 -0
  323. package/package.json +1 -1
  324. package/pagination/pagination.component.d.ts +11 -0
  325. package/popover/popover.directive.d.ts +5 -0
  326. package/progress/progress-circle.component.d.ts +3 -0
  327. package/progress/progress-strip.component.d.ts +1 -0
  328. package/progress/progress.component.d.ts +3 -0
  329. package/property/properties.component.d.ts +1 -0
  330. package/property/property-item.component.d.ts +2 -0
  331. package/property-operation/property-operation.component.d.ts +5 -0
  332. package/radio/group/radio-group.component.d.ts +2 -2
  333. package/rate/rate-item.component.d.ts +1 -0
  334. package/rate/rate.component.d.ts +5 -1
  335. package/resizable/resizable.directive.d.ts +10 -0
  336. package/resizable/resize-handle.component.d.ts +1 -0
  337. package/resizable/resize-handles.component.d.ts +1 -0
  338. package/schematics/version.d.ts +1 -1
  339. package/schematics/version.js +1 -1
  340. package/segment/segment-item.component.d.ts +1 -0
  341. package/segment/segment.component.d.ts +2 -0
  342. package/select/custom-select/custom-select.component.d.ts +12 -1
  343. package/select/native-select/native-select.component.d.ts +1 -0
  344. package/shared/base-form-check.component.d.ts +2 -0
  345. package/shared/directives/thy-autofocus.directive.d.ts +3 -1
  346. package/shared/directives/thy-scroll.directive.d.ts +1 -0
  347. package/shared/directives/thy-show.d.ts +1 -0
  348. package/shared/option/group/option-group.component.d.ts +1 -0
  349. package/shared/option/list-option/list-option.component.d.ts +1 -0
  350. package/shared/option/option.component.d.ts +1 -0
  351. package/shared/option/styles/select-dropdown.scss +1 -0
  352. package/shared/select/select-control/select-control.component.d.ts +7 -0
  353. package/skeleton/skeleton-circle.component.d.ts +1 -0
  354. package/skeleton/skeleton-rectangle.component.d.ts +1 -0
  355. package/skeleton/skeleton.component.d.ts +1 -0
  356. package/skeleton/stylized/bullet-list.component.d.ts +1 -0
  357. package/skeleton/stylized/list.component.d.ts +1 -0
  358. package/skeleton/stylized/paragraph.component.d.ts +1 -0
  359. package/slide/slide-body/slide-body-section.component.d.ts +2 -1
  360. package/slider/slider.component.d.ts +6 -1
  361. package/space/space.component.d.ts +1 -0
  362. package/stepper/step-header.component.d.ts +3 -0
  363. package/stepper/stepper.component.d.ts +2 -0
  364. package/switch/switch.component.d.ts +3 -1
  365. package/table/table-column.component.d.ts +7 -2
  366. package/table/table-skeleton.component.d.ts +2 -0
  367. package/table/table.component.d.ts +14 -0
  368. package/tabs/tab.component.d.ts +1 -0
  369. package/tabs/tabs.component.d.ts +2 -0
  370. package/tag/tag.component.d.ts +1 -0
  371. package/time-picker/time-picker-panel.component.d.ts +2 -0
  372. package/time-picker/time-picker.component.d.ts +6 -2
  373. package/timeline/timeline.component.d.ts +1 -0
  374. package/tooltip/tooltip.directive.d.ts +5 -0
  375. package/tree/tree-node.component.d.ts +7 -0
  376. package/tree/tree.component.d.ts +8 -0
  377. package/tree-select/tree-select.component.d.ts +7 -0
  378. package/upload/file-select-base.d.ts +1 -0
  379. package/upload/file-select.component.d.ts +3 -0
  380. package/vote/vote.component.d.ts +4 -2
  381. package/watermark/watermark.directive.d.ts +1 -0
@@ -1,12 +1,10 @@
1
- import { __decorate, __metadata } from "tslib";
2
- import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, HostBinding, Input, Output } from '@angular/core';
3
- import { coerceBooleanProperty, isString } from 'ngx-tethys/util';
1
+ import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, HostBinding, Input, Output, booleanAttribute } from '@angular/core';
2
+ import { isString } from 'ngx-tethys/util';
4
3
  import { useHostRenderer } from '@tethys/cdk/dom';
5
4
  import { ThyAvatarService } from './avatar.service';
6
5
  import { AvatarShortNamePipe, AvatarBgColorPipe, AvatarSrcPipe } from './avatar.pipe';
7
6
  import { ThyIcon } from 'ngx-tethys/icon';
8
7
  import { NgIf, NgClass, NgStyle } from '@angular/common';
9
- import { InputBoolean } from 'ngx-tethys/core';
10
8
  import * as i0 from "@angular/core";
11
9
  import * as i1 from "./avatar.service";
12
10
  const sizeArray = [16, 22, 24, 28, 32, 36, 44, 48, 68, 110, 160];
@@ -57,14 +55,14 @@ export class ThyAvatar {
57
55
  * @default false
58
56
  */
59
57
  set thyShowRemove(value) {
60
- this._showRemove = coerceBooleanProperty(value);
58
+ this._showRemove = value;
61
59
  }
62
60
  /**
63
61
  * 是否展示移除按钮
64
62
  * @default false
65
63
  */
66
64
  set thyRemovable(value) {
67
- this._showRemove = coerceBooleanProperty(value);
65
+ this._showRemove = value;
68
66
  }
69
67
  _setAvatarSize(size) {
70
68
  if (sizeArray.indexOf(size) > -1) {
@@ -140,26 +138,8 @@ export class ThyAvatar {
140
138
  this.thyError.emit($event);
141
139
  }
142
140
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyAvatar, deps: [{ token: i1.ThyAvatarService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
143
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: ThyAvatar, isStandalone: true, selector: "thy-avatar", inputs: { thyShowName: "thyShowName", thySrc: "thySrc", thyName: "thyName", thySize: "thySize", thyShowRemove: "thyShowRemove", thyRemovable: "thyRemovable", thyImgClass: "thyImgClass", thyDisabled: "thyDisabled", thyLoading: "thyLoading", thyFetchPriority: "thyFetchPriority" }, outputs: { thyOnRemove: "thyOnRemove", thyRemove: "thyRemove", thyError: "thyError" }, host: { properties: { "class.thy-avatar": "this._isAvatar" } }, ngImport: i0, template: "<img\n *ngIf=\"_src; else noSrc\"\n [src]=\"_src | thyAvatarSrc: _size\"\n class=\"avatar-avatar\"\n [ngClass]=\"thyImgClass\"\n alt=\"{{ avatarName || '' }}\"\n [attr.loading]=\"thyLoading\"\n [attr.fetchpriority]=\"thyFetchPriority\"\n (error)=\"avatarImgError($event)\"\n/>\n\n<ng-template #noSrc>\n <span class=\"avatar-default\" [ngStyle]=\"avatarName | avatarBgColor\">\n <div>{{ avatarName | avatarShortName }}</div>\n </span>\n</ng-template>\n\n<ng-template [ngIf]=\"thyShowName\">\n <div *ngIf=\"avatarNameSafeHtml; else noAvatarNameSafeHtml\" class=\"avatar-name\" [innerHtml]=\"avatarNameSafeHtml\"></div>\n <ng-template #noAvatarNameSafeHtml>\n <div class=\"avatar-name\">{{ avatarName }}</div>\n </ng-template>\n</ng-template>\n\n<a *ngIf=\"_showRemove\" (click)=\"remove($event)\" href=\"javascript:;\" class=\"remove-link avatar-remove\">\n <thy-icon class=\"remove-link-icon\" thyIconName=\"close-circle-bold-fill\"></thy-icon>\n</a>\n<div *ngIf=\"thyDisabled\" class=\"thy-avatar-disabled\">\n <thy-icon class=\"thy-avatar-disabled-icon\" thyIconName=\"ban\"></thy-icon>\n</div>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "pipe", type: AvatarShortNamePipe, name: "avatarShortName" }, { kind: "pipe", type: AvatarBgColorPipe, name: "avatarBgColor" }, { kind: "pipe", type: AvatarSrcPipe, name: "thyAvatarSrc" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
141
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.2.3", type: ThyAvatar, isStandalone: true, selector: "thy-avatar", inputs: { thyShowName: ["thyShowName", "thyShowName", booleanAttribute], thySrc: "thySrc", thyName: "thyName", thySize: "thySize", thyShowRemove: ["thyShowRemove", "thyShowRemove", booleanAttribute], thyRemovable: ["thyRemovable", "thyRemovable", booleanAttribute], thyImgClass: "thyImgClass", thyDisabled: ["thyDisabled", "thyDisabled", booleanAttribute], thyLoading: "thyLoading", thyFetchPriority: "thyFetchPriority" }, outputs: { thyOnRemove: "thyOnRemove", thyRemove: "thyRemove", thyError: "thyError" }, host: { properties: { "class.thy-avatar": "this._isAvatar" } }, ngImport: i0, template: "<img\n *ngIf=\"_src; else noSrc\"\n [src]=\"_src | thyAvatarSrc: _size\"\n class=\"avatar-avatar\"\n [ngClass]=\"thyImgClass\"\n alt=\"{{ avatarName || '' }}\"\n [attr.loading]=\"thyLoading\"\n [attr.fetchpriority]=\"thyFetchPriority\"\n (error)=\"avatarImgError($event)\"\n/>\n\n<ng-template #noSrc>\n <span class=\"avatar-default\" [ngStyle]=\"avatarName | avatarBgColor\">\n <div>{{ avatarName | avatarShortName }}</div>\n </span>\n</ng-template>\n\n<ng-template [ngIf]=\"thyShowName\">\n <div *ngIf=\"avatarNameSafeHtml; else noAvatarNameSafeHtml\" class=\"avatar-name\" [innerHtml]=\"avatarNameSafeHtml\"></div>\n <ng-template #noAvatarNameSafeHtml>\n <div class=\"avatar-name\">{{ avatarName }}</div>\n </ng-template>\n</ng-template>\n\n<a *ngIf=\"_showRemove\" (click)=\"remove($event)\" href=\"javascript:;\" class=\"remove-link avatar-remove\">\n <thy-icon class=\"remove-link-icon\" thyIconName=\"close-circle-bold-fill\"></thy-icon>\n</a>\n<div *ngIf=\"thyDisabled\" class=\"thy-avatar-disabled\">\n <thy-icon class=\"thy-avatar-disabled-icon\" thyIconName=\"ban\"></thy-icon>\n</div>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "pipe", type: AvatarShortNamePipe, name: "avatarShortName" }, { kind: "pipe", type: AvatarBgColorPipe, name: "avatarBgColor" }, { kind: "pipe", type: AvatarSrcPipe, name: "thyAvatarSrc" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
144
142
  }
145
- __decorate([
146
- InputBoolean(),
147
- __metadata("design:type", Boolean)
148
- ], ThyAvatar.prototype, "thyShowName", void 0);
149
- __decorate([
150
- InputBoolean(),
151
- __metadata("design:type", Boolean),
152
- __metadata("design:paramtypes", [Boolean])
153
- ], ThyAvatar.prototype, "thyShowRemove", null);
154
- __decorate([
155
- InputBoolean(),
156
- __metadata("design:type", Boolean),
157
- __metadata("design:paramtypes", [Boolean])
158
- ], ThyAvatar.prototype, "thyRemovable", null);
159
- __decorate([
160
- InputBoolean(),
161
- __metadata("design:type", Boolean)
162
- ], ThyAvatar.prototype, "thyDisabled", void 0);
163
143
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyAvatar, decorators: [{
164
144
  type: Component,
165
145
  args: [{ selector: 'thy-avatar', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgIf, NgClass, NgStyle, ThyIcon, AvatarShortNamePipe, AvatarBgColorPipe, AvatarSrcPipe], template: "<img\n *ngIf=\"_src; else noSrc\"\n [src]=\"_src | thyAvatarSrc: _size\"\n class=\"avatar-avatar\"\n [ngClass]=\"thyImgClass\"\n alt=\"{{ avatarName || '' }}\"\n [attr.loading]=\"thyLoading\"\n [attr.fetchpriority]=\"thyFetchPriority\"\n (error)=\"avatarImgError($event)\"\n/>\n\n<ng-template #noSrc>\n <span class=\"avatar-default\" [ngStyle]=\"avatarName | avatarBgColor\">\n <div>{{ avatarName | avatarShortName }}</div>\n </span>\n</ng-template>\n\n<ng-template [ngIf]=\"thyShowName\">\n <div *ngIf=\"avatarNameSafeHtml; else noAvatarNameSafeHtml\" class=\"avatar-name\" [innerHtml]=\"avatarNameSafeHtml\"></div>\n <ng-template #noAvatarNameSafeHtml>\n <div class=\"avatar-name\">{{ avatarName }}</div>\n </ng-template>\n</ng-template>\n\n<a *ngIf=\"_showRemove\" (click)=\"remove($event)\" href=\"javascript:;\" class=\"remove-link avatar-remove\">\n <thy-icon class=\"remove-link-icon\" thyIconName=\"close-circle-bold-fill\"></thy-icon>\n</a>\n<div *ngIf=\"thyDisabled\" class=\"thy-avatar-disabled\">\n <thy-icon class=\"thy-avatar-disabled-icon\" thyIconName=\"ban\"></thy-icon>\n</div>\n" }]
@@ -173,7 +153,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
173
153
  }], thyError: [{
174
154
  type: Output
175
155
  }], thyShowName: [{
176
- type: Input
156
+ type: Input,
157
+ args: [{ transform: booleanAttribute }]
177
158
  }], thySrc: [{
178
159
  type: Input
179
160
  }], thyName: [{
@@ -181,16 +162,19 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
181
162
  }], thySize: [{
182
163
  type: Input
183
164
  }], thyShowRemove: [{
184
- type: Input
165
+ type: Input,
166
+ args: [{ transform: booleanAttribute }]
185
167
  }], thyRemovable: [{
186
- type: Input
168
+ type: Input,
169
+ args: [{ transform: booleanAttribute }]
187
170
  }], thyImgClass: [{
188
171
  type: Input
189
172
  }], thyDisabled: [{
190
- type: Input
173
+ type: Input,
174
+ args: [{ transform: booleanAttribute }]
191
175
  }], thyLoading: [{
192
176
  type: Input
193
177
  }], thyFetchPriority: [{
194
178
  type: Input
195
179
  }] } });
196
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"","sources":["../../../../src/avatar/avatar.component.ts","../../../../src/avatar/avatar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, HostBinding, Input, OnInit, Output } from '@angular/core';\nimport { SafeHtml } from '@angular/platform-browser';\nimport { coerceBooleanProperty, isString } from 'ngx-tethys/util';\nimport { useHostRenderer } from '@tethys/cdk/dom';\nimport { ThyAvatarService } from './avatar.service';\nimport { AvatarShortNamePipe, AvatarBgColorPipe, AvatarSrcPipe } from './avatar.pipe';\nimport { ThyIcon } from 'ngx-tethys/icon';\nimport { NgIf, NgClass, NgStyle } from '@angular/common';\nimport { InputBoolean } from 'ngx-tethys/core';\n\nconst sizeArray = [16, 22, 24, 28, 32, 36, 44, 48, 68, 110, 160];\n\nexport const DEFAULT_SIZE = 36;\n\nexport const thyAvatarSizeMap = {\n    xxs: 22,\n    xs: 24,\n    sm: 32,\n    md: 36,\n    lg: 48\n};\n\n/** https://html.spec.whatwg.org/multipage/embedded-content.html#attr-img-loading */\nexport type ThyAvatarLoading = 'eager' | 'lazy';\n\n/** https://wicg.github.io/priority-hints/#idl-index */\nexport type ThyAvatarFetchPriority = 'high' | 'low' | 'auto';\n\n/**\n * 头像组件\n * @name thy-avatar\n * @order 10\n */\n@Component({\n    selector: 'thy-avatar',\n    templateUrl: './avatar.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [NgIf, NgClass, NgStyle, ThyIcon, AvatarShortNamePipe, AvatarBgColorPipe, AvatarSrcPipe]\n})\nexport class ThyAvatar implements OnInit {\n    _src: string;\n    _name: string;\n    _size: number;\n    _showRemove = false;\n\n    public avatarSrc: string;\n    public avatarName?: string;\n    public avatarNameSafeHtml?: SafeHtml;\n\n    @HostBinding('class.thy-avatar') _isAvatar = true;\n\n    /**\n     * * 已废弃，请使用 thyRemove\n     * @deprecated\n     */\n    @Output() thyOnRemove = new EventEmitter();\n\n    /**\n     *  移除按钮的事件, 当 thyRemovable 为 true 时起作用\n     */\n    @Output() thyRemove = new EventEmitter();\n\n    /**\n     *  头像 img 加载 error 时触发\n     */\n    @Output() thyError: EventEmitter<Event> = new EventEmitter<Event>();\n\n    /**\n     * 是否展示人员名称\n     * @default false\n     */\n    @Input() @InputBoolean() thyShowName: boolean;\n\n    /**\n     * 头像路径地址, 默认为全路径，如果不是全路径，可以通过自定义服务 ThyAvatarService，重写 srcTransform 方法实现转换\n     *\n     */\n    @Input()\n    set thySrc(value: string) {\n        this._setAvatarSrc(value);\n    }\n\n    /**\n     * 人员名称（可设置自定义名称，需通过自定义服务 ThyAvatarService，重写 nameTransform 方法去实现转换）\n     */\n    @Input()\n    set thyName(value: string) {\n        // this._name = value;\n        this._setAvatarName(value);\n    }\n\n    /**\n     * 头像大小\n     * @type 16 | 22 | 24 | 28 | 32 | 36 | 44 | 48 | 68 | 110 | 160 | xxs(22px) | xs(24px) | sm(32px) | md(36px) | lg(48px)\n     * @default md\n     */\n    @Input()\n    set thySize(value: number | string) {\n        if (thyAvatarSizeMap[value]) {\n            this._setAvatarSize(thyAvatarSizeMap[value]);\n        } else {\n            this._setAvatarSize((value as number) * 1);\n        }\n    }\n\n    /**\n     * 已废弃，请使用 thyRemovable\n     * @deprecated\n     * @default false\n     */\n    @Input()\n    @InputBoolean()\n    set thyShowRemove(value: boolean) {\n        this._showRemove = coerceBooleanProperty(value);\n    }\n\n    /**\n     * 是否展示移除按钮\n     * @default false\n     */\n    @Input()\n    @InputBoolean()\n    set thyRemovable(value: boolean) {\n        this._showRemove = coerceBooleanProperty(value);\n    }\n\n    /**\n     * 图片自定义类\n     */\n    @Input() thyImgClass: string;\n\n    /**\n     * 是否禁用\n     * @default false\n     */\n    @Input() @InputBoolean() thyDisabled: boolean;\n\n    /**\n     * 图片加载策略\n     * @type eager(立即加载) | lazy(延迟加载)\n     */\n    @Input() thyLoading?: ThyAvatarLoading;\n\n    /**\n     * 图片加载优先级\n     * @type auto(默认) | high(高) | low(低)\n     */\n    @Input() thyFetchPriority?: ThyAvatarFetchPriority;\n\n    private _setAvatarSize(size: number) {\n        if (sizeArray.indexOf(size) > -1) {\n            this._size = size;\n        } else {\n            this._size = this.findClosestSize(sizeArray, size);\n        }\n        this.hostRenderer.updateClass([`thy-avatar-${this._size}`]);\n    }\n\n    private findClosestSize(sizeArray: number[], currentSize: number): number {\n        let closestValue = sizeArray[0];\n        let closestDifference = Math.abs(closestValue - currentSize);\n\n        for (let i = 1; i < sizeArray.length; i++) {\n            const currentDifference = Math.abs(sizeArray[i] - currentSize);\n            if (currentDifference <= closestDifference) {\n                closestValue = sizeArray[i];\n                closestDifference = currentDifference;\n            }\n        }\n\n        return closestValue;\n    }\n\n    private _setAvatarSrc(src: string) {\n        if (src && this.thyAvatarService.ignoreAvatarSrcPaths.indexOf(src) < 0) {\n            this._src = src;\n        } else {\n            this._src = null;\n        }\n    }\n\n    private _setAvatarName(value: string) {\n        const name = this.thyAvatarService.nameTransform(value);\n        if (isString(name)) {\n            this.avatarName = name as string;\n        } else {\n            this.avatarName = value;\n            this.avatarNameSafeHtml = name;\n        }\n    }\n\n    private hostRenderer = useHostRenderer();\n\n    constructor(private thyAvatarService: ThyAvatarService, public elementRef: ElementRef) {}\n\n    ngOnInit() {\n        if (!this._size) {\n            this._setAvatarSize(DEFAULT_SIZE);\n        }\n        this.hostRenderer.updateClass([`thy-avatar-${this._size}`]);\n    }\n\n    remove($event: Event) {\n        this.thyOnRemove.emit($event);\n        this.thyRemove.emit($event);\n    }\n\n    avatarImgError($event: Event) {\n        this._setAvatarSrc(null);\n        this.thyError.emit($event);\n    }\n}\n","<img\n  *ngIf=\"_src; else noSrc\"\n  [src]=\"_src | thyAvatarSrc: _size\"\n  class=\"avatar-avatar\"\n  [ngClass]=\"thyImgClass\"\n  alt=\"{{ avatarName || '' }}\"\n  [attr.loading]=\"thyLoading\"\n  [attr.fetchpriority]=\"thyFetchPriority\"\n  (error)=\"avatarImgError($event)\"\n/>\n\n<ng-template #noSrc>\n  <span class=\"avatar-default\" [ngStyle]=\"avatarName | avatarBgColor\">\n    <div>{{ avatarName | avatarShortName }}</div>\n  </span>\n</ng-template>\n\n<ng-template [ngIf]=\"thyShowName\">\n  <div *ngIf=\"avatarNameSafeHtml; else noAvatarNameSafeHtml\" class=\"avatar-name\" [innerHtml]=\"avatarNameSafeHtml\"></div>\n  <ng-template #noAvatarNameSafeHtml>\n    <div class=\"avatar-name\">{{ avatarName }}</div>\n  </ng-template>\n</ng-template>\n\n<a *ngIf=\"_showRemove\" (click)=\"remove($event)\" href=\"javascript:;\" class=\"remove-link avatar-remove\">\n  <thy-icon class=\"remove-link-icon\" thyIconName=\"close-circle-bold-fill\"></thy-icon>\n</a>\n<div *ngIf=\"thyDisabled\" class=\"thy-avatar-disabled\">\n  <thy-icon class=\"thy-avatar-disabled-icon\" thyIconName=\"ban\"></thy-icon>\n</div>\n"]}
180
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"","sources":["../../../../src/avatar/avatar.component.ts","../../../../src/avatar/avatar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    OnInit,\n    Output,\n    booleanAttribute\n} from '@angular/core';\nimport { SafeHtml } from '@angular/platform-browser';\nimport { isString } from 'ngx-tethys/util';\nimport { useHostRenderer } from '@tethys/cdk/dom';\nimport { ThyAvatarService } from './avatar.service';\nimport { AvatarShortNamePipe, AvatarBgColorPipe, AvatarSrcPipe } from './avatar.pipe';\nimport { ThyIcon } from 'ngx-tethys/icon';\nimport { NgIf, NgClass, NgStyle } from '@angular/common';\n\nconst sizeArray = [16, 22, 24, 28, 32, 36, 44, 48, 68, 110, 160];\n\nexport const DEFAULT_SIZE = 36;\n\nexport const thyAvatarSizeMap = {\n    xxs: 22,\n    xs: 24,\n    sm: 32,\n    md: 36,\n    lg: 48\n};\n\n/** https://html.spec.whatwg.org/multipage/embedded-content.html#attr-img-loading */\nexport type ThyAvatarLoading = 'eager' | 'lazy';\n\n/** https://wicg.github.io/priority-hints/#idl-index */\nexport type ThyAvatarFetchPriority = 'high' | 'low' | 'auto';\n\n/**\n * 头像组件\n * @name thy-avatar\n * @order 10\n */\n@Component({\n    selector: 'thy-avatar',\n    templateUrl: './avatar.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [NgIf, NgClass, NgStyle, ThyIcon, AvatarShortNamePipe, AvatarBgColorPipe, AvatarSrcPipe]\n})\nexport class ThyAvatar implements OnInit {\n    _src: string;\n    _name: string;\n    _size: number;\n    _showRemove = false;\n\n    public avatarSrc: string;\n    public avatarName?: string;\n    public avatarNameSafeHtml?: SafeHtml;\n\n    @HostBinding('class.thy-avatar') _isAvatar = true;\n\n    /**\n     * * 已废弃，请使用 thyRemove\n     * @deprecated\n     */\n    @Output() thyOnRemove = new EventEmitter();\n\n    /**\n     *  移除按钮的事件, 当 thyRemovable 为 true 时起作用\n     */\n    @Output() thyRemove = new EventEmitter();\n\n    /**\n     *  头像 img 加载 error 时触发\n     */\n    @Output() thyError: EventEmitter<Event> = new EventEmitter<Event>();\n\n    /**\n     * 是否展示人员名称\n     * @default false\n     */\n    @Input({ transform: booleanAttribute }) thyShowName: boolean;\n\n    /**\n     * 头像路径地址, 默认为全路径，如果不是全路径，可以通过自定义服务 ThyAvatarService，重写 srcTransform 方法实现转换\n     *\n     */\n    @Input()\n    set thySrc(value: string) {\n        this._setAvatarSrc(value);\n    }\n\n    /**\n     * 人员名称（可设置自定义名称，需通过自定义服务 ThyAvatarService，重写 nameTransform 方法去实现转换）\n     */\n    @Input()\n    set thyName(value: string) {\n        // this._name = value;\n        this._setAvatarName(value);\n    }\n\n    /**\n     * 头像大小\n     * @type 16 | 22 | 24 | 28 | 32 | 36 | 44 | 48 | 68 | 110 | 160 | xxs(22px) | xs(24px) | sm(32px) | md(36px) | lg(48px)\n     * @default md\n     */\n    @Input()\n    set thySize(value: number | string) {\n        if (thyAvatarSizeMap[value]) {\n            this._setAvatarSize(thyAvatarSizeMap[value]);\n        } else {\n            this._setAvatarSize((value as number) * 1);\n        }\n    }\n\n    /**\n     * 已废弃，请使用 thyRemovable\n     * @deprecated\n     * @default false\n     */\n    @Input({ transform: booleanAttribute })\n    set thyShowRemove(value: boolean) {\n        this._showRemove = value;\n    }\n\n    /**\n     * 是否展示移除按钮\n     * @default false\n     */\n    @Input({ transform: booleanAttribute })\n    set thyRemovable(value: boolean) {\n        this._showRemove = value;\n    }\n\n    /**\n     * 图片自定义类\n     */\n    @Input() thyImgClass: string;\n\n    /**\n     * 是否禁用\n     * @default false\n     */\n    @Input({ transform: booleanAttribute }) thyDisabled: boolean;\n\n    /**\n     * 图片加载策略\n     * @type eager(立即加载) | lazy(延迟加载)\n     */\n    @Input() thyLoading?: ThyAvatarLoading;\n\n    /**\n     * 图片加载优先级\n     * @type auto(默认) | high(高) | low(低)\n     */\n    @Input() thyFetchPriority?: ThyAvatarFetchPriority;\n\n    private _setAvatarSize(size: number) {\n        if (sizeArray.indexOf(size) > -1) {\n            this._size = size;\n        } else {\n            this._size = this.findClosestSize(sizeArray, size);\n        }\n        this.hostRenderer.updateClass([`thy-avatar-${this._size}`]);\n    }\n\n    private findClosestSize(sizeArray: number[], currentSize: number): number {\n        let closestValue = sizeArray[0];\n        let closestDifference = Math.abs(closestValue - currentSize);\n\n        for (let i = 1; i < sizeArray.length; i++) {\n            const currentDifference = Math.abs(sizeArray[i] - currentSize);\n            if (currentDifference <= closestDifference) {\n                closestValue = sizeArray[i];\n                closestDifference = currentDifference;\n            }\n        }\n\n        return closestValue;\n    }\n\n    private _setAvatarSrc(src: string) {\n        if (src && this.thyAvatarService.ignoreAvatarSrcPaths.indexOf(src) < 0) {\n            this._src = src;\n        } else {\n            this._src = null;\n        }\n    }\n\n    private _setAvatarName(value: string) {\n        const name = this.thyAvatarService.nameTransform(value);\n        if (isString(name)) {\n            this.avatarName = name as string;\n        } else {\n            this.avatarName = value;\n            this.avatarNameSafeHtml = name;\n        }\n    }\n\n    private hostRenderer = useHostRenderer();\n\n    constructor(private thyAvatarService: ThyAvatarService, public elementRef: ElementRef) {}\n\n    ngOnInit() {\n        if (!this._size) {\n            this._setAvatarSize(DEFAULT_SIZE);\n        }\n        this.hostRenderer.updateClass([`thy-avatar-${this._size}`]);\n    }\n\n    remove($event: Event) {\n        this.thyOnRemove.emit($event);\n        this.thyRemove.emit($event);\n    }\n\n    avatarImgError($event: Event) {\n        this._setAvatarSrc(null);\n        this.thyError.emit($event);\n    }\n}\n","<img\n  *ngIf=\"_src; else noSrc\"\n  [src]=\"_src | thyAvatarSrc: _size\"\n  class=\"avatar-avatar\"\n  [ngClass]=\"thyImgClass\"\n  alt=\"{{ avatarName || '' }}\"\n  [attr.loading]=\"thyLoading\"\n  [attr.fetchpriority]=\"thyFetchPriority\"\n  (error)=\"avatarImgError($event)\"\n/>\n\n<ng-template #noSrc>\n  <span class=\"avatar-default\" [ngStyle]=\"avatarName | avatarBgColor\">\n    <div>{{ avatarName | avatarShortName }}</div>\n  </span>\n</ng-template>\n\n<ng-template [ngIf]=\"thyShowName\">\n  <div *ngIf=\"avatarNameSafeHtml; else noAvatarNameSafeHtml\" class=\"avatar-name\" [innerHtml]=\"avatarNameSafeHtml\"></div>\n  <ng-template #noAvatarNameSafeHtml>\n    <div class=\"avatar-name\">{{ avatarName }}</div>\n  </ng-template>\n</ng-template>\n\n<a *ngIf=\"_showRemove\" (click)=\"remove($event)\" href=\"javascript:;\" class=\"remove-link avatar-remove\">\n  <thy-icon class=\"remove-link-icon\" thyIconName=\"close-circle-bold-fill\"></thy-icon>\n</a>\n<div *ngIf=\"thyDisabled\" class=\"thy-avatar-disabled\">\n  <thy-icon class=\"thy-avatar-disabled-icon\" thyIconName=\"ban\"></thy-icon>\n</div>\n"]}
@@ -1,10 +1,9 @@
1
- import { __decorate, __metadata } from "tslib";
2
- import { Component, ChangeDetectionStrategy, ViewEncapsulation, Input, TemplateRef, EventEmitter, Output, HostBinding, NgZone, ChangeDetectorRef, Inject, ViewChild, ElementRef } from '@angular/core';
1
+ import { Component, ChangeDetectionStrategy, ViewEncapsulation, Input, TemplateRef, EventEmitter, Output, HostBinding, NgZone, ChangeDetectorRef, Inject, ViewChild, ElementRef, numberAttribute } from '@angular/core';
3
2
  import { Subject, fromEvent, BehaviorSubject, EMPTY, Observable } from 'rxjs';
4
3
  import { Platform } from '@angular/cdk/platform';
5
4
  import { throttleTime, takeUntil, switchMap } from 'rxjs/operators';
6
5
  import { DOCUMENT, NgIf, NgTemplateOutlet } from '@angular/common';
7
- import { fadeMotion, InputNumber, ThyScrollService } from 'ngx-tethys/core';
6
+ import { fadeMotion, ThyScrollService } from 'ngx-tethys/core';
8
7
  import { ThyIcon } from 'ngx-tethys/icon';
9
8
  import * as i0 from "@angular/core";
10
9
  import * as i1 from "ngx-tethys/core";
@@ -102,12 +101,8 @@ export class ThyBackTop {
102
101
  }
103
102
  }
104
103
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyBackTop, deps: [{ token: DOCUMENT }, { token: i1.ThyScrollService }, { token: i2.Platform }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
105
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: ThyBackTop, isStandalone: true, selector: "thy-back-top,[thyBackTop]", inputs: { thyTemplate: "thyTemplate", thyContainer: "thyContainer", thyVisibilityHeight: "thyVisibilityHeight" }, outputs: { thyClick: "thyClick", visibleChange: "visibleChange" }, host: { properties: { "class.thy-back-top-container": "this.classNames" } }, viewQueries: [{ propertyName: "backTop", first: true, predicate: ["backTop"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"thy-back-top\" #backTop @fadeMotion *ngIf=\"visible\">\n <ng-template #defaultContent>\n <div class=\"thy-back-top-content\">\n <thy-icon class=\"back-top-icon text-muted font-size-lg\" thyIconName=\"arrow-up\"></thy-icon>\n </div>\n </ng-template>\n <ng-template [ngTemplateOutlet]=\"thyTemplate || defaultContent\"></ng-template>\n</div>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], animations: [fadeMotion], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
104
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.2.3", type: ThyBackTop, isStandalone: true, selector: "thy-back-top,[thyBackTop]", inputs: { thyTemplate: "thyTemplate", thyContainer: "thyContainer", thyVisibilityHeight: ["thyVisibilityHeight", "thyVisibilityHeight", numberAttribute] }, outputs: { thyClick: "thyClick", visibleChange: "visibleChange" }, host: { properties: { "class.thy-back-top-container": "this.classNames" } }, viewQueries: [{ propertyName: "backTop", first: true, predicate: ["backTop"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"thy-back-top\" #backTop @fadeMotion *ngIf=\"visible\">\n <ng-template #defaultContent>\n <div class=\"thy-back-top-content\">\n <thy-icon class=\"back-top-icon text-muted font-size-lg\" thyIconName=\"arrow-up\"></thy-icon>\n </div>\n </ng-template>\n <ng-template [ngTemplateOutlet]=\"thyTemplate || defaultContent\"></ng-template>\n</div>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], animations: [fadeMotion], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
106
105
  }
107
- __decorate([
108
- InputNumber(),
109
- __metadata("design:type", Object)
110
- ], ThyBackTop.prototype, "thyVisibilityHeight", void 0);
111
106
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyBackTop, decorators: [{
112
107
  type: Component,
113
108
  args: [{ selector: 'thy-back-top,[thyBackTop]', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, animations: [fadeMotion], standalone: true, imports: [NgIf, ThyIcon, NgTemplateOutlet], template: "<div class=\"thy-back-top\" #backTop @fadeMotion *ngIf=\"visible\">\n <ng-template #defaultContent>\n <div class=\"thy-back-top-content\">\n <thy-icon class=\"back-top-icon text-muted font-size-lg\" thyIconName=\"arrow-up\"></thy-icon>\n </div>\n </ng-template>\n <ng-template [ngTemplateOutlet]=\"thyTemplate || defaultContent\"></ng-template>\n</div>\n" }]
@@ -122,7 +117,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
122
117
  }], thyContainer: [{
123
118
  type: Input
124
119
  }], thyVisibilityHeight: [{
125
- type: Input
120
+ type: Input,
121
+ args: [{ transform: numberAttribute }]
126
122
  }], thyClick: [{
127
123
  type: Output
128
124
  }], visibleChange: [{
@@ -131,4 +127,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
131
127
  type: ViewChild,
132
128
  args: ['backTop', { static: false }]
133
129
  }] } });
134
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"back-top.component.js","sourceRoot":"","sources":["../../../../src/back-top/back-top.component.ts","../../../../src/back-top/back-top.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    OnInit,\n    ChangeDetectionStrategy,\n    ViewEncapsulation,\n    Input,\n    TemplateRef,\n    EventEmitter,\n    Output,\n    HostBinding,\n    NgZone,\n    ChangeDetectorRef,\n    OnDestroy,\n    OnChanges,\n    Inject,\n    ViewChild,\n    ElementRef\n} from '@angular/core';\nimport { Subject, fromEvent, BehaviorSubject, EMPTY, Observable } from 'rxjs';\nimport { Platform } from '@angular/cdk/platform';\nimport { throttleTime, takeUntil, switchMap } from 'rxjs/operators';\nimport { DOCUMENT, NgIf, NgTemplateOutlet } from '@angular/common';\nimport { fadeMotion, InputNumber, ThyScrollService } from 'ngx-tethys/core';\nimport { ThyIcon } from 'ngx-tethys/icon';\n\n/**\n * 回到顶部组件\n * @name thy-back-top\n */\n@Component({\n    selector: 'thy-back-top,[thyBackTop]',\n    templateUrl: './back-top.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    animations: [fadeMotion],\n    standalone: true,\n    imports: [NgIf, ThyIcon, NgTemplateOutlet]\n})\nexport class ThyBackTop implements OnInit, OnDestroy, OnChanges {\n    @HostBinding('class.thy-back-top-container') classNames = true;\n\n    /**\n     * 自定义按钮显示模板\n     */\n    @Input() thyTemplate?: TemplateRef<void>;\n\n    /**\n     * 指定对哪个 DOM 元素返回顶部\n     * @type string | HTMLElement\n     * @default window\n     */\n    @Input() thyContainer?: string | HTMLElement;\n\n    /**\n     * 滚动高度达到此参数值才出现 thy-back-top\n     * @type number\n     */\n    @Input() @InputNumber() thyVisibilityHeight = 400;\n\n    /**\n     * 点击按钮的回调函数\n     */\n    @Output() readonly thyClick: EventEmitter<boolean> = new EventEmitter();\n\n    /**\n     * 监听按钮显示状态的回调函数\n     */\n    @Output() public visibleChange: EventEmitter<boolean> = new EventEmitter();\n\n    /** The native `<div class=\"thy-back-top\"></div>` element. */\n    @ViewChild('backTop', { static: false })\n    set backTop(backTop: ElementRef<HTMLElement> | undefined) {\n        this.backTop$.next(backTop);\n    }\n\n    public visible = false;\n\n    /**\n     * The subject used to store the native `<div class=\"thy-back-top\"></div>` since\n     * it's located within the `ngIf` directive. It might be set asynchronously whenever the condition\n     * is met. Having subject makes the code reactive and cancellable (e.g. event listeners will be\n     * automatically removed and re-added through the `switchMap` below).\n     */\n    private backTop$ = new BehaviorSubject<ElementRef<HTMLElement> | undefined>(undefined);\n\n    private destroy$ = new Subject<void>();\n    private scrollListenerDestroy$ = new Subject<void>();\n\n    private target: HTMLElement | null = null;\n\n    constructor(\n        @Inject(DOCUMENT) private doc: any,\n        private thyScrollService: ThyScrollService,\n        private platform: Platform,\n        private cdr: ChangeDetectorRef,\n        private zone: NgZone\n    ) {\n        this.backTop$\n            .pipe(\n                switchMap(backTop =>\n                    backTop\n                        ? new Observable(subscriber =>\n                              zone.runOutsideAngular(() => fromEvent(backTop.nativeElement, 'click').subscribe(subscriber))\n                          )\n                        : EMPTY\n                ),\n                takeUntil(this.destroy$)\n            )\n            .subscribe(() => {\n                this.thyScrollService.scrollTo(this.getTarget(), 0);\n                if (this.thyClick.observers.length) {\n                    zone.run(() => this.thyClick.emit(true));\n                }\n            });\n    }\n\n    ngOnInit(): void {\n        this.registerScrollEvent();\n    }\n\n    private getTarget(): HTMLElement | Window {\n        return this.target || window;\n    }\n\n    private handleScroll(): void {\n        if (this.visible === this.thyScrollService.getScroll(this.getTarget()) > this.thyVisibilityHeight) {\n            return;\n        }\n        this.visible = !this.visible;\n        this.cdr.detectChanges();\n        if (this.visibleChange.observers.length > 0) {\n            this.zone.run(() => {\n                this.visibleChange.emit(this.visible);\n            });\n        }\n    }\n\n    private registerScrollEvent(): void {\n        if (!this.platform.isBrowser) {\n            return;\n        }\n        this.scrollListenerDestroy$.next();\n        this.handleScroll();\n        this.zone.runOutsideAngular(() => {\n            fromEvent(this.getTarget(), 'scroll', { passive: true })\n                .pipe(throttleTime(50), takeUntil(this.scrollListenerDestroy$))\n                .subscribe(() => this.handleScroll());\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.scrollListenerDestroy$.next();\n    }\n\n    ngOnChanges(changes: any): void {\n        const { thyContainer } = changes;\n        if (thyContainer) {\n            this.target = typeof this.thyContainer === 'string' ? this.doc.querySelector(this.thyContainer) : this.thyContainer;\n            this.registerScrollEvent();\n        }\n    }\n}\n","<div class=\"thy-back-top\" #backTop @fadeMotion *ngIf=\"visible\">\n  <ng-template #defaultContent>\n    <div class=\"thy-back-top-content\">\n      <thy-icon class=\"back-top-icon text-muted font-size-lg\" thyIconName=\"arrow-up\"></thy-icon>\n    </div>\n  </ng-template>\n  <ng-template [ngTemplateOutlet]=\"thyTemplate || defaultContent\"></ng-template>\n</div>\n"]}
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"back-top.component.js","sourceRoot":"","sources":["../../../../src/back-top/back-top.component.ts","../../../../src/back-top/back-top.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    OnInit,\n    ChangeDetectionStrategy,\n    ViewEncapsulation,\n    Input,\n    TemplateRef,\n    EventEmitter,\n    Output,\n    HostBinding,\n    NgZone,\n    ChangeDetectorRef,\n    OnDestroy,\n    OnChanges,\n    Inject,\n    ViewChild,\n    ElementRef,\n    numberAttribute\n} from '@angular/core';\nimport { Subject, fromEvent, BehaviorSubject, EMPTY, Observable } from 'rxjs';\nimport { Platform } from '@angular/cdk/platform';\nimport { throttleTime, takeUntil, switchMap } from 'rxjs/operators';\nimport { DOCUMENT, NgIf, NgTemplateOutlet } from '@angular/common';\nimport { fadeMotion, ThyScrollService } from 'ngx-tethys/core';\nimport { ThyIcon } from 'ngx-tethys/icon';\n\n/**\n * 回到顶部组件\n * @name thy-back-top\n */\n@Component({\n    selector: 'thy-back-top,[thyBackTop]',\n    templateUrl: './back-top.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    animations: [fadeMotion],\n    standalone: true,\n    imports: [NgIf, ThyIcon, NgTemplateOutlet]\n})\nexport class ThyBackTop implements OnInit, OnDestroy, OnChanges {\n    @HostBinding('class.thy-back-top-container') classNames = true;\n\n    /**\n     * 自定义按钮显示模板\n     */\n    @Input() thyTemplate?: TemplateRef<void>;\n\n    /**\n     * 指定对哪个 DOM 元素返回顶部\n     * @type string | HTMLElement\n     * @default window\n     */\n    @Input() thyContainer?: string | HTMLElement;\n\n    /**\n     * 滚动高度达到此参数值才出现 thy-back-top\n     * @type number\n     */\n    @Input({ transform: numberAttribute }) thyVisibilityHeight = 400;\n\n    /**\n     * 点击按钮的回调函数\n     */\n    @Output() readonly thyClick: EventEmitter<boolean> = new EventEmitter();\n\n    /**\n     * 监听按钮显示状态的回调函数\n     */\n    @Output() public visibleChange: EventEmitter<boolean> = new EventEmitter();\n\n    /** The native `<div class=\"thy-back-top\"></div>` element. */\n    @ViewChild('backTop', { static: false })\n    set backTop(backTop: ElementRef<HTMLElement> | undefined) {\n        this.backTop$.next(backTop);\n    }\n\n    public visible = false;\n\n    /**\n     * The subject used to store the native `<div class=\"thy-back-top\"></div>` since\n     * it's located within the `ngIf` directive. It might be set asynchronously whenever the condition\n     * is met. Having subject makes the code reactive and cancellable (e.g. event listeners will be\n     * automatically removed and re-added through the `switchMap` below).\n     */\n    private backTop$ = new BehaviorSubject<ElementRef<HTMLElement> | undefined>(undefined);\n\n    private destroy$ = new Subject<void>();\n    private scrollListenerDestroy$ = new Subject<void>();\n\n    private target: HTMLElement | null = null;\n\n    constructor(\n        @Inject(DOCUMENT) private doc: any,\n        private thyScrollService: ThyScrollService,\n        private platform: Platform,\n        private cdr: ChangeDetectorRef,\n        private zone: NgZone\n    ) {\n        this.backTop$\n            .pipe(\n                switchMap(backTop =>\n                    backTop\n                        ? new Observable(subscriber =>\n                              zone.runOutsideAngular(() => fromEvent(backTop.nativeElement, 'click').subscribe(subscriber))\n                          )\n                        : EMPTY\n                ),\n                takeUntil(this.destroy$)\n            )\n            .subscribe(() => {\n                this.thyScrollService.scrollTo(this.getTarget(), 0);\n                if (this.thyClick.observers.length) {\n                    zone.run(() => this.thyClick.emit(true));\n                }\n            });\n    }\n\n    ngOnInit(): void {\n        this.registerScrollEvent();\n    }\n\n    private getTarget(): HTMLElement | Window {\n        return this.target || window;\n    }\n\n    private handleScroll(): void {\n        if (this.visible === this.thyScrollService.getScroll(this.getTarget()) > this.thyVisibilityHeight) {\n            return;\n        }\n        this.visible = !this.visible;\n        this.cdr.detectChanges();\n        if (this.visibleChange.observers.length > 0) {\n            this.zone.run(() => {\n                this.visibleChange.emit(this.visible);\n            });\n        }\n    }\n\n    private registerScrollEvent(): void {\n        if (!this.platform.isBrowser) {\n            return;\n        }\n        this.scrollListenerDestroy$.next();\n        this.handleScroll();\n        this.zone.runOutsideAngular(() => {\n            fromEvent(this.getTarget(), 'scroll', { passive: true })\n                .pipe(throttleTime(50), takeUntil(this.scrollListenerDestroy$))\n                .subscribe(() => this.handleScroll());\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.scrollListenerDestroy$.next();\n    }\n\n    ngOnChanges(changes: any): void {\n        const { thyContainer } = changes;\n        if (thyContainer) {\n            this.target = typeof this.thyContainer === 'string' ? this.doc.querySelector(this.thyContainer) : this.thyContainer;\n            this.registerScrollEvent();\n        }\n    }\n}\n","<div class=\"thy-back-top\" #backTop @fadeMotion *ngIf=\"visible\">\n  <ng-template #defaultContent>\n    <div class=\"thy-back-top-content\">\n      <thy-icon class=\"back-top-icon text-muted font-size-lg\" thyIconName=\"arrow-up\"></thy-icon>\n    </div>\n  </ng-template>\n  <ng-template [ngTemplateOutlet]=\"thyTemplate || defaultContent\"></ng-template>\n</div>\n"]}
@@ -1,7 +1,5 @@
1
- import { __decorate, __metadata } from "tslib";
2
- import { InputBoolean, InputNumber, isTextColor } from 'ngx-tethys/core';
3
- import { coerceBooleanProperty } from 'ngx-tethys/util';
4
- import { ChangeDetectionStrategy, Component, ElementRef, Input } from '@angular/core';
1
+ import { isTextColor } from 'ngx-tethys/core';
2
+ import { ChangeDetectionStrategy, Component, ElementRef, Input, booleanAttribute, numberAttribute } from '@angular/core';
5
3
  import { NgIf } from '@angular/common';
6
4
  import * as i0 from "@angular/core";
7
5
  /**
@@ -112,7 +110,7 @@ export class ThyBadge {
112
110
  * @default false
113
111
  */
114
112
  set thyKeepShow(value) {
115
- this.keepShowValue = coerceBooleanProperty(value);
113
+ this.keepShowValue = value;
116
114
  if (this.initialized) {
117
115
  this.combineBadgeDisplayContent();
118
116
  }
@@ -201,33 +199,8 @@ export class ThyBadge {
201
199
  }
202
200
  }
203
201
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyBadge, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
204
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: ThyBadge, isStandalone: true, selector: "thy-badge,[thyBadge]", inputs: { thyType: "thyType", thyCount: "thyCount", thyContent: "thyContent", thyContext: "thyContext", thyMaxCount: "thyMaxCount", thySize: "thySize", thyIsDot: "thyIsDot", thyIsHollow: "thyIsHollow", thyKeepShow: "thyKeepShow", thyTextColor: "thyTextColor", thyBackgroundColor: "thyBackgroundColor" }, host: { properties: { "class.thy-badge-wrapper": "isWrapper" }, classAttribute: "thy-badge-container" }, ngImport: i0, template: "<div *ngIf=\"isShowBadge\" class=\"thy-badge {{ badgeClassName }}\" [style.color]=\"textColor\" [style.backgroundColor]=\"backgroundColor\">\n <span>{{ displayContent }}</span>\n</div>\n<ng-content></ng-content>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
202
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.2.3", type: ThyBadge, isStandalone: true, selector: "thy-badge,[thyBadge]", inputs: { thyType: "thyType", thyCount: ["thyCount", "thyCount", numberAttribute], thyContent: "thyContent", thyContext: "thyContext", thyMaxCount: ["thyMaxCount", "thyMaxCount", numberAttribute], thySize: "thySize", thyIsDot: ["thyIsDot", "thyIsDot", booleanAttribute], thyIsHollow: ["thyIsHollow", "thyIsHollow", booleanAttribute], thyKeepShow: ["thyKeepShow", "thyKeepShow", booleanAttribute], thyTextColor: "thyTextColor", thyBackgroundColor: "thyBackgroundColor" }, host: { properties: { "class.thy-badge-wrapper": "isWrapper" }, classAttribute: "thy-badge-container" }, ngImport: i0, template: "<div *ngIf=\"isShowBadge\" class=\"thy-badge {{ badgeClassName }}\" [style.color]=\"textColor\" [style.backgroundColor]=\"backgroundColor\">\n <span>{{ displayContent }}</span>\n</div>\n<ng-content></ng-content>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
205
203
  }
206
- __decorate([
207
- InputNumber(),
208
- __metadata("design:type", Number),
209
- __metadata("design:paramtypes", [Number])
210
- ], ThyBadge.prototype, "thyCount", null);
211
- __decorate([
212
- InputNumber(),
213
- __metadata("design:type", Number),
214
- __metadata("design:paramtypes", [Number])
215
- ], ThyBadge.prototype, "thyMaxCount", null);
216
- __decorate([
217
- InputBoolean(),
218
- __metadata("design:type", Boolean),
219
- __metadata("design:paramtypes", [Boolean])
220
- ], ThyBadge.prototype, "thyIsDot", null);
221
- __decorate([
222
- InputBoolean(),
223
- __metadata("design:type", Boolean),
224
- __metadata("design:paramtypes", [Boolean])
225
- ], ThyBadge.prototype, "thyIsHollow", null);
226
- __decorate([
227
- InputBoolean(),
228
- __metadata("design:type", Boolean),
229
- __metadata("design:paramtypes", [Boolean])
230
- ], ThyBadge.prototype, "thyKeepShow", null);
231
204
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyBadge, decorators: [{
232
205
  type: Component,
233
206
  args: [{ selector: 'thy-badge,[thyBadge]', changeDetection: ChangeDetectionStrategy.OnPush, host: {
@@ -237,24 +210,29 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
237
210
  }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { thyType: [{
238
211
  type: Input
239
212
  }], thyCount: [{
240
- type: Input
213
+ type: Input,
214
+ args: [{ transform: numberAttribute }]
241
215
  }], thyContent: [{
242
216
  type: Input
243
217
  }], thyContext: [{
244
218
  type: Input
245
219
  }], thyMaxCount: [{
246
- type: Input
220
+ type: Input,
221
+ args: [{ transform: numberAttribute }]
247
222
  }], thySize: [{
248
223
  type: Input
249
224
  }], thyIsDot: [{
250
- type: Input
225
+ type: Input,
226
+ args: [{ transform: booleanAttribute }]
251
227
  }], thyIsHollow: [{
252
- type: Input
228
+ type: Input,
229
+ args: [{ transform: booleanAttribute }]
253
230
  }], thyKeepShow: [{
254
- type: Input
231
+ type: Input,
232
+ args: [{ transform: booleanAttribute }]
255
233
  }], thyTextColor: [{
256
234
  type: Input
257
235
  }], thyBackgroundColor: [{
258
236
  type: Input
259
237
  }] } });
260
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"badge.component.js","sourceRoot":"","sources":["../../../../src/badge/badge.component.ts","../../../../src/badge/badge.component.html"],"names":[],"mappings":"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","sourcesContent":["import { InputBoolean, InputNumber, isTextColor } from 'ngx-tethys/core';\nimport { coerceBooleanProperty } from 'ngx-tethys/util';\n\nimport { ChangeDetectionStrategy, Component, ElementRef, Input, OnInit } from '@angular/core';\nimport { NgIf } from '@angular/common';\n\nexport type ThyBadgeSize = 'md' | 'sm' | 'lg';\n\n/**\n * 徽标组件，支持组件`thy-badge`和`thyBadge`指令两种使用方式\n * @name thy-badge,[thyBadge]\n */\n@Component({\n    selector: 'thy-badge,[thyBadge]',\n    templateUrl: './badge.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: 'thy-badge-container',\n        '[class.thy-badge-wrapper]': 'isWrapper'\n    },\n    standalone: true,\n    imports: [NgIf]\n})\nexport class ThyBadge implements OnInit {\n    displayContent = '';\n\n    badgeClassName = '';\n\n    private nativeElement: any;\n\n    private initialized = false;\n\n    // 是否包裹在元素上\n    protected isWrapper = false;\n\n    public isShowBadge = true;\n\n    private keepShowValue = false;\n\n    private value: number | string = '';\n\n    private valueHasBeenSet = false;\n\n    private maxCount: number;\n\n    private type: string;\n\n    private size: ThyBadgeSize;\n\n    private isDot: boolean;\n\n    private isHollow: boolean;\n\n    protected textColor: string;\n\n    protected builtInTextColorClass: string;\n\n    protected backgroundColor: string;\n\n    protected builtInBackgroundColorClass: string;\n\n    protected supClasses: string[] = [];\n\n    constructor(private elementRef: ElementRef) {\n        this.nativeElement = this.elementRef.nativeElement;\n    }\n\n    /**\n     * 徽标类型\n     * @type default | primary | danger | warning | success\n     * @default danger\n     */\n    @Input()\n    set thyType(value: string) {\n        this.type = value;\n        if (this.initialized) {\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 徽标内容数字\n     * @type number\n     */\n    @Input()\n    @InputNumber()\n    set thyCount(value: number) {\n        this.value = value;\n        this.valueHasBeenSet = true;\n        if (this.initialized) {\n            this.combineBadgeDisplayContent();\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 徽标内容文本\n     * @type string\n     */\n    @Input()\n    set thyContent(value: string) {\n        this.value = value;\n        this.valueHasBeenSet = true;\n        if (this.initialized) {\n            this.combineBadgeDisplayContent();\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 已废弃，徽标内容文本，命名错误，请使用 thyContent\n     * @deprecated\n     */\n    @Input()\n    set thyContext(value: string) {\n        this.thyContent = value;\n    }\n\n    /**\n     * 徽标显示的最大值, 与 thyCount 一起使用,thyCount 超过了 thyMaxCount 设置的值时，徽标内容为 thyMaxCount+\n     * @type number\n     */\n    @Input()\n    @InputNumber()\n    set thyMaxCount(value: number) {\n        this.maxCount = value;\n        if (this.initialized) {\n            this.combineBadgeDisplayContent();\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 徽标显示的大小\n     * @type md | sm | lg\n     * @default md\n     */\n    @Input()\n    set thySize(value: ThyBadgeSize) {\n        this.size = value;\n\n        if (this.initialized) {\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 已废弃，徽标是一个实心点，已经被废弃\n     * @deprecated\n     */\n    @Input()\n    @InputBoolean()\n    set thyIsDot(value: boolean) {\n        this.isDot = value;\n        if (this.initialized) {\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 已废弃，徽标是一个空心点\n     * @deprecated\n     */\n    @Input()\n    @InputBoolean()\n    set thyIsHollow(value: boolean) {\n        this.isHollow = value;\n        if (this.initialized) {\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * thyCount 为 0 时，强制显示数字 0，默认不显示\n     * @default false\n     */\n    @Input()\n    @InputBoolean()\n    set thyKeepShow(value: boolean) {\n        this.keepShowValue = coerceBooleanProperty(value);\n        if (this.initialized) {\n            this.combineBadgeDisplayContent();\n        }\n    }\n\n    /**\n     * 设置徽标字体的颜色，支持内置颜色和自定义颜色 'primary' | '#87d068' | ...\n     * @type string\n     */\n    @Input()\n    set thyTextColor(value: string) {\n        if (isTextColor(value)) {\n            this.builtInTextColorClass = `text-${value}`;\n            this.textColor = null;\n        } else {\n            this.textColor = value;\n            this.builtInTextColorClass = null;\n        }\n        if (this.initialized) {\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 设置徽标的背景颜色，支持内置颜色和自定义颜色 'primary' | '#87d068' | ...\n     * @type string\n     */\n    @Input()\n    set thyBackgroundColor(value: string) {\n        if (isTextColor(value)) {\n            this.builtInBackgroundColorClass = `bg-${value}`;\n            this.backgroundColor = null;\n        } else {\n            this.backgroundColor = value;\n            this.builtInBackgroundColorClass = null;\n        }\n        if (this.initialized) {\n            this.combineBadgeClasses();\n        }\n    }\n\n    ngOnInit() {\n        let childNodeCount = 0;\n        this.nativeElement.childNodes.forEach((n: HTMLElement) => {\n            if (['#comment'].indexOf(n.nodeName) < 0) {\n                childNodeCount++;\n            }\n        });\n        this.isWrapper = childNodeCount > 0;\n\n        this.combineBadgeClasses();\n\n        if (this.valueHasBeenSet) {\n            this.combineBadgeDisplayContent();\n        }\n\n        this.initialized = true;\n    }\n\n    private combineBadgeClasses() {\n        const classes: string[] = [];\n        classes.push(`thy-badge-${this.type || 'danger'}`);\n        if (this.size) {\n            classes.push(`thy-badge-${this.size}`);\n        }\n        if (this.isDot) {\n            classes.push(`thy-badge-dot`);\n        } else if (this.isHollow) {\n            classes.push(`thy-badge-hollow`);\n        } else {\n            classes.push(`thy-badge-count`);\n        }\n\n        if (this.builtInTextColorClass) {\n            classes.push(this.builtInTextColorClass);\n        }\n        if (this.builtInBackgroundColorClass) {\n            classes.push(this.builtInBackgroundColorClass);\n        }\n        this.badgeClassName = classes.join(' ');\n    }\n\n    private combineBadgeDisplayContent() {\n        this.displayContent = this.value as string;\n        if (this.value && this.maxCount != undefined && (this.value as number) > this.maxCount) {\n            this.displayContent = `${this.maxCount}+`;\n        }\n\n        if (!this.value && !this.keepShowValue) {\n            this.isShowBadge = false;\n        } else {\n            this.isShowBadge = true;\n        }\n    }\n}\n","<div *ngIf=\"isShowBadge\" class=\"thy-badge {{ badgeClassName }}\" [style.color]=\"textColor\" [style.backgroundColor]=\"backgroundColor\">\n  <span>{{ displayContent }}</span>\n</div>\n<ng-content></ng-content>\n"]}
238
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"badge.component.js","sourceRoot":"","sources":["../../../../src/badge/badge.component.ts","../../../../src/badge/badge.component.html"],"names":[],"mappings":"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","sourcesContent":["import { isTextColor } from 'ngx-tethys/core';\n\nimport { ChangeDetectionStrategy, Component, ElementRef, Input, OnInit, booleanAttribute, numberAttribute } from '@angular/core';\nimport { NgIf } from '@angular/common';\n\nexport type ThyBadgeSize = 'md' | 'sm' | 'lg';\n\n/**\n * 徽标组件，支持组件`thy-badge`和`thyBadge`指令两种使用方式\n * @name thy-badge,[thyBadge]\n */\n@Component({\n    selector: 'thy-badge,[thyBadge]',\n    templateUrl: './badge.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: 'thy-badge-container',\n        '[class.thy-badge-wrapper]': 'isWrapper'\n    },\n    standalone: true,\n    imports: [NgIf]\n})\nexport class ThyBadge implements OnInit {\n    displayContent = '';\n\n    badgeClassName = '';\n\n    private nativeElement: any;\n\n    private initialized = false;\n\n    // 是否包裹在元素上\n    protected isWrapper = false;\n\n    public isShowBadge = true;\n\n    private keepShowValue = false;\n\n    private value: number | string = '';\n\n    private valueHasBeenSet = false;\n\n    private maxCount: number;\n\n    private type: string;\n\n    private size: ThyBadgeSize;\n\n    private isDot: boolean;\n\n    private isHollow: boolean;\n\n    protected textColor: string;\n\n    protected builtInTextColorClass: string;\n\n    protected backgroundColor: string;\n\n    protected builtInBackgroundColorClass: string;\n\n    protected supClasses: string[] = [];\n\n    constructor(private elementRef: ElementRef) {\n        this.nativeElement = this.elementRef.nativeElement;\n    }\n\n    /**\n     * 徽标类型\n     * @type default | primary | danger | warning | success\n     * @default danger\n     */\n    @Input()\n    set thyType(value: string) {\n        this.type = value;\n        if (this.initialized) {\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 徽标内容数字\n     * @type number\n     */\n    @Input({ transform: numberAttribute })\n    set thyCount(value: number) {\n        this.value = value;\n        this.valueHasBeenSet = true;\n        if (this.initialized) {\n            this.combineBadgeDisplayContent();\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 徽标内容文本\n     * @type string\n     */\n    @Input()\n    set thyContent(value: string) {\n        this.value = value;\n        this.valueHasBeenSet = true;\n        if (this.initialized) {\n            this.combineBadgeDisplayContent();\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 已废弃，徽标内容文本，命名错误，请使用 thyContent\n     * @deprecated\n     */\n    @Input()\n    set thyContext(value: string) {\n        this.thyContent = value;\n    }\n\n    /**\n     * 徽标显示的最大值, 与 thyCount 一起使用,thyCount 超过了 thyMaxCount 设置的值时，徽标内容为 thyMaxCount+\n     * @type number\n     */\n    @Input({ transform: numberAttribute })\n    set thyMaxCount(value: number) {\n        this.maxCount = value;\n        if (this.initialized) {\n            this.combineBadgeDisplayContent();\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 徽标显示的大小\n     * @type md | sm | lg\n     * @default md\n     */\n    @Input()\n    set thySize(value: ThyBadgeSize) {\n        this.size = value;\n\n        if (this.initialized) {\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 已废弃，徽标是一个实心点，已经被废弃\n     * @deprecated\n     */\n    @Input({ transform: booleanAttribute })\n    set thyIsDot(value: boolean) {\n        this.isDot = value;\n        if (this.initialized) {\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 已废弃，徽标是一个空心点\n     * @deprecated\n     */\n    @Input({ transform: booleanAttribute })\n    set thyIsHollow(value: boolean) {\n        this.isHollow = value;\n        if (this.initialized) {\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * thyCount 为 0 时，强制显示数字 0，默认不显示\n     * @default false\n     */\n    @Input({ transform: booleanAttribute })\n    set thyKeepShow(value: boolean) {\n        this.keepShowValue = value;\n        if (this.initialized) {\n            this.combineBadgeDisplayContent();\n        }\n    }\n\n    /**\n     * 设置徽标字体的颜色，支持内置颜色和自定义颜色 'primary' | '#87d068' | ...\n     * @type string\n     */\n    @Input()\n    set thyTextColor(value: string) {\n        if (isTextColor(value)) {\n            this.builtInTextColorClass = `text-${value}`;\n            this.textColor = null;\n        } else {\n            this.textColor = value;\n            this.builtInTextColorClass = null;\n        }\n        if (this.initialized) {\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 设置徽标的背景颜色，支持内置颜色和自定义颜色 'primary' | '#87d068' | ...\n     * @type string\n     */\n    @Input()\n    set thyBackgroundColor(value: string) {\n        if (isTextColor(value)) {\n            this.builtInBackgroundColorClass = `bg-${value}`;\n            this.backgroundColor = null;\n        } else {\n            this.backgroundColor = value;\n            this.builtInBackgroundColorClass = null;\n        }\n        if (this.initialized) {\n            this.combineBadgeClasses();\n        }\n    }\n\n    ngOnInit() {\n        let childNodeCount = 0;\n        this.nativeElement.childNodes.forEach((n: HTMLElement) => {\n            if (['#comment'].indexOf(n.nodeName) < 0) {\n                childNodeCount++;\n            }\n        });\n        this.isWrapper = childNodeCount > 0;\n\n        this.combineBadgeClasses();\n\n        if (this.valueHasBeenSet) {\n            this.combineBadgeDisplayContent();\n        }\n\n        this.initialized = true;\n    }\n\n    private combineBadgeClasses() {\n        const classes: string[] = [];\n        classes.push(`thy-badge-${this.type || 'danger'}`);\n        if (this.size) {\n            classes.push(`thy-badge-${this.size}`);\n        }\n        if (this.isDot) {\n            classes.push(`thy-badge-dot`);\n        } else if (this.isHollow) {\n            classes.push(`thy-badge-hollow`);\n        } else {\n            classes.push(`thy-badge-count`);\n        }\n\n        if (this.builtInTextColorClass) {\n            classes.push(this.builtInTextColorClass);\n        }\n        if (this.builtInBackgroundColorClass) {\n            classes.push(this.builtInBackgroundColorClass);\n        }\n        this.badgeClassName = classes.join(' ');\n    }\n\n    private combineBadgeDisplayContent() {\n        this.displayContent = this.value as string;\n        if (this.value && this.maxCount != undefined && (this.value as number) > this.maxCount) {\n            this.displayContent = `${this.maxCount}+`;\n        }\n\n        if (!this.value && !this.keepShowValue) {\n            this.isShowBadge = false;\n        } else {\n            this.isShowBadge = true;\n        }\n    }\n}\n","<div *ngIf=\"isShowBadge\" class=\"thy-badge {{ badgeClassName }}\" [style.color]=\"textColor\" [style.backgroundColor]=\"backgroundColor\">\n  <span>{{ displayContent }}</span>\n</div>\n<ng-content></ng-content>\n"]}
@@ -1,10 +1,7 @@
1
- import { __decorate, __metadata } from "tslib";
2
1
  import { NgClass, NgIf } from '@angular/common';
3
- import { ChangeDetectionStrategy, Component, HostBinding, Input, ViewEncapsulation } from '@angular/core';
2
+ import { ChangeDetectionStrategy, Component, HostBinding, Input, ViewEncapsulation, booleanAttribute } from '@angular/core';
4
3
  import { useHostRenderer } from '@tethys/cdk/dom';
5
- import { InputBoolean } from 'ngx-tethys/core';
6
4
  import { ThyIcon } from 'ngx-tethys/icon';
7
- import { coerceBooleanProperty } from 'ngx-tethys/util';
8
5
  import * as i0 from "@angular/core";
9
6
  const sizeClassesMap = {
10
7
  lg: ['btn-icon-lg'],
@@ -61,14 +58,14 @@ export class ThyButtonIcon {
61
58
  * @default false
62
59
  */
63
60
  set thyLight(value) {
64
- this._isLighted = coerceBooleanProperty(value);
61
+ this._isLighted = value;
65
62
  }
66
63
  /**
67
64
  * 设置为选中状态
68
65
  * @default false
69
66
  */
70
67
  set thyActive(value) {
71
- this._isActive = coerceBooleanProperty(value);
68
+ this._isActive = value;
72
69
  }
73
70
  /**
74
71
  * 按钮展示类型,默认图标移上去显示主色, danger-weak 鼠标移上去显示 danger 红色
@@ -129,18 +126,8 @@ export class ThyButtonIcon {
129
126
  this.initialized = true;
130
127
  }
131
128
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyButtonIcon, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
132
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: ThyButtonIcon, isStandalone: true, selector: "thy-button-icon,[thy-button-icon],[thyButtonIcon]", inputs: { thySize: "thySize", thyIcon: "thyIcon", thyButtonIcon: "thyButtonIcon", thyShape: "thyShape", thyLight: "thyLight", thyActive: "thyActive", thyTheme: "thyTheme", thyColor: "thyColor" }, host: { properties: { "class.btn": "this._isBtn", "class.btn-icon": "this._isBtnIcon", "class.btn-icon-light": "this._isLighted", "class.btn-icon-active": "this._isActive" } }, ngImport: i0, template: "<thy-icon *ngIf=\"svgIconName; else iconFont\" [thyIconName]=\"svgIconName\" [style.color]=\"thyColor\" [style.borderColor]=\"thyColor\"></thy-icon>\n<ng-template #iconFont>\n <i [ngClass]=\"iconClasses\" *ngIf=\"iconClasses\" [style.color]=\"thyColor\" [style.borderColor]=\"thyColor\"></i>\n</ng-template>\n<ng-content></ng-content>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
129
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.2.3", type: ThyButtonIcon, isStandalone: true, selector: "thy-button-icon,[thy-button-icon],[thyButtonIcon]", inputs: { thySize: "thySize", thyIcon: "thyIcon", thyButtonIcon: "thyButtonIcon", thyShape: "thyShape", thyLight: ["thyLight", "thyLight", booleanAttribute], thyActive: ["thyActive", "thyActive", booleanAttribute], thyTheme: "thyTheme", thyColor: "thyColor" }, host: { properties: { "class.btn": "this._isBtn", "class.btn-icon": "this._isBtnIcon", "class.btn-icon-light": "this._isLighted", "class.btn-icon-active": "this._isActive" } }, ngImport: i0, template: "<thy-icon *ngIf=\"svgIconName; else iconFont\" [thyIconName]=\"svgIconName\" [style.color]=\"thyColor\" [style.borderColor]=\"thyColor\"></thy-icon>\n<ng-template #iconFont>\n <i [ngClass]=\"iconClasses\" *ngIf=\"iconClasses\" [style.color]=\"thyColor\" [style.borderColor]=\"thyColor\"></i>\n</ng-template>\n<ng-content></ng-content>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
133
130
  }
134
- __decorate([
135
- InputBoolean(),
136
- __metadata("design:type", Boolean),
137
- __metadata("design:paramtypes", [Boolean])
138
- ], ThyButtonIcon.prototype, "thyLight", null);
139
- __decorate([
140
- InputBoolean(),
141
- __metadata("design:type", Boolean),
142
- __metadata("design:paramtypes", [Boolean])
143
- ], ThyButtonIcon.prototype, "thyActive", null);
144
131
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyButtonIcon, decorators: [{
145
132
  type: Component,
146
133
  args: [{ selector: 'thy-button-icon,[thy-button-icon],[thyButtonIcon]', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgIf, ThyIcon, NgClass], template: "<thy-icon *ngIf=\"svgIconName; else iconFont\" [thyIconName]=\"svgIconName\" [style.color]=\"thyColor\" [style.borderColor]=\"thyColor\"></thy-icon>\n<ng-template #iconFont>\n <i [ngClass]=\"iconClasses\" *ngIf=\"iconClasses\" [style.color]=\"thyColor\" [style.borderColor]=\"thyColor\"></i>\n</ng-template>\n<ng-content></ng-content>\n" }]
@@ -153,9 +140,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
153
140
  }], thyShape: [{
154
141
  type: Input
155
142
  }], thyLight: [{
156
- type: Input
143
+ type: Input,
144
+ args: [{ transform: booleanAttribute }]
157
145
  }], thyActive: [{
158
- type: Input
146
+ type: Input,
147
+ args: [{ transform: booleanAttribute }]
159
148
  }], thyTheme: [{
160
149
  type: Input
161
150
  }], _isBtn: [{
@@ -173,4 +162,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
173
162
  }], thyColor: [{
174
163
  type: Input
175
164
  }] } });
176
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-icon.component.js","sourceRoot":"","sources":["../../../../src/button/button-icon.component.ts","../../../../src/button/button-icon.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, NgIf } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, HostBinding, Input, OnInit, ViewEncapsulation } from '@angular/core';\nimport { useHostRenderer } from '@tethys/cdk/dom';\nimport { InputBoolean } from 'ngx-tethys/core';\nimport { ThyIcon } from 'ngx-tethys/icon';\nimport { coerceBooleanProperty } from 'ngx-tethys/util';\n\nexport type ThyButtonIconShape = '' | 'circle-dashed' | 'circle-solid' | 'circle-thick-dashed' | 'circle-thick-solid' | 'self-icon';\n\nconst sizeClassesMap = {\n    lg: ['btn-icon-lg'],\n    md: ['btn-icon-md'],\n    sm: ['btn-icon-sm'],\n    xs: ['btn-icon-xs']\n};\n\nconst shapeClassesMap = {\n    'circle-dashed': ['btn-icon-circle', 'circle-dashed'],\n    'circle-solid': ['btn-icon-circle', 'circle-solid'],\n    'circle-thick-dashed': ['btn-icon-circle', 'circle-dashed', 'border-thick'],\n    'circle-thick-solid': ['btn-icon-circle', 'circle-solid', 'border-thick'],\n    'self-icon': ['btn-icon-self-circle']\n};\n\nconst themeClassesMap: any = {\n    'danger-weak': ['btn-icon-danger-weak']\n};\n\n/**\n * 操作按钮图标，支持`thy-button-icon`组件和`thyButtonIcon`指令两种形式\n * @name thy-button-icon,[thy-button-icon],[thyButtonIcon]\n * @order 20\n */\n@Component({\n    selector: 'thy-button-icon,[thy-button-icon],[thyButtonIcon]',\n    templateUrl: './button-icon.component.html',\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [NgIf, ThyIcon, NgClass]\n})\nexport class ThyButtonIcon implements OnInit {\n    /**\n     * 大小\n     * @type xs | sm | md | lg\n     * @default 36px\n     */\n    @Input()\n    set thySize(size: string) {\n        this.size = size;\n        this.setClasses();\n    }\n\n    /**\n     * 图标, 和`thyButtonIcon`相同，当使用`thy-button-icon`时，只能使用 thyIcon 设置图标\n     */\n    @Input()\n    set thyIcon(icon: string) {\n        this.setIconClass(icon);\n    }\n\n    /**\n     * 图标按钮的图标\n     */\n    @Input()\n    set thyButtonIcon(icon: string) {\n        this.setIconClass(icon);\n    }\n\n    /**\n     * 展示的形状，默认只显示字体图标图标，circle-dashed, circle-solid 展示成虚线,实线边框圆形图标, circle-thick-dashed, circle-thick-solid 边框加粗\n     */\n    @Input()\n    set thyShape(value: ThyButtonIconShape) {\n        this.shape = value;\n        this.setClasses();\n    }\n\n    /**\n     * 亮色，颜色更浅，适合左侧导航顶部的按钮\n     * @default false\n     */\n    @Input()\n    @InputBoolean()\n    set thyLight(value: boolean) {\n        this._isLighted = coerceBooleanProperty(value);\n    }\n\n    /**\n     * 设置为选中状态\n     * @default false\n     */\n    @Input()\n    @InputBoolean()\n    set thyActive(value: boolean) {\n        this._isActive = coerceBooleanProperty(value);\n    }\n\n    /**\n     * 按钮展示类型，默认图标移上去显示主色， danger-weak 鼠标移上去显示 danger 红色\n     */\n    @Input()\n    set thyTheme(value: string) {\n        this.theme = value;\n        this.setClasses();\n    }\n\n    constructor() {}\n\n    private initialized = false;\n\n    private shape: ThyButtonIconShape;\n\n    private size: string;\n\n    private hostRenderer = useHostRenderer();\n\n    iconPrefix = 'wtf';\n\n    iconClasses: string[];\n\n    icon: string;\n\n    theme: string;\n\n    svgIconName: string;\n\n    @HostBinding('class.btn') _isBtn = true;\n    @HostBinding('class.btn-icon') _isBtnIcon = true;\n    @HostBinding('class.btn-icon-light') _isLighted = false;\n    @HostBinding('class.btn-icon-active') _isActive = false;\n\n    @Input() thyColor: string;\n\n    private setIconClass(icon: string) {\n        if (icon) {\n            if (icon.includes('wtf')) {\n                const classes = icon.split(' ');\n                if (classes.length === 1) {\n                    classes.unshift('wtf');\n                }\n                this.iconClasses = classes;\n                this.svgIconName = null;\n            } else {\n                this.svgIconName = icon;\n            }\n        } else {\n            this.iconClasses = null;\n            this.svgIconName = null;\n        }\n    }\n\n    private setClasses(first = false) {\n        // 设置样式判断是否已经初始化，未初始化直接返回，除非是初次调用\n        // 只有 ngOnInit 调用会传入 first = true\n        if (!first && !this.initialized) {\n            return;\n        }\n        const classes = sizeClassesMap[this.size] ? [...sizeClassesMap[this.size]] : [];\n        if (this.shape && shapeClassesMap[this.shape]) {\n            shapeClassesMap[this.shape].forEach((className: string) => {\n                classes.push(className);\n            });\n        }\n        if (this.theme && themeClassesMap[this.theme]) {\n            themeClassesMap[this.theme].forEach((className: string) => {\n                classes.push(className);\n            });\n        }\n        this.hostRenderer.updateClass(classes);\n    }\n\n    ngOnInit() {\n        this.setClasses(true);\n        this.initialized = true;\n    }\n}\n","<thy-icon *ngIf=\"svgIconName; else iconFont\" [thyIconName]=\"svgIconName\" [style.color]=\"thyColor\" [style.borderColor]=\"thyColor\"></thy-icon>\n<ng-template #iconFont>\n  <i [ngClass]=\"iconClasses\" *ngIf=\"iconClasses\" [style.color]=\"thyColor\" [style.borderColor]=\"thyColor\"></i>\n</ng-template>\n<ng-content></ng-content>\n"]}
165
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-icon.component.js","sourceRoot":"","sources":["../../../../src/button/button-icon.component.ts","../../../../src/button/button-icon.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, NgIf } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, HostBinding, Input, OnInit, ViewEncapsulation, booleanAttribute } from '@angular/core';\nimport { useHostRenderer } from '@tethys/cdk/dom';\nimport { ThyIcon } from 'ngx-tethys/icon';\n\nexport type ThyButtonIconShape = '' | 'circle-dashed' | 'circle-solid' | 'circle-thick-dashed' | 'circle-thick-solid' | 'self-icon';\n\nconst sizeClassesMap = {\n    lg: ['btn-icon-lg'],\n    md: ['btn-icon-md'],\n    sm: ['btn-icon-sm'],\n    xs: ['btn-icon-xs']\n};\n\nconst shapeClassesMap = {\n    'circle-dashed': ['btn-icon-circle', 'circle-dashed'],\n    'circle-solid': ['btn-icon-circle', 'circle-solid'],\n    'circle-thick-dashed': ['btn-icon-circle', 'circle-dashed', 'border-thick'],\n    'circle-thick-solid': ['btn-icon-circle', 'circle-solid', 'border-thick'],\n    'self-icon': ['btn-icon-self-circle']\n};\n\nconst themeClassesMap: any = {\n    'danger-weak': ['btn-icon-danger-weak']\n};\n\n/**\n * 操作按钮图标，支持`thy-button-icon`组件和`thyButtonIcon`指令两种形式\n * @name thy-button-icon,[thy-button-icon],[thyButtonIcon]\n * @order 20\n */\n@Component({\n    selector: 'thy-button-icon,[thy-button-icon],[thyButtonIcon]',\n    templateUrl: './button-icon.component.html',\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [NgIf, ThyIcon, NgClass]\n})\nexport class ThyButtonIcon implements OnInit {\n    /**\n     * 大小\n     * @type xs | sm | md | lg\n     * @default 36px\n     */\n    @Input()\n    set thySize(size: string) {\n        this.size = size;\n        this.setClasses();\n    }\n\n    /**\n     * 图标, 和`thyButtonIcon`相同，当使用`thy-button-icon`时，只能使用 thyIcon 设置图标\n     */\n    @Input()\n    set thyIcon(icon: string) {\n        this.setIconClass(icon);\n    }\n\n    /**\n     * 图标按钮的图标\n     */\n    @Input()\n    set thyButtonIcon(icon: string) {\n        this.setIconClass(icon);\n    }\n\n    /**\n     * 展示的形状，默认只显示字体图标图标，circle-dashed, circle-solid 展示成虚线,实线边框圆形图标, circle-thick-dashed, circle-thick-solid 边框加粗\n     */\n    @Input()\n    set thyShape(value: ThyButtonIconShape) {\n        this.shape = value;\n        this.setClasses();\n    }\n\n    /**\n     * 亮色，颜色更浅，适合左侧导航顶部的按钮\n     * @default false\n     */\n    @Input({ transform: booleanAttribute })\n    set thyLight(value: boolean) {\n        this._isLighted = value;\n    }\n\n    /**\n     * 设置为选中状态\n     * @default false\n     */\n    @Input({ transform: booleanAttribute })\n    set thyActive(value: boolean) {\n        this._isActive = value;\n    }\n\n    /**\n     * 按钮展示类型，默认图标移上去显示主色， danger-weak 鼠标移上去显示 danger 红色\n     */\n    @Input()\n    set thyTheme(value: string) {\n        this.theme = value;\n        this.setClasses();\n    }\n\n    constructor() {}\n\n    private initialized = false;\n\n    private shape: ThyButtonIconShape;\n\n    private size: string;\n\n    private hostRenderer = useHostRenderer();\n\n    iconPrefix = 'wtf';\n\n    iconClasses: string[];\n\n    icon: string;\n\n    theme: string;\n\n    svgIconName: string;\n\n    @HostBinding('class.btn') _isBtn = true;\n    @HostBinding('class.btn-icon') _isBtnIcon = true;\n    @HostBinding('class.btn-icon-light') _isLighted = false;\n    @HostBinding('class.btn-icon-active') _isActive = false;\n\n    @Input() thyColor: string;\n\n    private setIconClass(icon: string) {\n        if (icon) {\n            if (icon.includes('wtf')) {\n                const classes = icon.split(' ');\n                if (classes.length === 1) {\n                    classes.unshift('wtf');\n                }\n                this.iconClasses = classes;\n                this.svgIconName = null;\n            } else {\n                this.svgIconName = icon;\n            }\n        } else {\n            this.iconClasses = null;\n            this.svgIconName = null;\n        }\n    }\n\n    private setClasses(first = false) {\n        // 设置样式判断是否已经初始化，未初始化直接返回，除非是初次调用\n        // 只有 ngOnInit 调用会传入 first = true\n        if (!first && !this.initialized) {\n            return;\n        }\n        const classes = sizeClassesMap[this.size] ? [...sizeClassesMap[this.size]] : [];\n        if (this.shape && shapeClassesMap[this.shape]) {\n            shapeClassesMap[this.shape].forEach((className: string) => {\n                classes.push(className);\n            });\n        }\n        if (this.theme && themeClassesMap[this.theme]) {\n            themeClassesMap[this.theme].forEach((className: string) => {\n                classes.push(className);\n            });\n        }\n        this.hostRenderer.updateClass(classes);\n    }\n\n    ngOnInit() {\n        this.setClasses(true);\n        this.initialized = true;\n    }\n}\n","<thy-icon *ngIf=\"svgIconName; else iconFont\" [thyIconName]=\"svgIconName\" [style.color]=\"thyColor\" [style.borderColor]=\"thyColor\"></thy-icon>\n<ng-template #iconFont>\n  <i [ngClass]=\"iconClasses\" *ngIf=\"iconClasses\" [style.color]=\"thyColor\" [style.borderColor]=\"thyColor\"></i>\n</ng-template>\n<ng-content></ng-content>\n"]}