ngx-tethys 19.0.12 → 19.1.0-next.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (270) hide show
  1. package/CHANGELOG.md +21 -0
  2. package/action/action.component.d.ts +2 -2
  3. package/alert/alert.component.d.ts +1 -1
  4. package/anchor/anchor-link.component.d.ts +8 -8
  5. package/anchor/anchor.component.d.ts +15 -21
  6. package/arrow-switcher/arrow-switcher.component.d.ts +15 -22
  7. package/autocomplete/autocomplete.component.d.ts +10 -17
  8. package/autocomplete/autocomplete.trigger.directive.d.ts +10 -18
  9. package/avatar/avatar-list/avatar-list.component.d.ts +1 -1
  10. package/avatar/avatar.component.d.ts +5 -5
  11. package/back-top/back-top.component.d.ts +9 -12
  12. package/badge/badge.component.d.ts +19 -59
  13. package/breadcrumb/breadcrumb.component.d.ts +15 -20
  14. package/button/button-icon.component.d.ts +3 -2
  15. package/button/button.component.d.ts +3 -2
  16. package/calendar/calendar-header.component.d.ts +9 -8
  17. package/calendar/calendar.component.d.ts +16 -16
  18. package/card/card.component.d.ts +5 -11
  19. package/card/content.component.d.ts +3 -8
  20. package/card/header.component.d.ts +7 -8
  21. package/carousel/carousel.component.d.ts +22 -27
  22. package/cascader/cascader-li.component.d.ts +13 -21
  23. package/cascader/cascader-search-option.component.d.ts +8 -16
  24. package/cascader/cascader.component.d.ts +58 -80
  25. package/checkbox/checkbox.component.d.ts +2 -5
  26. package/collapse/collapse-item.component.d.ts +12 -19
  27. package/collapse/collapse.component.d.ts +6 -12
  28. package/collapse/collapse.token.d.ts +3 -3
  29. package/color-picker/color-picker-custom-panel.component.d.ts +5 -5
  30. package/color-picker/color-picker-panel.component.d.ts +7 -11
  31. package/color-picker/color-picker.component.d.ts +19 -35
  32. package/color-picker/parts/alpha/alpha.component.d.ts +8 -8
  33. package/color-picker/parts/hue/hue.component.d.ts +6 -6
  34. package/color-picker/parts/indicator/indicator.component.d.ts +4 -3
  35. package/color-picker/parts/inputs/inputs.component.d.ts +9 -9
  36. package/color-picker/parts/saturation/saturation.component.d.ts +9 -9
  37. package/comment/comment.component.d.ts +4 -5
  38. package/copy/copy.directive.d.ts +8 -9
  39. package/date-picker/abstract-picker.component.d.ts +8 -7
  40. package/date-picker/lib/calendar/calendar-footer.component.d.ts +2 -1
  41. package/date-picker/lib/popups/inner-popup.component.d.ts +2 -1
  42. package/date-picker/picker.component.d.ts +2 -1
  43. package/date-range/date-range.component.d.ts +2 -2
  44. package/dialog/body/dialog-body.component.d.ts +2 -6
  45. package/dialog/confirm/confirm.component.d.ts +2 -2
  46. package/dialog/footer/dialog-footer.component.d.ts +6 -9
  47. package/dialog/header/dialog-header.component.d.ts +9 -11
  48. package/divider/divider.component.d.ts +12 -16
  49. package/dot/dot.component.d.ts +5 -13
  50. package/drag-drop/drag-handle.directive.d.ts +2 -1
  51. package/drag-drop/drag.directive.d.ts +2 -1
  52. package/drag-drop/drop-container.directive.d.ts +2 -1
  53. package/dropdown/dropdown-menu-item.directive.d.ts +3 -2
  54. package/dropdown/dropdown-menu.component.d.ts +2 -1
  55. package/dropdown/dropdown.directive.d.ts +2 -1
  56. package/empty/empty.component.d.ts +21 -27
  57. package/fesm2022/ngx-tethys-anchor.mjs +91 -118
  58. package/fesm2022/ngx-tethys-anchor.mjs.map +1 -1
  59. package/fesm2022/ngx-tethys-arrow-switcher.mjs +51 -77
  60. package/fesm2022/ngx-tethys-arrow-switcher.mjs.map +1 -1
  61. package/fesm2022/ngx-tethys-autocomplete.mjs +69 -103
  62. package/fesm2022/ngx-tethys-autocomplete.mjs.map +1 -1
  63. package/fesm2022/ngx-tethys-avatar.mjs.map +1 -1
  64. package/fesm2022/ngx-tethys-back-top.mjs +33 -46
  65. package/fesm2022/ngx-tethys-back-top.mjs.map +1 -1
  66. package/fesm2022/ngx-tethys-badge.mjs +104 -208
  67. package/fesm2022/ngx-tethys-badge.mjs.map +1 -1
  68. package/fesm2022/ngx-tethys-breadcrumb.mjs +66 -70
  69. package/fesm2022/ngx-tethys-breadcrumb.mjs.map +1 -1
  70. package/fesm2022/ngx-tethys-calendar.mjs +85 -87
  71. package/fesm2022/ngx-tethys-calendar.mjs.map +1 -1
  72. package/fesm2022/ngx-tethys-card.mjs +72 -77
  73. package/fesm2022/ngx-tethys-card.mjs.map +1 -1
  74. package/fesm2022/ngx-tethys-carousel.mjs +82 -99
  75. package/fesm2022/ngx-tethys-carousel.mjs.map +1 -1
  76. package/fesm2022/ngx-tethys-cascader.mjs +313 -468
  77. package/fesm2022/ngx-tethys-cascader.mjs.map +1 -1
  78. package/fesm2022/ngx-tethys-checkbox.mjs +10 -17
  79. package/fesm2022/ngx-tethys-checkbox.mjs.map +1 -1
  80. package/fesm2022/ngx-tethys-collapse.mjs +66 -71
  81. package/fesm2022/ngx-tethys-collapse.mjs.map +1 -1
  82. package/fesm2022/ngx-tethys-color-picker.mjs +187 -246
  83. package/fesm2022/ngx-tethys-color-picker.mjs.map +1 -1
  84. package/fesm2022/ngx-tethys-comment.mjs +16 -10
  85. package/fesm2022/ngx-tethys-comment.mjs.map +1 -1
  86. package/fesm2022/ngx-tethys-copy.mjs +25 -28
  87. package/fesm2022/ngx-tethys-copy.mjs.map +1 -1
  88. package/fesm2022/ngx-tethys-dialog.mjs +81 -82
  89. package/fesm2022/ngx-tethys-dialog.mjs.map +1 -1
  90. package/fesm2022/ngx-tethys-divider.mjs +49 -58
  91. package/fesm2022/ngx-tethys-divider.mjs.map +1 -1
  92. package/fesm2022/ngx-tethys-dot.mjs +45 -68
  93. package/fesm2022/ngx-tethys-dot.mjs.map +1 -1
  94. package/fesm2022/ngx-tethys-empty.mjs +107 -95
  95. package/fesm2022/ngx-tethys-empty.mjs.map +1 -1
  96. package/fesm2022/ngx-tethys-form.mjs +161 -200
  97. package/fesm2022/ngx-tethys-form.mjs.map +1 -1
  98. package/fesm2022/ngx-tethys-fullscreen.mjs +21 -23
  99. package/fesm2022/ngx-tethys-fullscreen.mjs.map +1 -1
  100. package/fesm2022/ngx-tethys-grid.mjs +160 -152
  101. package/fesm2022/ngx-tethys-grid.mjs.map +1 -1
  102. package/fesm2022/ngx-tethys-i18n.mjs +25 -25
  103. package/fesm2022/ngx-tethys-i18n.mjs.map +1 -1
  104. package/fesm2022/ngx-tethys-input-number.mjs +101 -114
  105. package/fesm2022/ngx-tethys-input-number.mjs.map +1 -1
  106. package/fesm2022/ngx-tethys-input.mjs +268 -271
  107. package/fesm2022/ngx-tethys-input.mjs.map +1 -1
  108. package/fesm2022/ngx-tethys-loading.mjs +17 -35
  109. package/fesm2022/ngx-tethys-loading.mjs.map +1 -1
  110. package/fesm2022/ngx-tethys-mention.mjs +3 -3
  111. package/fesm2022/ngx-tethys-mention.mjs.map +1 -1
  112. package/fesm2022/ngx-tethys-menu.mjs +106 -179
  113. package/fesm2022/ngx-tethys-menu.mjs.map +1 -1
  114. package/fesm2022/ngx-tethys-nav.mjs +169 -201
  115. package/fesm2022/ngx-tethys-nav.mjs.map +1 -1
  116. package/fesm2022/ngx-tethys-pagination.mjs +230 -294
  117. package/fesm2022/ngx-tethys-pagination.mjs.map +1 -1
  118. package/fesm2022/ngx-tethys-popover.mjs +67 -70
  119. package/fesm2022/ngx-tethys-popover.mjs.map +1 -1
  120. package/fesm2022/ngx-tethys-progress.mjs +196 -244
  121. package/fesm2022/ngx-tethys-progress.mjs.map +1 -1
  122. package/fesm2022/ngx-tethys-property.mjs +102 -105
  123. package/fesm2022/ngx-tethys-property.mjs.map +1 -1
  124. package/fesm2022/ngx-tethys-radio.mjs +34 -38
  125. package/fesm2022/ngx-tethys-radio.mjs.map +1 -1
  126. package/fesm2022/ngx-tethys-result.mjs +46 -28
  127. package/fesm2022/ngx-tethys-result.mjs.map +1 -1
  128. package/fesm2022/ngx-tethys-skeleton.mjs +339 -342
  129. package/fesm2022/ngx-tethys-skeleton.mjs.map +1 -1
  130. package/fesm2022/ngx-tethys-slider.mjs +75 -108
  131. package/fesm2022/ngx-tethys-slider.mjs.map +1 -1
  132. package/fesm2022/ngx-tethys-space.mjs +26 -46
  133. package/fesm2022/ngx-tethys-space.mjs.map +1 -1
  134. package/fesm2022/ngx-tethys-statistic.mjs +114 -151
  135. package/fesm2022/ngx-tethys-statistic.mjs.map +1 -1
  136. package/fesm2022/ngx-tethys-stepper.mjs +74 -107
  137. package/fesm2022/ngx-tethys-stepper.mjs.map +1 -1
  138. package/fesm2022/ngx-tethys-switch.mjs +80 -140
  139. package/fesm2022/ngx-tethys-switch.mjs.map +1 -1
  140. package/fesm2022/ngx-tethys-table.mjs +1 -1
  141. package/fesm2022/ngx-tethys-table.mjs.map +1 -1
  142. package/fesm2022/ngx-tethys-tabs.mjs +69 -87
  143. package/fesm2022/ngx-tethys-tabs.mjs.map +1 -1
  144. package/fesm2022/ngx-tethys-tag.mjs +42 -64
  145. package/fesm2022/ngx-tethys-tag.mjs.map +1 -1
  146. package/fesm2022/ngx-tethys-timeline.mjs +104 -129
  147. package/fesm2022/ngx-tethys-timeline.mjs.map +1 -1
  148. package/fesm2022/ngx-tethys-typography.mjs +36 -33
  149. package/fesm2022/ngx-tethys-typography.mjs.map +1 -1
  150. package/fesm2022/ngx-tethys-upload.mjs +91 -130
  151. package/fesm2022/ngx-tethys-upload.mjs.map +1 -1
  152. package/fesm2022/ngx-tethys-util.mjs.map +1 -1
  153. package/fesm2022/ngx-tethys-watermark.mjs +36 -40
  154. package/fesm2022/ngx-tethys-watermark.mjs.map +1 -1
  155. package/fesm2022/ngx-tethys.mjs +1 -1
  156. package/fesm2022/ngx-tethys.mjs.map +1 -1
  157. package/form/form-group-error/form-group-error.component.d.ts +2 -3
  158. package/form/form-group-label.directive.d.ts +2 -1
  159. package/form/form-group.component.d.ts +17 -24
  160. package/form/form-submit.directive.d.ts +2 -2
  161. package/form/form.directive.d.ts +6 -8
  162. package/form/from-group-footer/form-group-footer.component.d.ts +2 -2
  163. package/form/validator/confirm-validator.directive.d.ts +2 -2
  164. package/form/validator/unique-validator.directive.d.ts +2 -2
  165. package/fullscreen/fullscreen.component.d.ts +7 -7
  166. package/grid/flex.d.ts +14 -19
  167. package/grid/thy-col.directive.d.ts +6 -9
  168. package/grid/thy-grid-item.component.d.ts +3 -4
  169. package/grid/thy-grid.component.d.ts +11 -12
  170. package/grid/thy-row.directive.d.ts +12 -12
  171. package/icon/icon.component.d.ts +3 -2
  172. package/image/image.directive.d.ts +3 -2
  173. package/input/input-count.component.d.ts +4 -5
  174. package/input/input-group.component.d.ts +20 -20
  175. package/input/input-search.component.d.ts +15 -20
  176. package/input/input.component.d.ts +20 -21
  177. package/input/input.directive.d.ts +4 -6
  178. package/input-number/input-number.component.d.ts +21 -29
  179. package/layout/header.component.d.ts +4 -9
  180. package/layout/sidebar-header.component.d.ts +2 -1
  181. package/layout/sidebar.component.d.ts +8 -7
  182. package/list/list.component.d.ts +2 -1
  183. package/list/selection/selection-list.d.ts +4 -3
  184. package/loading/loading.component.d.ts +4 -10
  185. package/mention/mention.directive.d.ts +2 -2
  186. package/menu/group/menu-group.component.d.ts +16 -33
  187. package/menu/item/action/menu-item-action.component.d.ts +7 -8
  188. package/menu/item/icon/menu-item-icon.component.d.ts +2 -2
  189. package/menu/item/menu-item.component.d.ts +4 -4
  190. package/menu/item/name/menu-item-name.component.d.ts +2 -3
  191. package/menu/menu.component.d.ts +3 -7
  192. package/nav/icon-nav/icon-nav-link.directive.d.ts +3 -7
  193. package/nav/icon-nav/icon-nav.component.d.ts +3 -8
  194. package/nav/nav-ink-bar.directive.d.ts +4 -6
  195. package/nav/nav-item.directive.d.ts +7 -10
  196. package/nav/nav.component.d.ts +20 -48
  197. package/package.json +1 -1
  198. package/pagination/pagination.component.d.ts +48 -109
  199. package/popover/header/popover-header.component.d.ts +7 -6
  200. package/popover/popover.directive.d.ts +11 -18
  201. package/progress/progress-circle.component.d.ts +32 -21
  202. package/progress/progress-strip.component.d.ts +10 -14
  203. package/progress/progress.component.d.ts +15 -23
  204. package/property/examples/single/single.component.scss +6 -0
  205. package/property/properties.component.d.ts +6 -13
  206. package/property/property-item.component.d.ts +21 -26
  207. package/property/styles/properties.scss +124 -52
  208. package/property-operation/property-operation.component.d.ts +6 -5
  209. package/radio/button/radio-button.component.d.ts +2 -2
  210. package/radio/group/radio-group.component.d.ts +8 -7
  211. package/radio/radio.component.d.ts +2 -2
  212. package/radio/radio.token.d.ts +2 -2
  213. package/rate/rate-item.component.d.ts +2 -1
  214. package/rate/rate.component.d.ts +4 -3
  215. package/resizable/resizable.directive.d.ts +4 -9
  216. package/resizable/resize-handle.component.d.ts +2 -1
  217. package/resizable/resize-handles.component.d.ts +2 -1
  218. package/result/result.component.d.ts +9 -10
  219. package/schematics/version.d.ts +1 -1
  220. package/schematics/version.js +1 -1
  221. package/segment/segment-item.component.d.ts +2 -1
  222. package/segment/segment.component.d.ts +2 -1
  223. package/select/custom-select/custom-select.component.d.ts +11 -10
  224. package/select/native-select/native-select.component.d.ts +2 -1
  225. package/shared/base-form-check.component.d.ts +3 -2
  226. package/shared/directives/thy-autofocus.directive.d.ts +3 -2
  227. package/shared/directives/thy-scroll.directive.d.ts +2 -1
  228. package/shared/directives/thy-show.d.ts +2 -1
  229. package/shared/option/group/option-group.component.d.ts +2 -1
  230. package/shared/option/list-option/list-option.component.d.ts +2 -7
  231. package/shared/option/option.component.d.ts +2 -1
  232. package/shared/select/select-control/select-control.component.d.ts +7 -6
  233. package/skeleton/skeleton-circle.component.d.ts +16 -19
  234. package/skeleton/skeleton-rectangle.component.d.ts +20 -23
  235. package/skeleton/skeleton.component.d.ts +5 -6
  236. package/skeleton/stylized/bullet-list.component.d.ts +11 -13
  237. package/skeleton/stylized/list.component.d.ts +10 -12
  238. package/skeleton/stylized/paragraph.component.d.ts +12 -14
  239. package/slide/slide-body/slide-body-section.component.d.ts +2 -1
  240. package/slider/slider.component.d.ts +17 -24
  241. package/space/space.component.d.ts +8 -8
  242. package/statistic/statistic.component.d.ts +35 -40
  243. package/stepper/step-header.component.d.ts +6 -10
  244. package/stepper/step.component.d.ts +6 -6
  245. package/stepper/stepper.component.d.ts +15 -20
  246. package/switch/switch.component.d.ts +24 -35
  247. package/table/table-column.component.d.ts +6 -5
  248. package/table/table-skeleton.component.d.ts +3 -10
  249. package/table/table.component.d.ts +11 -10
  250. package/tabs/tab-content.component.d.ts +4 -4
  251. package/tabs/tab.component.d.ts +4 -5
  252. package/tabs/tabs.component.d.ts +13 -15
  253. package/tag/tag.component.d.ts +10 -16
  254. package/time-picker/time-picker-panel.component.d.ts +3 -2
  255. package/time-picker/time-picker.component.d.ts +6 -5
  256. package/timeline/timeline-item.component.d.ts +9 -13
  257. package/timeline/timeline.component.d.ts +13 -17
  258. package/tooltip/tooltip.directive.d.ts +3 -2
  259. package/tree/tree-node.component.d.ts +6 -15
  260. package/tree/tree.component.d.ts +8 -7
  261. package/tree-select/tree-select.component.d.ts +8 -7
  262. package/typography/bg-color.directive.d.ts +3 -3
  263. package/typography/text/text.component.d.ts +2 -2
  264. package/typography/text-color.directive.d.ts +3 -3
  265. package/upload/file-drop.directive.d.ts +9 -11
  266. package/upload/file-select-base.d.ts +6 -10
  267. package/upload/file-select.component.d.ts +10 -20
  268. package/util/helpers/helpers.d.ts +2 -1
  269. package/vote/vote.component.d.ts +4 -3
  270. package/watermark/watermark.directive.d.ts +7 -9
@@ -1 +1 @@
1
- {"version":3,"file":"ngx-tethys-back-top.mjs","sources":["../../../src/back-top/back-top.component.ts","../../../src/back-top/back-top.component.html","../../../src/back-top/back-top.module.ts","../../../src/back-top/ngx-tethys-back-top.ts"],"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 ViewChild,\n ElementRef,\n numberAttribute,\n inject\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, 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 imports: [ThyIcon, NgTemplateOutlet]\n})\nexport class ThyBackTop implements OnInit, OnDestroy, OnChanges {\n private doc = inject(DOCUMENT);\n private thyScrollService = inject(ThyScrollService);\n private platform = inject(Platform);\n private cdr = inject(ChangeDetectorRef);\n private zone = inject(NgZone);\n\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 const zone = this.zone;\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","@if (visible) {\n <div class=\"thy-back-top\" #backTop @fadeMotion>\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}\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { ThyIconModule } from 'ngx-tethys/icon';\nimport { ThyBackTop } from './back-top.component';\n\n@NgModule({\n imports: [CommonModule, ThyIconModule, ThyBackTop],\n exports: [ThyBackTop]\n})\nexport class ThyBackTopModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"ngx-tethys-back-top.mjs","sources":["../../../src/back-top/back-top.component.ts","../../../src/back-top/back-top.component.html","../../../src/back-top/back-top.module.ts","../../../src/back-top/ngx-tethys-back-top.ts"],"sourcesContent":["import {\n Component,\n OnInit,\n ChangeDetectionStrategy,\n ViewEncapsulation,\n TemplateRef,\n HostBinding,\n NgZone,\n ChangeDetectorRef,\n OnDestroy,\n OnChanges,\n ViewChild,\n ElementRef,\n numberAttribute,\n inject,\n input,\n output,\n effect,\n viewChild,\n Signal,\n computed\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, 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 imports: [ThyIcon, NgTemplateOutlet]\n})\nexport class ThyBackTop implements OnInit, OnDestroy {\n private doc = inject(DOCUMENT);\n private thyScrollService = inject(ThyScrollService);\n private platform = inject(Platform);\n private cdr = inject(ChangeDetectorRef);\n private zone = inject(NgZone);\n\n @HostBinding('class.thy-back-top-container') classNames = true;\n\n /**\n * 自定义按钮显示模板\n */\n readonly thyTemplate = input<TemplateRef<void>>();\n\n /**\n * 指定对哪个 DOM 元素返回顶部\n * @type string | HTMLElement\n * @default window\n */\n readonly thyContainer = input<string | HTMLElement>();\n\n /**\n * 滚动高度达到此参数值才出现 thy-back-top\n * @type number\n */\n readonly thyVisibilityHeight = input(400, { transform: numberAttribute });\n\n /**\n * 点击按钮的回调函数\n */\n readonly thyClick = output<boolean>();\n\n /**\n * 监听按钮显示状态的回调函数\n */\n public readonly visibleChange = output<boolean>();\n\n /** The native `<div class=\"thy-back-top\"></div>` element. */\n readonly backTop = viewChild<ElementRef<HTMLElement>>('backTop');\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\n private scrollListenerDestroy$ = new Subject<void>();\n\n private target: Signal<Element | Window> = computed(() => {\n const thyContainerValue = this.thyContainer();\n const target = typeof thyContainerValue === 'string' ? this.doc.querySelector(thyContainerValue) : thyContainerValue;\n return target || window;\n });\n\n constructor() {\n const zone = this.zone;\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.target(), 0);\n zone.run(() => this.thyClick.emit(true));\n });\n\n effect(() => {\n this.backTop$.next(this.backTop());\n });\n }\n\n ngOnInit(): void {\n this.registerScrollEvent();\n }\n\n private handleScroll(): void {\n if (this.visible === this.thyScrollService.getScroll(this.target()) > this.thyVisibilityHeight()) {\n return;\n }\n this.visible = !this.visible;\n this.cdr.detectChanges();\n this.zone.run(() => {\n this.visibleChange.emit(this.visible);\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.target(), '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","@if (visible) {\n <div class=\"thy-back-top\" #backTop @fadeMotion>\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}\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { ThyIconModule } from 'ngx-tethys/icon';\nimport { ThyBackTop } from './back-top.component';\n\n@NgModule({\n imports: [CommonModule, ThyIconModule, ThyBackTop],\n exports: [ThyBackTop]\n})\nexport class ThyBackTopModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
@@ -1,8 +1,8 @@
1
1
  import * as i0 from '@angular/core';
2
- import { inject, ElementRef, numberAttribute, Input, ChangeDetectionStrategy, Component, NgModule } from '@angular/core';
2
+ import { inject, ElementRef, computed, input, numberAttribute, ChangeDetectionStrategy, Component, NgModule } from '@angular/core';
3
3
  import { CommonModule } from '@angular/common';
4
4
  import { isTextColor } from 'ngx-tethys/core';
5
- import { coerceBooleanProperty } from 'ngx-tethys/util';
5
+ import { isUndefined, coerceBooleanProperty } from 'ngx-tethys/util';
6
6
 
7
7
  /**
8
8
  * 徽标组件,支持组件`thy-badge`和`thyBadge`指令两种使用方式
@@ -11,146 +11,109 @@ import { coerceBooleanProperty } from 'ngx-tethys/util';
11
11
  class ThyBadge {
12
12
  constructor() {
13
13
  this.elementRef = inject(ElementRef);
14
- this.displayContent = '';
15
- this.badgeClassName = '';
16
- this.initialized = false;
14
+ this.displayContent = computed(() => {
15
+ let content = this.value();
16
+ if (this.value() && !isUndefined(this.thyMaxCount()) && this.value() > this.thyMaxCount()) {
17
+ content = `${this.thyMaxCount()}+`;
18
+ }
19
+ return content;
20
+ });
21
+ this.badgeClassName = computed(() => {
22
+ const classes = [];
23
+ classes.push(`thy-badge-${this.thyType()}`);
24
+ if (this.thySize()) {
25
+ classes.push(`thy-badge-${this.thySize()}`);
26
+ }
27
+ if (this.thyIsDot()) {
28
+ classes.push(`thy-badge-dot`);
29
+ }
30
+ else if (this.thyIsHollow()) {
31
+ classes.push(`thy-badge-hollow`);
32
+ }
33
+ else {
34
+ classes.push(`thy-badge-count`);
35
+ }
36
+ const builtInTextColorClass = isTextColor(this.thyTextColor()) ? `text-${this.thyTextColor()}` : null;
37
+ if (builtInTextColorClass) {
38
+ classes.push(builtInTextColorClass);
39
+ }
40
+ const builtInBackgroundColorClass = isTextColor(this.thyBackgroundColor()) ? `bg-${this.thyBackgroundColor()}` : null;
41
+ if (builtInBackgroundColorClass) {
42
+ classes.push(builtInBackgroundColorClass);
43
+ }
44
+ return classes.join(' ');
45
+ });
17
46
  // 是否包裹在元素上
18
47
  this.isWrapper = false;
19
- this.isShowBadge = true;
20
- this.keepShowValue = false;
21
- this.value = '';
22
- this.valueHasBeenSet = false;
23
- this.supClasses = [];
48
+ this.isShowBadge = computed(() => {
49
+ return !(!this.value() && !this.thyKeepShow() && !this.thyIsDot() && !this.thyIsHollow());
50
+ });
51
+ this.value = computed(() => {
52
+ return this.thyContent() || this.thyContext() || this.thyCount();
53
+ });
54
+ this.textColor = computed(() => {
55
+ return !isTextColor(this.thyTextColor()) ? this.thyTextColor() : null;
56
+ });
57
+ this.backgroundColor = computed(() => {
58
+ return !isTextColor(this.thyBackgroundColor()) ? this.thyBackgroundColor() : null;
59
+ });
60
+ /**
61
+ * 徽标类型
62
+ * @type default | primary | danger | warning | success
63
+ */
64
+ this.thyType = input('danger', {
65
+ transform: (value) => value || 'danger'
66
+ });
67
+ /**
68
+ * 徽标内容数字
69
+ * @type number
70
+ */
71
+ this.thyCount = input(undefined, { transform: numberAttribute });
72
+ /**
73
+ * 徽标内容文本
74
+ * @type string
75
+ */
76
+ this.thyContent = input();
77
+ /**
78
+ * 已废弃,徽标内容文本,命名错误,请使用 thyContent
79
+ */
80
+ this.thyContext = input();
81
+ /**
82
+ * 徽标显示的最大值, 与 thyCount 一起使用,thyCount 超过了 thyMaxCount 设置的值时,徽标内容为 thyMaxCount+
83
+ * @type number
84
+ */
85
+ this.thyMaxCount = input(undefined, { transform: numberAttribute });
86
+ /**
87
+ * 徽标显示的大小
88
+ * @type md | sm | lg
89
+ */
90
+ this.thySize = input('md', { transform: (value) => value || 'md' });
91
+ /**
92
+ * 已废弃,徽标是一个实心点,已经被废弃
93
+ * @deprecated
94
+ */
95
+ this.thyIsDot = input(false, { transform: coerceBooleanProperty });
96
+ /**
97
+ * 已废弃,徽标是一个空心点
98
+ * @deprecated
99
+ */
100
+ this.thyIsHollow = input(false, { transform: coerceBooleanProperty });
101
+ /**
102
+ * thyCount 为 0 时,强制显示数字 0,默认不显示
103
+ */
104
+ this.thyKeepShow = input(false, { transform: coerceBooleanProperty });
105
+ /**
106
+ * 设置徽标字体的颜色,支持内置颜色和自定义颜色 'primary' | '#87d068' | ...
107
+ * @type string
108
+ */
109
+ this.thyTextColor = input('');
110
+ /**
111
+ * 设置徽标的背景颜色,支持内置颜色和自定义颜色 'primary' | '#87d068' | ...
112
+ * @type string
113
+ */
114
+ this.thyBackgroundColor = input('');
24
115
  this.nativeElement = this.elementRef.nativeElement;
25
116
  }
26
- /**
27
- * 徽标类型
28
- * @type default | primary | danger | warning | success
29
- * @default danger
30
- */
31
- set thyType(value) {
32
- this.type = value;
33
- if (this.initialized) {
34
- this.combineBadgeClasses();
35
- }
36
- }
37
- /**
38
- * 徽标内容数字
39
- * @type number
40
- */
41
- set thyCount(value) {
42
- this.value = value;
43
- this.valueHasBeenSet = true;
44
- if (this.initialized) {
45
- this.combineBadgeDisplayContent();
46
- this.combineBadgeClasses();
47
- }
48
- }
49
- /**
50
- * 徽标内容文本
51
- * @type string
52
- */
53
- set thyContent(value) {
54
- this.value = value;
55
- this.valueHasBeenSet = true;
56
- if (this.initialized) {
57
- this.combineBadgeDisplayContent();
58
- this.combineBadgeClasses();
59
- }
60
- }
61
- /**
62
- * 已废弃,徽标内容文本,命名错误,请使用 thyContent
63
- * @deprecated
64
- */
65
- set thyContext(value) {
66
- this.thyContent = value;
67
- }
68
- /**
69
- * 徽标显示的最大值, 与 thyCount 一起使用,thyCount 超过了 thyMaxCount 设置的值时,徽标内容为 thyMaxCount+
70
- * @type number
71
- */
72
- set thyMaxCount(value) {
73
- this.maxCount = value;
74
- if (this.initialized) {
75
- this.combineBadgeDisplayContent();
76
- this.combineBadgeClasses();
77
- }
78
- }
79
- /**
80
- * 徽标显示的大小
81
- * @type md | sm | lg
82
- * @default md
83
- */
84
- set thySize(value) {
85
- this.size = value;
86
- if (this.initialized) {
87
- this.combineBadgeClasses();
88
- }
89
- }
90
- /**
91
- * 已废弃,徽标是一个实心点,已经被废弃
92
- * @deprecated
93
- */
94
- set thyIsDot(value) {
95
- this.isDot = value;
96
- if (this.initialized) {
97
- this.combineBadgeClasses();
98
- }
99
- }
100
- /**
101
- * 已废弃,徽标是一个空心点
102
- * @deprecated
103
- */
104
- set thyIsHollow(value) {
105
- this.isHollow = value;
106
- if (this.initialized) {
107
- this.combineBadgeClasses();
108
- }
109
- }
110
- /**
111
- * thyCount 为 0 时,强制显示数字 0,默认不显示
112
- * @default false
113
- */
114
- set thyKeepShow(value) {
115
- this.keepShowValue = value;
116
- if (this.initialized) {
117
- this.combineBadgeDisplayContent();
118
- }
119
- }
120
- /**
121
- * 设置徽标字体的颜色,支持内置颜色和自定义颜色 'primary' | '#87d068' | ...
122
- * @type string
123
- */
124
- set thyTextColor(value) {
125
- if (isTextColor(value)) {
126
- this.builtInTextColorClass = `text-${value}`;
127
- this.textColor = null;
128
- }
129
- else {
130
- this.textColor = value;
131
- this.builtInTextColorClass = null;
132
- }
133
- if (this.initialized) {
134
- this.combineBadgeClasses();
135
- }
136
- }
137
- /**
138
- * 设置徽标的背景颜色,支持内置颜色和自定义颜色 'primary' | '#87d068' | ...
139
- * @type string
140
- */
141
- set thyBackgroundColor(value) {
142
- if (isTextColor(value)) {
143
- this.builtInBackgroundColorClass = `bg-${value}`;
144
- this.backgroundColor = null;
145
- }
146
- else {
147
- this.backgroundColor = value;
148
- this.builtInBackgroundColorClass = null;
149
- }
150
- if (this.initialized) {
151
- this.combineBadgeClasses();
152
- }
153
- }
154
117
  ngOnInit() {
155
118
  let childNodeCount = 0;
156
119
  this.nativeElement.childNodes.forEach((n) => {
@@ -159,84 +122,17 @@ class ThyBadge {
159
122
  }
160
123
  });
161
124
  this.isWrapper = childNodeCount > 0;
162
- this.combineBadgeClasses();
163
- if (this.valueHasBeenSet) {
164
- this.combineBadgeDisplayContent();
165
- }
166
- this.initialized = true;
167
- }
168
- combineBadgeClasses() {
169
- const classes = [];
170
- classes.push(`thy-badge-${this.type || 'danger'}`);
171
- if (this.size) {
172
- classes.push(`thy-badge-${this.size}`);
173
- }
174
- if (this.isDot) {
175
- classes.push(`thy-badge-dot`);
176
- }
177
- else if (this.isHollow) {
178
- classes.push(`thy-badge-hollow`);
179
- }
180
- else {
181
- classes.push(`thy-badge-count`);
182
- }
183
- if (this.builtInTextColorClass) {
184
- classes.push(this.builtInTextColorClass);
185
- }
186
- if (this.builtInBackgroundColorClass) {
187
- classes.push(this.builtInBackgroundColorClass);
188
- }
189
- this.badgeClassName = classes.join(' ');
190
- }
191
- combineBadgeDisplayContent() {
192
- this.displayContent = this.value;
193
- if (this.value && this.maxCount != undefined && this.value > this.maxCount) {
194
- this.displayContent = `${this.maxCount}+`;
195
- }
196
- if (!this.value && !this.keepShowValue) {
197
- this.isShowBadge = false;
198
- }
199
- else {
200
- this.isShowBadge = true;
201
- }
202
125
  }
203
126
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.8", ngImport: i0, type: ThyBadge, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
204
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.8", 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", coerceBooleanProperty], thyIsHollow: ["thyIsHollow", "thyIsHollow", coerceBooleanProperty], thyKeepShow: ["thyKeepShow", "thyKeepShow", coerceBooleanProperty], thyTextColor: "thyTextColor", thyBackgroundColor: "thyBackgroundColor" }, host: { properties: { "class.thy-badge-wrapper": "isWrapper" }, classAttribute: "thy-badge-container" }, ngImport: i0, template: "@if (isShowBadge) {\n <div class=\"thy-badge {{ badgeClassName }}\" [style.color]=\"textColor\" [style.backgroundColor]=\"backgroundColor\">\n <span>{{ displayContent }}</span>\n </div>\n}\n<ng-content></ng-content>\n", changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
127
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.8", type: ThyBadge, isStandalone: true, selector: "thy-badge,[thyBadge]", inputs: { thyType: { classPropertyName: "thyType", publicName: "thyType", isSignal: true, isRequired: false, transformFunction: null }, thyCount: { classPropertyName: "thyCount", publicName: "thyCount", isSignal: true, isRequired: false, transformFunction: null }, thyContent: { classPropertyName: "thyContent", publicName: "thyContent", isSignal: true, isRequired: false, transformFunction: null }, thyContext: { classPropertyName: "thyContext", publicName: "thyContext", isSignal: true, isRequired: false, transformFunction: null }, thyMaxCount: { classPropertyName: "thyMaxCount", publicName: "thyMaxCount", isSignal: true, isRequired: false, transformFunction: null }, thySize: { classPropertyName: "thySize", publicName: "thySize", isSignal: true, isRequired: false, transformFunction: null }, thyIsDot: { classPropertyName: "thyIsDot", publicName: "thyIsDot", isSignal: true, isRequired: false, transformFunction: null }, thyIsHollow: { classPropertyName: "thyIsHollow", publicName: "thyIsHollow", isSignal: true, isRequired: false, transformFunction: null }, thyKeepShow: { classPropertyName: "thyKeepShow", publicName: "thyKeepShow", isSignal: true, isRequired: false, transformFunction: null }, thyTextColor: { classPropertyName: "thyTextColor", publicName: "thyTextColor", isSignal: true, isRequired: false, transformFunction: null }, thyBackgroundColor: { classPropertyName: "thyBackgroundColor", publicName: "thyBackgroundColor", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class.thy-badge-wrapper": "isWrapper" }, classAttribute: "thy-badge-container" }, ngImport: i0, template: "@if (isShowBadge()) {\n <div class=\"thy-badge {{ badgeClassName() }}\" [style.color]=\"textColor()\" [style.backgroundColor]=\"backgroundColor()\">\n <span>{{ displayContent() }}</span>\n </div>\n}\n<ng-content></ng-content>\n", changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
205
128
  }
206
129
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.8", ngImport: i0, type: ThyBadge, decorators: [{
207
130
  type: Component,
208
131
  args: [{ selector: 'thy-badge,[thyBadge]', changeDetection: ChangeDetectionStrategy.OnPush, host: {
209
132
  class: 'thy-badge-container',
210
133
  '[class.thy-badge-wrapper]': 'isWrapper'
211
- }, imports: [], template: "@if (isShowBadge) {\n <div class=\"thy-badge {{ badgeClassName }}\" [style.color]=\"textColor\" [style.backgroundColor]=\"backgroundColor\">\n <span>{{ displayContent }}</span>\n </div>\n}\n<ng-content></ng-content>\n" }]
212
- }], ctorParameters: () => [], propDecorators: { thyType: [{
213
- type: Input
214
- }], thyCount: [{
215
- type: Input,
216
- args: [{ transform: numberAttribute }]
217
- }], thyContent: [{
218
- type: Input
219
- }], thyContext: [{
220
- type: Input
221
- }], thyMaxCount: [{
222
- type: Input,
223
- args: [{ transform: numberAttribute }]
224
- }], thySize: [{
225
- type: Input
226
- }], thyIsDot: [{
227
- type: Input,
228
- args: [{ transform: coerceBooleanProperty }]
229
- }], thyIsHollow: [{
230
- type: Input,
231
- args: [{ transform: coerceBooleanProperty }]
232
- }], thyKeepShow: [{
233
- type: Input,
234
- args: [{ transform: coerceBooleanProperty }]
235
- }], thyTextColor: [{
236
- type: Input
237
- }], thyBackgroundColor: [{
238
- type: Input
239
- }] } });
134
+ }, imports: [], template: "@if (isShowBadge()) {\n <div class=\"thy-badge {{ badgeClassName() }}\" [style.color]=\"textColor()\" [style.backgroundColor]=\"backgroundColor()\">\n <span>{{ displayContent() }}</span>\n </div>\n}\n<ng-content></ng-content>\n" }]
135
+ }], ctorParameters: () => [] });
240
136
 
241
137
  class ThyBadgeModule {
242
138
  constructor() { }
@@ -1 +1 @@
1
- {"version":3,"file":"ngx-tethys-badge.mjs","sources":["../../../src/badge/badge.component.ts","../../../src/badge/badge.component.html","../../../src/badge/badge.module.ts","../../../src/badge/ngx-tethys-badge.ts"],"sourcesContent":["import { isTextColor } from 'ngx-tethys/core';\n\nimport { ChangeDetectionStrategy, Component, ElementRef, Input, OnInit, numberAttribute, inject } from '@angular/core';\n\nimport { coerceBooleanProperty } from 'ngx-tethys/util';\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 imports: []\n})\nexport class ThyBadge implements OnInit {\n private elementRef = inject(ElementRef);\n\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() {\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: coerceBooleanProperty })\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: coerceBooleanProperty })\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: coerceBooleanProperty })\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","@if (isShowBadge) {\n <div class=\"thy-badge {{ badgeClassName }}\" [style.color]=\"textColor\" [style.backgroundColor]=\"backgroundColor\">\n <span>{{ displayContent }}</span>\n </div>\n}\n<ng-content></ng-content>\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { ThyBadge } from './badge.component';\n\n@NgModule({\n imports: [CommonModule, ThyBadge],\n exports: [ThyBadge]\n})\nexport class ThyBadgeModule {\n constructor() {}\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"ngx-tethys-badge.mjs","sources":["../../../src/badge/badge.component.ts","../../../src/badge/badge.component.html","../../../src/badge/badge.module.ts","../../../src/badge/ngx-tethys-badge.ts"],"sourcesContent":["import { isTextColor } from 'ngx-tethys/core';\n\nimport { ChangeDetectionStrategy, Component, ElementRef, OnInit, Signal, computed, inject, input, numberAttribute } from '@angular/core';\n\nimport { coerceBooleanProperty, isUndefined } from 'ngx-tethys/util';\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 imports: []\n})\nexport class ThyBadge implements OnInit {\n private elementRef = inject(ElementRef);\n\n private nativeElement: any;\n\n readonly displayContent: Signal<string> = computed(() => {\n let content = this.value() as string;\n if (this.value() && !isUndefined(this.thyMaxCount()) && (this.value() as number) > this.thyMaxCount()) {\n content = `${this.thyMaxCount()}+`;\n }\n return content;\n });\n\n readonly badgeClassName: Signal<string> = computed(() => {\n const classes: string[] = [];\n classes.push(`thy-badge-${this.thyType()}`);\n if (this.thySize()) {\n classes.push(`thy-badge-${this.thySize()}`);\n }\n if (this.thyIsDot()) {\n classes.push(`thy-badge-dot`);\n } else if (this.thyIsHollow()) {\n classes.push(`thy-badge-hollow`);\n } else {\n classes.push(`thy-badge-count`);\n }\n const builtInTextColorClass = isTextColor(this.thyTextColor()) ? `text-${this.thyTextColor()}` : null;\n if (builtInTextColorClass) {\n classes.push(builtInTextColorClass);\n }\n const builtInBackgroundColorClass = isTextColor(this.thyBackgroundColor()) ? `bg-${this.thyBackgroundColor()}` : null;\n if (builtInBackgroundColorClass) {\n classes.push(builtInBackgroundColorClass);\n }\n return classes.join(' ');\n });\n\n // 是否包裹在元素上\n protected isWrapper = false;\n\n public readonly isShowBadge: Signal<boolean> = computed(() => {\n return !(!this.value() && !this.thyKeepShow() && !this.thyIsDot() && !this.thyIsHollow());\n });\n\n private readonly value: Signal<number | string> = computed(() => {\n return this.thyContent() || this.thyContext() || this.thyCount();\n });\n\n protected readonly textColor: Signal<string> = computed(() => {\n return !isTextColor(this.thyTextColor()) ? this.thyTextColor() : null;\n });\n\n protected readonly backgroundColor: Signal<string> = computed(() => {\n return !isTextColor(this.thyBackgroundColor()) ? this.thyBackgroundColor() : null;\n });\n\n constructor() {\n this.nativeElement = this.elementRef.nativeElement;\n }\n\n /**\n * 徽标类型\n * @type default | primary | danger | warning | success\n */\n readonly thyType = input<string, string>('danger', {\n transform: (value: string) => value || 'danger'\n });\n\n /**\n * 徽标内容数字\n * @type number\n */\n readonly thyCount = input<number, unknown>(undefined, { transform: numberAttribute });\n\n /**\n * 徽标内容文本\n * @type string\n */\n readonly thyContent = input<string>();\n\n /**\n * 已废弃,徽标内容文本,命名错误,请使用 thyContent\n */\n readonly thyContext = input<string>();\n\n /**\n * 徽标显示的最大值, 与 thyCount 一起使用,thyCount 超过了 thyMaxCount 设置的值时,徽标内容为 thyMaxCount+\n * @type number\n */\n readonly thyMaxCount = input<number, unknown>(undefined, { transform: numberAttribute });\n\n /**\n * 徽标显示的大小\n * @type md | sm | lg\n */\n readonly thySize = input<ThyBadgeSize, ThyBadgeSize>('md', { transform: (value: ThyBadgeSize) => value || 'md' });\n\n /**\n * 已废弃,徽标是一个实心点,已经被废弃\n * @deprecated\n */\n readonly thyIsDot = input(false, { transform: coerceBooleanProperty });\n\n /**\n * 已废弃,徽标是一个空心点\n * @deprecated\n */\n readonly thyIsHollow = input(false, { transform: coerceBooleanProperty });\n\n /**\n * thyCount 为 0 时,强制显示数字 0,默认不显示\n */\n readonly thyKeepShow = input(false, { transform: coerceBooleanProperty });\n\n /**\n * 设置徽标字体的颜色,支持内置颜色和自定义颜色 'primary' | '#87d068' | ...\n * @type string\n */\n readonly thyTextColor = input<string>('');\n\n /**\n * 设置徽标的背景颜色,支持内置颜色和自定义颜色 'primary' | '#87d068' | ...\n * @type string\n */\n readonly thyBackgroundColor = input<string>('');\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}\n","@if (isShowBadge()) {\n <div class=\"thy-badge {{ badgeClassName() }}\" [style.color]=\"textColor()\" [style.backgroundColor]=\"backgroundColor()\">\n <span>{{ displayContent() }}</span>\n </div>\n}\n<ng-content></ng-content>\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { ThyBadge } from './badge.component';\n\n@NgModule({\n imports: [CommonModule, ThyBadge],\n exports: [ThyBadge]\n})\nexport class ThyBadgeModule {\n constructor() {}\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}