@delon/abc 15.2.1 → 16.0.0-beta.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 (461) hide show
  1. package/auto-focus/auto-focus.directive.d.ts +1 -1
  2. package/avatar-list/avatar-list-item.component.d.ts +1 -1
  3. package/avatar-list/avatar-list.component.d.ts +1 -1
  4. package/count-down/count-down.component.d.ts +1 -1
  5. package/date-picker/range.directive.d.ts +1 -1
  6. package/down-file/down-file.directive.d.ts +1 -1
  7. package/ellipsis/ellipsis.component.d.ts +1 -1
  8. package/error-collect/error-collect.component.d.ts +1 -1
  9. package/esm2022/auto-focus/auto-focus.directive.mjs +51 -0
  10. package/esm2022/auto-focus/auto-focus.module.mjs +18 -0
  11. package/esm2022/avatar-list/avatar-list-item.component.mjs +27 -0
  12. package/esm2022/avatar-list/avatar-list.component.mjs +89 -0
  13. package/esm2022/avatar-list/avatar-list.module.mjs +23 -0
  14. package/esm2022/count-down/count-down.component.mjs +46 -0
  15. package/esm2022/count-down/count-down.module.mjs +21 -0
  16. package/esm2022/date-picker/date-picker.module.mjs +23 -0
  17. package/esm2022/date-picker/range-shortcut.component.mjs +41 -0
  18. package/esm2022/date-picker/range.directive.mjs +174 -0
  19. package/esm2022/down-file/down-file.directive.mjs +115 -0
  20. package/esm2022/down-file/down-file.module.mjs +21 -0
  21. package/esm2022/ellipsis/ellipsis.component.mjs +233 -0
  22. package/esm2022/ellipsis/ellipsis.module.mjs +22 -0
  23. package/esm2022/error-collect/error-collect.component.mjs +122 -0
  24. package/esm2022/error-collect/error-collect.module.mjs +21 -0
  25. package/esm2022/exception/exception.component.mjs +109 -0
  26. package/esm2022/exception/exception.module.mjs +24 -0
  27. package/esm2022/footer-toolbar/footer-toolbar.component.mjs +45 -0
  28. package/esm2022/footer-toolbar/footer-toolbar.module.mjs +22 -0
  29. package/esm2022/full-content/full-content-toggle.directive.mjs +25 -0
  30. package/esm2022/full-content/full-content.component.mjs +140 -0
  31. package/esm2022/full-content/full-content.module.mjs +21 -0
  32. package/esm2022/full-content/full-content.service.mjs +23 -0
  33. package/esm2022/global-footer/global-footer-item.component.mjs +31 -0
  34. package/esm2022/global-footer/global-footer.component.mjs +73 -0
  35. package/esm2022/global-footer/global-footer.module.mjs +22 -0
  36. package/esm2022/hotkey/hotkey.directive.mjs +37 -0
  37. package/esm2022/hotkey/hotkey.module.mjs +18 -0
  38. package/esm2022/let/let.directive.mjs +38 -0
  39. package/esm2022/let/let.module.mjs +18 -0
  40. package/esm2022/loading/loading.component.mjs +27 -0
  41. package/esm2022/loading/loading.module.mjs +24 -0
  42. package/esm2022/loading/loading.service.mjs +91 -0
  43. package/esm2022/lodop/lodop.module.mjs +13 -0
  44. package/esm2022/lodop/lodop.service.mjs +223 -0
  45. package/esm2022/media/media.component.mjs +118 -0
  46. package/esm2022/media/media.module.mjs +20 -0
  47. package/esm2022/media/media.service.mjs +47 -0
  48. package/esm2022/notice-icon/notice-icon-tab.component.mjs +35 -0
  49. package/esm2022/notice-icon/notice-icon.component.mjs +90 -0
  50. package/esm2022/notice-icon/notice-icon.module.mjs +59 -0
  51. package/esm2022/observers/observer-size.mjs +119 -0
  52. package/esm2022/onboarding/onboarding.component.mjs +135 -0
  53. package/esm2022/onboarding/onboarding.module.mjs +27 -0
  54. package/esm2022/onboarding/onboarding.service.mjs +186 -0
  55. package/esm2022/page-header/page-header.component.mjs +247 -0
  56. package/esm2022/page-header/page-header.module.mjs +25 -0
  57. package/esm2022/pdf/pdf.component.mjs +474 -0
  58. package/esm2022/pdf/pdf.module.mjs +21 -0
  59. package/esm2022/qr/qr.component.mjs +137 -0
  60. package/esm2022/qr/qr.module.mjs +20 -0
  61. package/esm2022/quick-menu/quick-menu.component.mjs +90 -0
  62. package/esm2022/quick-menu/quick-menu.module.mjs +22 -0
  63. package/esm2022/result/result.component.mjs +61 -0
  64. package/esm2022/result/result.module.mjs +22 -0
  65. package/esm2022/reuse-tab/reuse-tab-context-menu.component.mjs +77 -0
  66. package/esm2022/reuse-tab/reuse-tab-context.component.mjs +34 -0
  67. package/esm2022/reuse-tab/reuse-tab-context.directive.mjs +36 -0
  68. package/esm2022/reuse-tab/reuse-tab-context.service.mjs +56 -0
  69. package/esm2022/reuse-tab/reuse-tab.component.mjs +368 -0
  70. package/esm2022/reuse-tab/reuse-tab.module.mjs +50 -0
  71. package/esm2022/reuse-tab/reuse-tab.service.mjs +559 -0
  72. package/esm2022/se/se-container.component.mjs +174 -0
  73. package/esm2022/se/se.component.mjs +235 -0
  74. package/esm2022/se/se.module.mjs +24 -0
  75. package/esm2022/sg/sg-container.component.mjs +53 -0
  76. package/esm2022/sg/sg.component.mjs +68 -0
  77. package/esm2022/sg/sg.module.mjs +21 -0
  78. package/esm2022/st/st-column-source.mjs +493 -0
  79. package/esm2022/st/st-data-source.mjs +480 -0
  80. package/esm2022/st/st-export.mjs +90 -0
  81. package/{esm2020 → esm2022}/st/st-filter.component.mjs +8 -7
  82. package/esm2022/st/st-row.directive.mjs +47 -0
  83. package/esm2022/st/st-widget-host.directive.mjs +32 -0
  84. package/esm2022/st/st-widget.mjs +27 -0
  85. package/esm2022/st/st.component.mjs +1004 -0
  86. package/esm2022/st/st.module.mjs +97 -0
  87. package/esm2022/sv/sv-container.component.mjs +127 -0
  88. package/esm2022/sv/sv-value.component.mjs +45 -0
  89. package/esm2022/sv/sv.component.mjs +120 -0
  90. package/esm2022/sv/sv.module.mjs +26 -0
  91. package/esm2022/tag-select/tag-select.component.mjs +64 -0
  92. package/esm2022/tag-select/tag-select.module.mjs +22 -0
  93. package/esm2022/xlsx/xlsx.directive.mjs +28 -0
  94. package/esm2022/xlsx/xlsx.module.mjs +20 -0
  95. package/esm2022/xlsx/xlsx.service.mjs +129 -0
  96. package/esm2022/zip/zip.module.mjs +16 -0
  97. package/esm2022/zip/zip.service.mjs +117 -0
  98. package/exception/exception.component.d.ts +1 -1
  99. package/{fesm2015 → fesm2022}/auto-focus.mjs +7 -7
  100. package/{fesm2015 → fesm2022}/auto-focus.mjs.map +1 -1
  101. package/{fesm2020 → fesm2022}/avatar-list.mjs +10 -10
  102. package/fesm2022/avatar-list.mjs.map +1 -0
  103. package/{fesm2020 → fesm2022}/chart-observer-size.mjs +10 -10
  104. package/fesm2022/chart-observer-size.mjs.map +1 -0
  105. package/{fesm2020 → fesm2022}/count-down.mjs +7 -7
  106. package/fesm2022/count-down.mjs.map +1 -0
  107. package/{fesm2020 → fesm2022}/date-picker.mjs +14 -13
  108. package/fesm2022/date-picker.mjs.map +1 -0
  109. package/{fesm2020 → fesm2022}/down-file.mjs +8 -8
  110. package/fesm2022/down-file.mjs.map +1 -0
  111. package/{fesm2020 → fesm2022}/ellipsis.mjs +7 -7
  112. package/fesm2022/ellipsis.mjs.map +1 -0
  113. package/{fesm2020 → fesm2022}/error-collect.mjs +9 -9
  114. package/fesm2022/error-collect.mjs.map +1 -0
  115. package/{fesm2020 → fesm2022}/exception.mjs +7 -7
  116. package/fesm2022/exception.mjs.map +1 -0
  117. package/{fesm2020 → fesm2022}/footer-toolbar.mjs +7 -7
  118. package/fesm2022/footer-toolbar.mjs.map +1 -0
  119. package/{fesm2020 → fesm2022}/full-content.mjs +13 -13
  120. package/fesm2022/full-content.mjs.map +1 -0
  121. package/{fesm2020 → fesm2022}/global-footer.mjs +10 -10
  122. package/fesm2022/global-footer.mjs.map +1 -0
  123. package/{fesm2020 → fesm2022}/hotkey.mjs +7 -7
  124. package/{fesm2015 → fesm2022}/hotkey.mjs.map +1 -1
  125. package/{fesm2020 → fesm2022}/let.mjs +9 -8
  126. package/fesm2022/let.mjs.map +1 -0
  127. package/{fesm2020 → fesm2022}/loading.mjs +10 -11
  128. package/fesm2022/loading.mjs.map +1 -0
  129. package/{fesm2020 → fesm2022}/lodop.mjs +7 -7
  130. package/{fesm2020 → fesm2022}/lodop.mjs.map +1 -1
  131. package/{fesm2020 → fesm2022}/media.mjs +10 -10
  132. package/fesm2022/media.mjs.map +1 -0
  133. package/fesm2022/notice-icon.mjs +180 -0
  134. package/fesm2022/notice-icon.mjs.map +1 -0
  135. package/{fesm2020 → fesm2022}/onboarding.mjs +10 -11
  136. package/{fesm2020 → fesm2022}/onboarding.mjs.map +1 -1
  137. package/{fesm2020 → fesm2022}/page-header.mjs +7 -7
  138. package/{fesm2015 → fesm2022}/page-header.mjs.map +1 -1
  139. package/{fesm2020 → fesm2022}/pdf.mjs +9 -9
  140. package/{fesm2020 → fesm2022}/pdf.mjs.map +1 -1
  141. package/{fesm2015 → fesm2022}/qr.mjs +7 -7
  142. package/{fesm2020 → fesm2022}/qr.mjs.map +1 -1
  143. package/{fesm2020 → fesm2022}/quick-menu.mjs +7 -7
  144. package/fesm2022/quick-menu.mjs.map +1 -0
  145. package/{fesm2020 → fesm2022}/result.mjs +7 -7
  146. package/{fesm2020 → fesm2022}/result.mjs.map +1 -1
  147. package/{fesm2020 → fesm2022}/reuse-tab.mjs +31 -31
  148. package/{fesm2015 → fesm2022}/reuse-tab.mjs.map +1 -1
  149. package/{fesm2020 → fesm2022}/se.mjs +15 -15
  150. package/fesm2022/se.mjs.map +1 -0
  151. package/{fesm2020 → fesm2022}/sg.mjs +10 -10
  152. package/fesm2022/sg.mjs.map +1 -0
  153. package/{fesm2020 → fesm2022}/st.mjs +72 -72
  154. package/fesm2022/st.mjs.map +1 -0
  155. package/{fesm2020 → fesm2022}/sv.mjs +20 -20
  156. package/fesm2022/sv.mjs.map +1 -0
  157. package/{fesm2020 → fesm2022}/tag-select.mjs +7 -7
  158. package/fesm2022/tag-select.mjs.map +1 -0
  159. package/{fesm2020 → fesm2022}/xlsx.mjs +10 -10
  160. package/fesm2022/xlsx.mjs.map +1 -0
  161. package/{fesm2020 → fesm2022}/zip.mjs +7 -7
  162. package/{fesm2015 → fesm2022}/zip.mjs.map +1 -1
  163. package/footer-toolbar/footer-toolbar.component.d.ts +1 -1
  164. package/full-content/full-content.component.d.ts +1 -1
  165. package/global-footer/global-footer-item.component.d.ts +1 -1
  166. package/global-footer/global-footer.component.d.ts +1 -1
  167. package/hotkey/hotkey.directive.d.ts +1 -1
  168. package/let/let.directive.d.ts +1 -1
  169. package/loading/style/index.less +1 -4
  170. package/media/media.component.d.ts +1 -1
  171. package/notice-icon/notice-icon-tab.component.d.ts +1 -1
  172. package/notice-icon/notice-icon.component.d.ts +1 -1
  173. package/onboarding/style/index.less +1 -4
  174. package/package.json +105 -175
  175. package/page-header/page-header.component.d.ts +1 -1
  176. package/pdf/pdf.component.d.ts +1 -1
  177. package/qr/qr.component.d.ts +1 -1
  178. package/quick-menu/quick-menu.component.d.ts +1 -1
  179. package/result/result.component.d.ts +1 -1
  180. package/reuse-tab/reuse-tab-context-menu.component.d.ts +1 -1
  181. package/reuse-tab/reuse-tab-context.component.d.ts +1 -1
  182. package/reuse-tab/reuse-tab-context.directive.d.ts +1 -1
  183. package/reuse-tab/reuse-tab.component.d.ts +1 -1
  184. package/se/se-container.component.d.ts +1 -1
  185. package/se/se.component.d.ts +1 -1
  186. package/sg/sg-container.component.d.ts +1 -1
  187. package/sg/sg.component.d.ts +1 -1
  188. package/st/st-filter.component.d.ts +1 -1
  189. package/st/st-row.directive.d.ts +1 -1
  190. package/st/st-widget-host.directive.d.ts +1 -1
  191. package/st/st.component.d.ts +9 -5
  192. package/st/style/index.less +6 -2
  193. package/sv/sv-container.component.d.ts +1 -1
  194. package/sv/sv-value.component.d.ts +1 -1
  195. package/sv/sv.component.d.ts +1 -1
  196. package/tag-select/tag-select.component.d.ts +1 -1
  197. package/xlsx/xlsx.directive.d.ts +1 -1
  198. package/esm2020/auto-focus/auto-focus.directive.mjs +0 -50
  199. package/esm2020/auto-focus/auto-focus.module.mjs +0 -17
  200. package/esm2020/avatar-list/avatar-list-item.component.mjs +0 -26
  201. package/esm2020/avatar-list/avatar-list.component.mjs +0 -88
  202. package/esm2020/avatar-list/avatar-list.module.mjs +0 -22
  203. package/esm2020/count-down/count-down.component.mjs +0 -45
  204. package/esm2020/count-down/count-down.module.mjs +0 -20
  205. package/esm2020/date-picker/date-picker.module.mjs +0 -22
  206. package/esm2020/date-picker/range-shortcut.component.mjs +0 -40
  207. package/esm2020/date-picker/range.directive.mjs +0 -172
  208. package/esm2020/down-file/down-file.directive.mjs +0 -114
  209. package/esm2020/down-file/down-file.module.mjs +0 -20
  210. package/esm2020/ellipsis/ellipsis.component.mjs +0 -232
  211. package/esm2020/ellipsis/ellipsis.module.mjs +0 -21
  212. package/esm2020/error-collect/error-collect.component.mjs +0 -121
  213. package/esm2020/error-collect/error-collect.module.mjs +0 -20
  214. package/esm2020/exception/exception.component.mjs +0 -108
  215. package/esm2020/exception/exception.module.mjs +0 -23
  216. package/esm2020/footer-toolbar/footer-toolbar.component.mjs +0 -44
  217. package/esm2020/footer-toolbar/footer-toolbar.module.mjs +0 -21
  218. package/esm2020/full-content/full-content-toggle.directive.mjs +0 -24
  219. package/esm2020/full-content/full-content.component.mjs +0 -139
  220. package/esm2020/full-content/full-content.module.mjs +0 -20
  221. package/esm2020/full-content/full-content.service.mjs +0 -22
  222. package/esm2020/global-footer/global-footer-item.component.mjs +0 -30
  223. package/esm2020/global-footer/global-footer.component.mjs +0 -72
  224. package/esm2020/global-footer/global-footer.module.mjs +0 -21
  225. package/esm2020/hotkey/hotkey.directive.mjs +0 -36
  226. package/esm2020/hotkey/hotkey.module.mjs +0 -17
  227. package/esm2020/let/let.directive.mjs +0 -36
  228. package/esm2020/let/let.module.mjs +0 -17
  229. package/esm2020/loading/loading.component.mjs +0 -26
  230. package/esm2020/loading/loading.module.mjs +0 -24
  231. package/esm2020/loading/loading.service.mjs +0 -90
  232. package/esm2020/lodop/lodop.module.mjs +0 -12
  233. package/esm2020/lodop/lodop.service.mjs +0 -222
  234. package/esm2020/media/media.component.mjs +0 -117
  235. package/esm2020/media/media.module.mjs +0 -19
  236. package/esm2020/media/media.service.mjs +0 -46
  237. package/esm2020/notice-icon/notice-icon-tab.component.mjs +0 -34
  238. package/esm2020/notice-icon/notice-icon.component.mjs +0 -89
  239. package/esm2020/notice-icon/notice-icon.module.mjs +0 -58
  240. package/esm2020/observers/observer-size.mjs +0 -116
  241. package/esm2020/onboarding/onboarding.component.mjs +0 -134
  242. package/esm2020/onboarding/onboarding.module.mjs +0 -27
  243. package/esm2020/onboarding/onboarding.service.mjs +0 -185
  244. package/esm2020/page-header/page-header.component.mjs +0 -246
  245. package/esm2020/page-header/page-header.module.mjs +0 -24
  246. package/esm2020/pdf/pdf.component.mjs +0 -473
  247. package/esm2020/pdf/pdf.module.mjs +0 -20
  248. package/esm2020/qr/qr.component.mjs +0 -136
  249. package/esm2020/qr/qr.module.mjs +0 -19
  250. package/esm2020/quick-menu/quick-menu.component.mjs +0 -89
  251. package/esm2020/quick-menu/quick-menu.module.mjs +0 -21
  252. package/esm2020/result/result.component.mjs +0 -60
  253. package/esm2020/result/result.module.mjs +0 -21
  254. package/esm2020/reuse-tab/reuse-tab-context-menu.component.mjs +0 -76
  255. package/esm2020/reuse-tab/reuse-tab-context.component.mjs +0 -33
  256. package/esm2020/reuse-tab/reuse-tab-context.directive.mjs +0 -35
  257. package/esm2020/reuse-tab/reuse-tab-context.service.mjs +0 -55
  258. package/esm2020/reuse-tab/reuse-tab.component.mjs +0 -367
  259. package/esm2020/reuse-tab/reuse-tab.module.mjs +0 -49
  260. package/esm2020/reuse-tab/reuse-tab.service.mjs +0 -558
  261. package/esm2020/se/se-container.component.mjs +0 -172
  262. package/esm2020/se/se.component.mjs +0 -234
  263. package/esm2020/se/se.module.mjs +0 -23
  264. package/esm2020/sg/sg-container.component.mjs +0 -52
  265. package/esm2020/sg/sg.component.mjs +0 -67
  266. package/esm2020/sg/sg.module.mjs +0 -20
  267. package/esm2020/st/st-column-source.mjs +0 -492
  268. package/esm2020/st/st-data-source.mjs +0 -479
  269. package/esm2020/st/st-export.mjs +0 -89
  270. package/esm2020/st/st-row.directive.mjs +0 -45
  271. package/esm2020/st/st-widget-host.directive.mjs +0 -31
  272. package/esm2020/st/st-widget.mjs +0 -26
  273. package/esm2020/st/st.component.mjs +0 -1002
  274. package/esm2020/st/st.module.mjs +0 -96
  275. package/esm2020/sv/sv-container.component.mjs +0 -125
  276. package/esm2020/sv/sv-value.component.mjs +0 -44
  277. package/esm2020/sv/sv.component.mjs +0 -119
  278. package/esm2020/sv/sv.module.mjs +0 -25
  279. package/esm2020/tag-select/tag-select.component.mjs +0 -63
  280. package/esm2020/tag-select/tag-select.module.mjs +0 -21
  281. package/esm2020/xlsx/xlsx.directive.mjs +0 -27
  282. package/esm2020/xlsx/xlsx.module.mjs +0 -19
  283. package/esm2020/xlsx/xlsx.service.mjs +0 -128
  284. package/esm2020/zip/zip.module.mjs +0 -15
  285. package/esm2020/zip/zip.service.mjs +0 -116
  286. package/fesm2015/avatar-list.mjs +0 -139
  287. package/fesm2015/avatar-list.mjs.map +0 -1
  288. package/fesm2015/chart-observer-size.mjs +0 -124
  289. package/fesm2015/chart-observer-size.mjs.map +0 -1
  290. package/fesm2015/count-down.mjs +0 -69
  291. package/fesm2015/count-down.mjs.map +0 -1
  292. package/fesm2015/date-picker.mjs +0 -236
  293. package/fesm2015/date-picker.mjs.map +0 -1
  294. package/fesm2015/down-file.mjs +0 -141
  295. package/fesm2015/down-file.mjs.map +0 -1
  296. package/fesm2015/ellipsis.mjs +0 -258
  297. package/fesm2015/ellipsis.mjs.map +0 -1
  298. package/fesm2015/error-collect.mjs +0 -147
  299. package/fesm2015/error-collect.mjs.map +0 -1
  300. package/fesm2015/exception.mjs +0 -138
  301. package/fesm2015/exception.mjs.map +0 -1
  302. package/fesm2015/footer-toolbar.mjs +0 -70
  303. package/fesm2015/footer-toolbar.mjs.map +0 -1
  304. package/fesm2015/full-content.mjs +0 -202
  305. package/fesm2015/full-content.mjs.map +0 -1
  306. package/fesm2015/global-footer.mjs +0 -126
  307. package/fesm2015/global-footer.mjs.map +0 -1
  308. package/fesm2015/hotkey.mjs +0 -57
  309. package/fesm2015/let.mjs +0 -59
  310. package/fesm2015/let.mjs.map +0 -1
  311. package/fesm2015/loading.mjs +0 -142
  312. package/fesm2015/loading.mjs.map +0 -1
  313. package/fesm2015/lodop.mjs +0 -232
  314. package/fesm2015/lodop.mjs.map +0 -1
  315. package/fesm2015/media.mjs +0 -180
  316. package/fesm2015/media.mjs.map +0 -1
  317. package/fesm2015/notice-icon.mjs +0 -180
  318. package/fesm2015/notice-icon.mjs.map +0 -1
  319. package/fesm2015/onboarding.mjs +0 -336
  320. package/fesm2015/onboarding.mjs.map +0 -1
  321. package/fesm2015/page-header.mjs +0 -276
  322. package/fesm2015/pdf.mjs +0 -516
  323. package/fesm2015/pdf.mjs.map +0 -1
  324. package/fesm2015/qr.mjs.map +0 -1
  325. package/fesm2015/quick-menu.mjs +0 -114
  326. package/fesm2015/quick-menu.mjs.map +0 -1
  327. package/fesm2015/result.mjs +0 -88
  328. package/fesm2015/result.mjs.map +0 -1
  329. package/fesm2015/reuse-tab.mjs +0 -1217
  330. package/fesm2015/se.mjs +0 -444
  331. package/fesm2015/se.mjs.map +0 -1
  332. package/fesm2015/sg.mjs +0 -139
  333. package/fesm2015/sg.mjs.map +0 -1
  334. package/fesm2015/st.mjs +0 -2526
  335. package/fesm2015/st.mjs.map +0 -1
  336. package/fesm2015/sv.mjs +0 -308
  337. package/fesm2015/sv.mjs.map +0 -1
  338. package/fesm2015/tag-select.mjs +0 -91
  339. package/fesm2015/tag-select.mjs.map +0 -1
  340. package/fesm2015/xlsx.mjs +0 -172
  341. package/fesm2015/xlsx.mjs.map +0 -1
  342. package/fesm2015/zip.mjs +0 -136
  343. package/fesm2020/abc.mjs +0 -7
  344. package/fesm2020/abc.mjs.map +0 -1
  345. package/fesm2020/auto-focus.mjs +0 -71
  346. package/fesm2020/auto-focus.mjs.map +0 -1
  347. package/fesm2020/avatar-list.mjs.map +0 -1
  348. package/fesm2020/chart-observer-size.mjs.map +0 -1
  349. package/fesm2020/count-down.mjs.map +0 -1
  350. package/fesm2020/date-picker.mjs.map +0 -1
  351. package/fesm2020/down-file.mjs.map +0 -1
  352. package/fesm2020/ellipsis.mjs.map +0 -1
  353. package/fesm2020/error-collect.mjs.map +0 -1
  354. package/fesm2020/exception.mjs.map +0 -1
  355. package/fesm2020/footer-toolbar.mjs.map +0 -1
  356. package/fesm2020/full-content.mjs.map +0 -1
  357. package/fesm2020/global-footer.mjs.map +0 -1
  358. package/fesm2020/hotkey.mjs.map +0 -1
  359. package/fesm2020/let.mjs.map +0 -1
  360. package/fesm2020/loading.mjs.map +0 -1
  361. package/fesm2020/media.mjs.map +0 -1
  362. package/fesm2020/notice-icon.mjs +0 -180
  363. package/fesm2020/notice-icon.mjs.map +0 -1
  364. package/fesm2020/page-header.mjs.map +0 -1
  365. package/fesm2020/qr.mjs +0 -171
  366. package/fesm2020/quick-menu.mjs.map +0 -1
  367. package/fesm2020/reuse-tab.mjs.map +0 -1
  368. package/fesm2020/se.mjs.map +0 -1
  369. package/fesm2020/sg.mjs.map +0 -1
  370. package/fesm2020/st.mjs.map +0 -1
  371. package/fesm2020/sv.mjs.map +0 -1
  372. package/fesm2020/tag-select.mjs.map +0 -1
  373. package/fesm2020/xlsx.mjs.map +0 -1
  374. package/fesm2020/zip.mjs.map +0 -1
  375. /package/{esm2020 → esm2022}/abc.mjs +0 -0
  376. /package/{esm2020 → esm2022}/auto-focus/auto-focus.mjs +0 -0
  377. /package/{esm2020 → esm2022}/auto-focus/index.mjs +0 -0
  378. /package/{esm2020 → esm2022}/avatar-list/avatar-list.mjs +0 -0
  379. /package/{esm2020 → esm2022}/avatar-list/public_api.mjs +0 -0
  380. /package/{esm2020 → esm2022}/count-down/count-down.mjs +0 -0
  381. /package/{esm2020 → esm2022}/count-down/public_api.mjs +0 -0
  382. /package/{esm2020 → esm2022}/date-picker/date-picker.mjs +0 -0
  383. /package/{esm2020 → esm2022}/date-picker/public_api.mjs +0 -0
  384. /package/{esm2020 → esm2022}/down-file/down-file.mjs +0 -0
  385. /package/{esm2020 → esm2022}/down-file/public_api.mjs +0 -0
  386. /package/{esm2020 → esm2022}/ellipsis/ellipsis.mjs +0 -0
  387. /package/{esm2020 → esm2022}/ellipsis/public_api.mjs +0 -0
  388. /package/{esm2020 → esm2022}/error-collect/error-collect.mjs +0 -0
  389. /package/{esm2020 → esm2022}/error-collect/public_api.mjs +0 -0
  390. /package/{esm2020 → esm2022}/exception/exception.mjs +0 -0
  391. /package/{esm2020 → esm2022}/exception/public_api.mjs +0 -0
  392. /package/{esm2020 → esm2022}/footer-toolbar/footer-toolbar.mjs +0 -0
  393. /package/{esm2020 → esm2022}/footer-toolbar/public_api.mjs +0 -0
  394. /package/{esm2020 → esm2022}/full-content/full-content.mjs +0 -0
  395. /package/{esm2020 → esm2022}/full-content/public_api.mjs +0 -0
  396. /package/{esm2020 → esm2022}/global-footer/global-footer.mjs +0 -0
  397. /package/{esm2020 → esm2022}/global-footer/global-footer.types.mjs +0 -0
  398. /package/{esm2020 → esm2022}/global-footer/public_api.mjs +0 -0
  399. /package/{esm2020 → esm2022}/hotkey/hotkey.mjs +0 -0
  400. /package/{esm2020 → esm2022}/hotkey/public_api.mjs +0 -0
  401. /package/{esm2020 → esm2022}/let/index.mjs +0 -0
  402. /package/{esm2020 → esm2022}/let/let.mjs +0 -0
  403. /package/{esm2020 → esm2022}/loading/loading.mjs +0 -0
  404. /package/{esm2020 → esm2022}/loading/loading.types.mjs +0 -0
  405. /package/{esm2020 → esm2022}/loading/public_api.mjs +0 -0
  406. /package/{esm2020 → esm2022}/lodop/lodop.mjs +0 -0
  407. /package/{esm2020 → esm2022}/lodop/lodop.types.mjs +0 -0
  408. /package/{esm2020 → esm2022}/lodop/public_api.mjs +0 -0
  409. /package/{esm2020 → esm2022}/media/media.mjs +0 -0
  410. /package/{esm2020 → esm2022}/media/public_api.mjs +0 -0
  411. /package/{esm2020 → esm2022}/notice-icon/notice-icon.mjs +0 -0
  412. /package/{esm2020 → esm2022}/notice-icon/notice-icon.types.mjs +0 -0
  413. /package/{esm2020 → esm2022}/notice-icon/public_api.mjs +0 -0
  414. /package/{esm2020 → esm2022}/observers/chart-observer-size.mjs +0 -0
  415. /package/{esm2020 → esm2022}/observers/public-api.mjs +0 -0
  416. /package/{esm2020 → esm2022}/onboarding/onboarding.mjs +0 -0
  417. /package/{esm2020 → esm2022}/onboarding/onboarding.types.mjs +0 -0
  418. /package/{esm2020 → esm2022}/onboarding/public_api.mjs +0 -0
  419. /package/{esm2020 → esm2022}/page-header/page-header.mjs +0 -0
  420. /package/{esm2020 → esm2022}/page-header/public_api.mjs +0 -0
  421. /package/{esm2020 → esm2022}/pdf/pdf.config.mjs +0 -0
  422. /package/{esm2020 → esm2022}/pdf/pdf.mjs +0 -0
  423. /package/{esm2020 → esm2022}/pdf/pdf.types.mjs +0 -0
  424. /package/{esm2020 → esm2022}/pdf/public_api.mjs +0 -0
  425. /package/{esm2020 → esm2022}/public_api.mjs +0 -0
  426. /package/{esm2020 → esm2022}/qr/public_api.mjs +0 -0
  427. /package/{esm2020 → esm2022}/qr/qr.config.mjs +0 -0
  428. /package/{esm2020 → esm2022}/qr/qr.mjs +0 -0
  429. /package/{esm2020 → esm2022}/qr/qr.types.mjs +0 -0
  430. /package/{esm2020 → esm2022}/quick-menu/public_api.mjs +0 -0
  431. /package/{esm2020 → esm2022}/quick-menu/quick-menu.mjs +0 -0
  432. /package/{esm2020 → esm2022}/result/public_api.mjs +0 -0
  433. /package/{esm2020 → esm2022}/result/result.mjs +0 -0
  434. /package/{esm2020 → esm2022}/reuse-tab/lifecycle_hooks.mjs +0 -0
  435. /package/{esm2020 → esm2022}/reuse-tab/public_api.mjs +0 -0
  436. /package/{esm2020 → esm2022}/reuse-tab/reuse-tab.interfaces.mjs +0 -0
  437. /package/{esm2020 → esm2022}/reuse-tab/reuse-tab.mjs +0 -0
  438. /package/{esm2020 → esm2022}/reuse-tab/reuse-tab.state.mjs +0 -0
  439. /package/{esm2020 → esm2022}/reuse-tab/reuse-tab.strategy.mjs +0 -0
  440. /package/{esm2020 → esm2022}/se/public_api.mjs +0 -0
  441. /package/{esm2020 → esm2022}/se/se.mjs +0 -0
  442. /package/{esm2020 → esm2022}/se/se.types.mjs +0 -0
  443. /package/{esm2020 → esm2022}/sg/public_api.mjs +0 -0
  444. /package/{esm2020 → esm2022}/sg/sg.mjs +0 -0
  445. /package/{esm2020 → esm2022}/st/public_api.mjs +0 -0
  446. /package/{esm2020 → esm2022}/st/st.config.mjs +0 -0
  447. /package/{esm2020 → esm2022}/st/st.interfaces.mjs +0 -0
  448. /package/{esm2020 → esm2022}/st/st.mjs +0 -0
  449. /package/{esm2020 → esm2022}/st/st.types.mjs +0 -0
  450. /package/{esm2020 → esm2022}/sv/public_api.mjs +0 -0
  451. /package/{esm2020 → esm2022}/sv/sv.mjs +0 -0
  452. /package/{esm2020 → esm2022}/tag-select/public_api.mjs +0 -0
  453. /package/{esm2020 → esm2022}/tag-select/tag-select.mjs +0 -0
  454. /package/{esm2020 → esm2022}/xlsx/public_api.mjs +0 -0
  455. /package/{esm2020 → esm2022}/xlsx/xlsx.mjs +0 -0
  456. /package/{esm2020 → esm2022}/xlsx/xlsx.types.mjs +0 -0
  457. /package/{esm2020 → esm2022}/zip/public_api.mjs +0 -0
  458. /package/{esm2020 → esm2022}/zip/zip.mjs +0 -0
  459. /package/{esm2020 → esm2022}/zip/zip.types.mjs +0 -0
  460. /package/{fesm2015 → fesm2022}/abc.mjs +0 -0
  461. /package/{fesm2015 → fesm2022}/abc.mjs.map +0 -0
@@ -0,0 +1,174 @@
1
+ import { Directive, EventEmitter, Host, Input, Optional, Output } from '@angular/core';
2
+ import { Subject } from 'rxjs';
3
+ import { fixEndTimeOfRange, getTimeDistance } from '@delon/util/date-time';
4
+ import { assert, deepMergeKey } from '@delon/util/other';
5
+ import { RangePickerShortcutTplComponent } from './range-shortcut.component';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/platform-browser";
8
+ import * as i2 from "@delon/util/config";
9
+ import * as i3 from "ng-zorro-antd/date-picker";
10
+ class RangePickerDirective {
11
+ set shortcut(val) {
12
+ const item = deepMergeKey({ list: [] }, true, this.defaultShortcuts, val == null ? {} : val);
13
+ if (typeof val !== 'object') {
14
+ item.enabled = val !== false;
15
+ }
16
+ (item.list || []).forEach(i => {
17
+ i._text = this.dom.bypassSecurityTrustHtml(i.text);
18
+ });
19
+ this._shortcut = item;
20
+ this.refreshShortcut();
21
+ }
22
+ get shortcut() {
23
+ return this._shortcut;
24
+ }
25
+ get dp() {
26
+ return this.nativeComp.datePicker;
27
+ }
28
+ get srv() {
29
+ return this.dp.datePickerService;
30
+ }
31
+ constructor(dom, configSrv, nativeComp, vcr) {
32
+ this.dom = dom;
33
+ this.nativeComp = nativeComp;
34
+ this.vcr = vcr;
35
+ this._shortcut = null;
36
+ this.destroy$ = new Subject();
37
+ this.shortcutFactory = null;
38
+ this.start = null;
39
+ this.end = null;
40
+ this.ngModelEndChange = new EventEmitter();
41
+ assert(!!nativeComp, `It should be attached to nz-range-picker component, for example: '<nz-range-picker [(ngModel)]="i.start" extend [(ngModelEnd)]="i.end" shortcut></nz-range-picker>'`);
42
+ const cog = configSrv.merge('dataRange', {
43
+ nzFormat: 'yyyy-MM-dd',
44
+ nzAllowClear: true,
45
+ nzAutoFocus: false,
46
+ nzPopupStyle: { position: 'relative' },
47
+ nzShowToday: true,
48
+ shortcuts: {
49
+ enabled: false,
50
+ closed: true,
51
+ list: [
52
+ {
53
+ text: '今天',
54
+ fn: () => getTimeDistance('today')
55
+ },
56
+ {
57
+ text: '昨天',
58
+ fn: () => getTimeDistance('yesterday')
59
+ },
60
+ {
61
+ text: '近3天',
62
+ fn: () => getTimeDistance(-2)
63
+ },
64
+ {
65
+ text: '近7天',
66
+ fn: () => getTimeDistance(-6)
67
+ },
68
+ {
69
+ text: '本周',
70
+ fn: () => getTimeDistance('week')
71
+ },
72
+ {
73
+ text: '本月',
74
+ fn: () => getTimeDistance('month')
75
+ },
76
+ {
77
+ text: '全年',
78
+ fn: () => getTimeDistance('year')
79
+ }
80
+ ]
81
+ }
82
+ });
83
+ this.defaultShortcuts = { ...cog.shortcuts };
84
+ Object.assign(this, cog);
85
+ }
86
+ cd() {
87
+ this.dp.cdr.markForCheck();
88
+ }
89
+ overrideNative() {
90
+ const dp = this.dp;
91
+ dp.writeValue = (value) => {
92
+ const dates = (value && this.ngModelEnd ? [value, this.ngModelEnd] : []).filter(w => !!w);
93
+ this.srv.setValue(this.srv.makeValue(dates));
94
+ this.start = dates.length > 0 ? dates[0] : null;
95
+ this.end = dates.length > 0 ? dates[1] : null;
96
+ this.cd();
97
+ };
98
+ const oldOnChangeFn = dp.onChangeFn;
99
+ dp.onChangeFn = (list) => {
100
+ let start = null;
101
+ let end = null;
102
+ if (list.length > 0 && list.filter(w => w != null).length === 2) {
103
+ [start, end] = fixEndTimeOfRange([list[0], list[1]]);
104
+ }
105
+ this.start = start;
106
+ this.end = end;
107
+ oldOnChangeFn(start);
108
+ this.ngModelEnd = end;
109
+ this.ngModelEndChange.emit(end);
110
+ };
111
+ }
112
+ refreshShortcut() {
113
+ if (!this._shortcut) {
114
+ return;
115
+ }
116
+ const { enabled, list } = this._shortcut;
117
+ let extraFooter;
118
+ if (!this.nativeComp || !enabled) {
119
+ extraFooter = undefined;
120
+ }
121
+ else {
122
+ if (!this.shortcutFactory) {
123
+ this.shortcutFactory = this.vcr.createComponent(RangePickerShortcutTplComponent);
124
+ }
125
+ const { instance } = this.shortcutFactory;
126
+ instance.list = list;
127
+ instance.click = (item) => {
128
+ const res = item.fn([this.start, this.end]);
129
+ this.srv.setValue(this.srv.makeValue(res));
130
+ this.dp.onChangeFn(res);
131
+ this.dp.close();
132
+ };
133
+ extraFooter = instance.tpl;
134
+ }
135
+ this.nativeComp.datePicker.extraFooter = extraFooter;
136
+ Promise.resolve().then(() => this.cd());
137
+ }
138
+ ngAfterViewInit() {
139
+ this.overrideNative();
140
+ this.refreshShortcut();
141
+ }
142
+ destoryShortcut() {
143
+ if (this.shortcutFactory != null) {
144
+ this.shortcutFactory.destroy();
145
+ }
146
+ }
147
+ ngOnDestroy() {
148
+ this.destoryShortcut();
149
+ this.destroy$.next();
150
+ this.destroy$.complete();
151
+ }
152
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: RangePickerDirective, deps: [{ token: i1.DomSanitizer }, { token: i2.AlainConfigService }, { token: i3.NzRangePickerComponent, host: true, optional: true }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive }); }
153
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.4", type: RangePickerDirective, selector: "nz-range-picker[extend]", inputs: { shortcut: "shortcut", ngModelEnd: "ngModelEnd" }, outputs: { ngModelEndChange: "ngModelEndChange" }, exportAs: ["extendRangePicker"], ngImport: i0 }); }
154
+ }
155
+ export { RangePickerDirective };
156
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: RangePickerDirective, decorators: [{
157
+ type: Directive,
158
+ args: [{
159
+ selector: 'nz-range-picker[extend]',
160
+ exportAs: 'extendRangePicker'
161
+ }]
162
+ }], ctorParameters: function () { return [{ type: i1.DomSanitizer }, { type: i2.AlainConfigService }, { type: i3.NzRangePickerComponent, decorators: [{
163
+ type: Host
164
+ }, {
165
+ type: Optional
166
+ }] }, { type: i0.ViewContainerRef }]; }, propDecorators: { shortcut: [{
167
+ type: Input
168
+ }], ngModelEnd: [{
169
+ type: Input,
170
+ args: [{ required: true }]
171
+ }], ngModelEndChange: [{
172
+ type: Output
173
+ }] } });
174
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range.directive.js","sourceRoot":"","sources":["../../../../../packages/abc/date-picker/range.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ComponentRef,\n  Directive,\n  EventEmitter,\n  Host,\n  Input,\n  OnDestroy,\n  Optional,\n  Output,\n  TemplateRef,\n  ViewContainerRef\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { Subject } from 'rxjs';\n\nimport { AlainConfigService, AlainDateRangePickerShortcut, AlainDateRangePickerShortcutItem } from '@delon/util/config';\nimport { fixEndTimeOfRange, getTimeDistance } from '@delon/util/date-time';\nimport { assert, deepMergeKey } from '@delon/util/other';\nimport type { NzSafeAny } from 'ng-zorro-antd/core/types';\nimport { NzDatePickerComponent, NzRangePickerComponent } from 'ng-zorro-antd/date-picker';\nimport { DatePickerService } from 'ng-zorro-antd/date-picker/date-picker.service';\n\nimport { RangePickerShortcutTplComponent } from './range-shortcut.component';\n\n@Directive({\n  selector: 'nz-range-picker[extend]',\n  exportAs: 'extendRangePicker'\n})\nexport class RangePickerDirective implements OnDestroy, AfterViewInit {\n  static ngAcceptInputType_shortcut: AlainDateRangePickerShortcut | string | null;\n\n  private defaultShortcuts: AlainDateRangePickerShortcut;\n  private _shortcut: AlainDateRangePickerShortcut | null = null;\n  private destroy$ = new Subject<void>();\n  private shortcutFactory: ComponentRef<RangePickerShortcutTplComponent> | null = null;\n  start: Date | null = null;\n  end: Date | null = null;\n\n  @Input()\n  set shortcut(val: AlainDateRangePickerShortcut | null) {\n    const item = deepMergeKey(\n      { list: [] },\n      true,\n      this.defaultShortcuts,\n      val == null ? {} : val\n    ) as AlainDateRangePickerShortcut;\n    if (typeof val !== 'object') {\n      item.enabled = val !== false;\n    }\n    (item.list || []).forEach(i => {\n      i._text = this.dom.bypassSecurityTrustHtml(i.text);\n    });\n    this._shortcut = item;\n    this.refreshShortcut();\n  }\n  get shortcut(): AlainDateRangePickerShortcut | null {\n    return this._shortcut;\n  }\n  @Input({ required: true }) ngModelEnd: NzSafeAny;\n  @Output() readonly ngModelEndChange = new EventEmitter<NzSafeAny>();\n\n  private get dp(): NzDatePickerComponent {\n    return this.nativeComp.datePicker;\n  }\n\n  private get srv(): DatePickerService {\n    return this.dp.datePickerService;\n  }\n\n  constructor(\n    private dom: DomSanitizer,\n    configSrv: AlainConfigService,\n    @Host() @Optional() private nativeComp: NzRangePickerComponent,\n    private vcr: ViewContainerRef\n  ) {\n    assert(\n      !!nativeComp,\n      `It should be attached to nz-range-picker component, for example: '<nz-range-picker [(ngModel)]=\"i.start\" extend [(ngModelEnd)]=\"i.end\" shortcut></nz-range-picker>'`\n    );\n    const cog = configSrv.merge('dataRange', {\n      nzFormat: 'yyyy-MM-dd',\n      nzAllowClear: true,\n      nzAutoFocus: false,\n      nzPopupStyle: { position: 'relative' },\n      nzShowToday: true,\n      shortcuts: {\n        enabled: false,\n        closed: true,\n        list: [\n          {\n            text: '今天',\n            fn: () => getTimeDistance('today')\n          },\n          {\n            text: '昨天',\n            fn: () => getTimeDistance('yesterday')\n          },\n          {\n            text: '近3天',\n            fn: () => getTimeDistance(-2)\n          },\n          {\n            text: '近7天',\n            fn: () => getTimeDistance(-6)\n          },\n          {\n            text: '本周',\n            fn: () => getTimeDistance('week')\n          },\n          {\n            text: '本月',\n            fn: () => getTimeDistance('month')\n          },\n          {\n            text: '全年',\n            fn: () => getTimeDistance('year')\n          }\n        ]\n      }\n    })!;\n    this.defaultShortcuts = { ...cog.shortcuts } as AlainDateRangePickerShortcut;\n    Object.assign(this, cog);\n  }\n\n  private cd(): void {\n    (this.dp as NzSafeAny).cdr.markForCheck();\n  }\n\n  private overrideNative(): void {\n    const dp = this.dp;\n    dp.writeValue = (value: Date) => {\n      const dates = (value && this.ngModelEnd ? [value, this.ngModelEnd] : []).filter(w => !!w);\n      this.srv.setValue(this.srv.makeValue(dates));\n      this.start = dates.length > 0 ? dates[0] : null;\n      this.end = dates.length > 0 ? dates[1] : null;\n      this.cd();\n    };\n\n    const oldOnChangeFn = dp.onChangeFn;\n    dp.onChangeFn = (list: Array<Date | null>) => {\n      let start: Date | null = null;\n      let end: Date | null = null;\n      if (list.length > 0 && list.filter(w => w != null).length === 2) {\n        [start, end] = fixEndTimeOfRange([list[0]!, list[1]!]);\n      }\n      this.start = start;\n      this.end = end;\n      oldOnChangeFn(start);\n      this.ngModelEnd = end;\n      this.ngModelEndChange.emit(end);\n    };\n  }\n\n  private refreshShortcut(): void {\n    if (!this._shortcut) {\n      return;\n    }\n    const { enabled, list } = this._shortcut;\n    let extraFooter: TemplateRef<NzSafeAny> | undefined;\n    if (!this.nativeComp || !enabled) {\n      extraFooter = undefined;\n    } else {\n      if (!this.shortcutFactory) {\n        this.shortcutFactory = this.vcr.createComponent(RangePickerShortcutTplComponent);\n      }\n      const { instance } = this.shortcutFactory;\n      instance.list = list!;\n      instance.click = (item: AlainDateRangePickerShortcutItem) => {\n        const res = item.fn([this.start, this.end]);\n        this.srv.setValue(this.srv.makeValue(res as Date[]));\n        this.dp.onChangeFn(res);\n        this.dp.close();\n      };\n      extraFooter = instance.tpl;\n    }\n    this.nativeComp.datePicker.extraFooter = extraFooter;\n    Promise.resolve().then(() => this.cd());\n  }\n\n  ngAfterViewInit(): void {\n    this.overrideNative();\n    this.refreshShortcut();\n  }\n\n  private destoryShortcut(): void {\n    if (this.shortcutFactory != null) {\n      this.shortcutFactory.destroy();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destoryShortcut();\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n"]}
@@ -0,0 +1,115 @@
1
+ import { Directive, EventEmitter, Input, Output } from '@angular/core';
2
+ import { finalize } from 'rxjs';
3
+ import { saveAs } from 'file-saver';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@delon/theme";
6
+ class DownFileDirective {
7
+ getDisposition(data) {
8
+ const arr = (data || '')
9
+ .split(';')
10
+ .filter(i => i.includes('='))
11
+ .map(v => {
12
+ const strArr = v.split('=');
13
+ const utfId = `UTF-8''`;
14
+ let value = strArr[1];
15
+ if (value.startsWith(utfId))
16
+ value = value.substring(utfId.length);
17
+ return { [strArr[0].trim()]: value };
18
+ });
19
+ return arr.reduce((_o, item) => item, {});
20
+ }
21
+ constructor(el, _http) {
22
+ this.el = el;
23
+ this._http = _http;
24
+ this.isFileSaverSupported = true;
25
+ this.httpMethod = 'get';
26
+ this.success = new EventEmitter();
27
+ this.error = new EventEmitter();
28
+ let isFileSaverSupported = false;
29
+ try {
30
+ isFileSaverSupported = !!new Blob();
31
+ }
32
+ catch { }
33
+ this.isFileSaverSupported = isFileSaverSupported;
34
+ if (!isFileSaverSupported) {
35
+ el.nativeElement.classList.add(`down-file__not-support`);
36
+ }
37
+ }
38
+ setDisabled(status) {
39
+ const el = this.el.nativeElement;
40
+ el.disabled = status;
41
+ el.classList[status ? 'add' : 'remove'](`down-file__disabled`);
42
+ }
43
+ async _click(ev) {
44
+ if (!this.isFileSaverSupported || (typeof this.pre === 'function' && !(await this.pre(ev)))) {
45
+ ev.stopPropagation();
46
+ ev.preventDefault();
47
+ return;
48
+ }
49
+ this.setDisabled(true);
50
+ this._http
51
+ .request(this.httpMethod, this.httpUrl, {
52
+ params: this.httpData || {},
53
+ responseType: 'blob',
54
+ observe: 'response',
55
+ body: this.httpBody
56
+ })
57
+ .pipe(finalize(() => this.setDisabled(false)))
58
+ .subscribe({
59
+ next: (res) => {
60
+ if (res.status !== 200 || res.body.size <= 0) {
61
+ this.error.emit(res);
62
+ return;
63
+ }
64
+ const disposition = this.getDisposition(res.headers.get('content-disposition'));
65
+ let fileName = this.fileName;
66
+ if (typeof fileName === 'function')
67
+ fileName = fileName(res);
68
+ fileName =
69
+ fileName ||
70
+ disposition[`filename*`] ||
71
+ disposition[`filename`] ||
72
+ res.headers.get('filename') ||
73
+ res.headers.get('x-filename');
74
+ saveAs(res.body, decodeURI(fileName));
75
+ this.success.emit(res);
76
+ },
77
+ error: err => this.error.emit(err)
78
+ });
79
+ }
80
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: DownFileDirective, deps: [{ token: i0.ElementRef }, { token: i1._HttpClient }], target: i0.ɵɵFactoryTarget.Directive }); }
81
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.4", type: DownFileDirective, selector: "[down-file]", inputs: { httpData: ["http-data", "httpData"], httpBody: ["http-body", "httpBody"], httpMethod: ["http-method", "httpMethod"], httpUrl: ["http-url", "httpUrl"], fileName: ["file-name", "fileName"], pre: "pre" }, outputs: { success: "success", error: "error" }, host: { listeners: { "click": "_click($event)" } }, exportAs: ["downFile"], ngImport: i0 }); }
82
+ }
83
+ export { DownFileDirective };
84
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: DownFileDirective, decorators: [{
85
+ type: Directive,
86
+ args: [{
87
+ selector: '[down-file]',
88
+ exportAs: 'downFile',
89
+ host: {
90
+ '(click)': '_click($event)'
91
+ }
92
+ }]
93
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1._HttpClient }]; }, propDecorators: { httpData: [{
94
+ type: Input,
95
+ args: ['http-data']
96
+ }], httpBody: [{
97
+ type: Input,
98
+ args: ['http-body']
99
+ }], httpMethod: [{
100
+ type: Input,
101
+ args: ['http-method']
102
+ }], httpUrl: [{
103
+ type: Input,
104
+ args: [{ alias: 'http-url', required: true }]
105
+ }], fileName: [{
106
+ type: Input,
107
+ args: ['file-name']
108
+ }], pre: [{
109
+ type: Input
110
+ }], success: [{
111
+ type: Output
112
+ }], error: [{
113
+ type: Output
114
+ }] } });
115
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"down-file.directive.js","sourceRoot":"","sources":["../../../../../packages/abc/down-file/down-file.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpResponse } from '@angular/common/http';\nimport { Directive, ElementRef, EventEmitter, Input, Output } from '@angular/core';\nimport { finalize } from 'rxjs';\n\nimport { saveAs } from 'file-saver';\n\nimport { _HttpClient } from '@delon/theme';\nimport type { NzSafeAny } from 'ng-zorro-antd/core/types';\n\n@Directive({\n  selector: '[down-file]',\n  exportAs: 'downFile',\n  host: {\n    '(click)': '_click($event)'\n  }\n})\nexport class DownFileDirective {\n  private isFileSaverSupported = true;\n  @Input('http-data') httpData: NzSafeAny;\n  @Input('http-body') httpBody: NzSafeAny;\n  @Input('http-method') httpMethod: string = 'get';\n  @Input({ alias: 'http-url', required: true }) httpUrl!: string;\n  @Input('file-name') fileName?: string | ((rep: HttpResponse<Blob>) => string);\n  @Input() pre?: (ev: MouseEvent) => Promise<boolean>;\n  @Output() readonly success = new EventEmitter<HttpResponse<Blob>>();\n  @Output() readonly error = new EventEmitter<NzSafeAny>();\n\n  private getDisposition(data: string | null): NzSafeAny {\n    const arr: Array<Record<string, string>> = (data || '')\n      .split(';')\n      .filter(i => i.includes('='))\n      .map(v => {\n        const strArr = v.split('=');\n        const utfId = `UTF-8''`;\n        let value = strArr[1];\n        if (value.startsWith(utfId)) value = value.substring(utfId.length);\n        return { [strArr[0].trim()]: value };\n      });\n    return arr.reduce((_o, item) => item, {});\n  }\n\n  constructor(private el: ElementRef<HTMLButtonElement>, private _http: _HttpClient) {\n    let isFileSaverSupported = false;\n    try {\n      isFileSaverSupported = !!new Blob();\n    } catch {}\n    this.isFileSaverSupported = isFileSaverSupported;\n    if (!isFileSaverSupported) {\n      el.nativeElement.classList.add(`down-file__not-support`);\n    }\n  }\n\n  private setDisabled(status: boolean): void {\n    const el = this.el.nativeElement;\n    el.disabled = status;\n    el.classList[status ? 'add' : 'remove'](`down-file__disabled`);\n  }\n\n  async _click(ev: MouseEvent): Promise<void> {\n    if (!this.isFileSaverSupported || (typeof this.pre === 'function' && !(await this.pre(ev)))) {\n      ev.stopPropagation();\n      ev.preventDefault();\n      return;\n    }\n    this.setDisabled(true);\n    this._http\n      .request(this.httpMethod, this.httpUrl, {\n        params: this.httpData || {},\n        responseType: 'blob',\n        observe: 'response',\n        body: this.httpBody\n      })\n      .pipe(finalize(() => this.setDisabled(false)))\n      .subscribe({\n        next: (res: HttpResponse<Blob>) => {\n          if (res.status !== 200 || res.body!.size <= 0) {\n            this.error.emit(res);\n            return;\n          }\n          const disposition = this.getDisposition(res.headers.get('content-disposition'));\n          let fileName = this.fileName;\n          if (typeof fileName === 'function') fileName = fileName(res);\n          fileName =\n            fileName ||\n            disposition[`filename*`] ||\n            disposition[`filename`] ||\n            res.headers.get('filename') ||\n            res.headers.get('x-filename');\n          saveAs(res.body!, decodeURI(fileName as string));\n          this.success.emit(res);\n        },\n        error: err => this.error.emit(err)\n      });\n  }\n}\n"]}
@@ -0,0 +1,21 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { AlainThemeModule } from '@delon/theme';
4
+ import { DownFileDirective } from './down-file.directive';
5
+ import * as i0 from "@angular/core";
6
+ const DIRECTIVES = [DownFileDirective];
7
+ class DownFileModule {
8
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: DownFileModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
9
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.4", ngImport: i0, type: DownFileModule, declarations: [DownFileDirective], imports: [CommonModule, AlainThemeModule], exports: [DownFileDirective] }); }
10
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: DownFileModule, imports: [CommonModule, AlainThemeModule] }); }
11
+ }
12
+ export { DownFileModule };
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: DownFileModule, decorators: [{
14
+ type: NgModule,
15
+ args: [{
16
+ imports: [CommonModule, AlainThemeModule],
17
+ declarations: [...DIRECTIVES],
18
+ exports: [...DIRECTIVES]
19
+ }]
20
+ }] });
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG93bi1maWxlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FiYy9kb3duLWZpbGUvZG93bi1maWxlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFaEQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7O0FBRTFELE1BQU0sVUFBVSxHQUFHLENBQUMsaUJBQWlCLENBQUMsQ0FBQztBQUV2QyxNQUthLGNBQWM7OEdBQWQsY0FBYzsrR0FBZCxjQUFjLGlCQVBQLGlCQUFpQixhQUd6QixZQUFZLEVBQUUsZ0JBQWdCLGFBSHRCLGlCQUFpQjsrR0FPeEIsY0FBYyxZQUpmLFlBQVksRUFBRSxnQkFBZ0I7O1NBSTdCLGNBQWM7MkZBQWQsY0FBYztrQkFMMUIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsZ0JBQWdCLENBQUM7b0JBQ3pDLFlBQVksRUFBRSxDQUFDLEdBQUcsVUFBVSxDQUFDO29CQUM3QixPQUFPLEVBQUUsQ0FBQyxHQUFHLFVBQVUsQ0FBQztpQkFDekIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgQWxhaW5UaGVtZU1vZHVsZSB9IGZyb20gJ0BkZWxvbi90aGVtZSc7XG5cbmltcG9ydCB7IERvd25GaWxlRGlyZWN0aXZlIH0gZnJvbSAnLi9kb3duLWZpbGUuZGlyZWN0aXZlJztcblxuY29uc3QgRElSRUNUSVZFUyA9IFtEb3duRmlsZURpcmVjdGl2ZV07XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIEFsYWluVGhlbWVNb2R1bGVdLFxuICBkZWNsYXJhdGlvbnM6IFsuLi5ESVJFQ1RJVkVTXSxcbiAgZXhwb3J0czogWy4uLkRJUkVDVElWRVNdXG59KVxuZXhwb3J0IGNsYXNzIERvd25GaWxlTW9kdWxlIHt9XG4iXX0=
@@ -0,0 +1,233 @@
1
+ import { __decorate } from "tslib";
2
+ import { DOCUMENT } from '@angular/common';
3
+ import { ChangeDetectionStrategy, Component, Inject, Input, ViewChild, ViewEncapsulation } from '@angular/core';
4
+ import { take } from 'rxjs';
5
+ import { InputBoolean, InputNumber } from '@delon/util/decorator';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/platform-browser";
8
+ import * as i2 from "@angular/common";
9
+ import * as i3 from "@angular/cdk/observers";
10
+ import * as i4 from "ng-zorro-antd/tooltip";
11
+ class EllipsisComponent {
12
+ get linsWord() {
13
+ const { targetCount, text, tail } = this;
14
+ return ((targetCount > 0 ? text.substring(0, targetCount) : '') +
15
+ (targetCount > 0 && targetCount < text.length ? tail : ''));
16
+ }
17
+ get win() {
18
+ return this.doc.defaultView || window;
19
+ }
20
+ constructor(el, ngZone, dom, doc, cdr) {
21
+ this.el = el;
22
+ this.ngZone = ngZone;
23
+ this.dom = dom;
24
+ this.doc = doc;
25
+ this.cdr = cdr;
26
+ this.isSupportLineClamp = this.doc.body.style['webkitLineClamp'] !== undefined;
27
+ this.inited = false;
28
+ this.type = 'default';
29
+ this.cls = {};
30
+ this.text = '';
31
+ this.targetCount = 0;
32
+ this.tooltip = false;
33
+ this.fullWidthRecognition = false;
34
+ this.tail = '...';
35
+ }
36
+ getStrFullLength(str) {
37
+ return str.split('').reduce((pre, cur) => {
38
+ const charCode = cur.charCodeAt(0);
39
+ if (charCode >= 0 && charCode <= 128) {
40
+ return pre + 1;
41
+ }
42
+ return pre + 2;
43
+ }, 0);
44
+ }
45
+ cutStrByFullLength(str, maxLength) {
46
+ let showLength = 0;
47
+ return str.split('').reduce((pre, cur) => {
48
+ const charCode = cur.charCodeAt(0);
49
+ if (charCode >= 0 && charCode <= 128) {
50
+ showLength += 1;
51
+ }
52
+ else {
53
+ showLength += 2;
54
+ }
55
+ if (showLength <= maxLength) {
56
+ return pre + cur;
57
+ }
58
+ return pre;
59
+ }, '');
60
+ }
61
+ bisection(targetHeight, mid, begin, end, text, node) {
62
+ const suffix = this.tail;
63
+ node.innerHTML = text.substring(0, mid) + suffix;
64
+ let sh = node.offsetHeight;
65
+ if (sh <= targetHeight) {
66
+ node.innerHTML = text.substring(0, mid + 1) + suffix;
67
+ sh = node.offsetHeight;
68
+ if (sh > targetHeight || mid === begin) {
69
+ return mid;
70
+ }
71
+ begin = mid;
72
+ mid = end - begin === 1 ? begin + 1 : Math.floor((end - begin) / 2) + begin;
73
+ return this.bisection(targetHeight, mid, begin, end, text, node);
74
+ }
75
+ if (mid - 1 < 0) {
76
+ return mid;
77
+ }
78
+ node.innerHTML = text.substring(0, mid - 1) + suffix;
79
+ sh = node.offsetHeight;
80
+ if (sh <= targetHeight) {
81
+ return mid - 1;
82
+ }
83
+ end = mid;
84
+ mid = Math.floor((end - begin) / 2) + begin;
85
+ return this.bisection(targetHeight, mid, begin, end, text, node);
86
+ }
87
+ genType() {
88
+ const { lines, length, isSupportLineClamp } = this;
89
+ this.cls = {
90
+ ellipsis: true,
91
+ ellipsis__lines: lines && !isSupportLineClamp,
92
+ 'ellipsis__line-clamp': lines && isSupportLineClamp
93
+ };
94
+ if (!lines && !length) {
95
+ this.type = 'default';
96
+ }
97
+ else if (!lines) {
98
+ this.type = 'length';
99
+ }
100
+ else if (isSupportLineClamp) {
101
+ this.type = 'line-clamp';
102
+ }
103
+ else {
104
+ this.type = 'line';
105
+ }
106
+ }
107
+ gen() {
108
+ const { type, lines, length, fullWidthRecognition, tail, orgEl, cdr, ngZone } = this;
109
+ if (type === 'length') {
110
+ const el = orgEl.nativeElement;
111
+ if (el.children.length > 0) {
112
+ throw new Error('Ellipsis content must be string.');
113
+ }
114
+ const lengthText = el.textContent;
115
+ const textLength = fullWidthRecognition ? this.getStrFullLength(lengthText) : lengthText.length;
116
+ if (textLength <= length || length < 0) {
117
+ this.text = lengthText;
118
+ }
119
+ else {
120
+ let displayText;
121
+ if (length - tail.length <= 0) {
122
+ displayText = '';
123
+ }
124
+ else {
125
+ displayText = fullWidthRecognition
126
+ ? this.cutStrByFullLength(lengthText, length)
127
+ : lengthText.slice(0, length);
128
+ }
129
+ this.text = displayText + tail;
130
+ }
131
+ ngZone.run(() => cdr.detectChanges());
132
+ }
133
+ else if (type === 'line') {
134
+ const { shadowOrgEl, shadowTextEl } = this;
135
+ const orgNode = shadowOrgEl.nativeElement;
136
+ const lineText = orgNode.innerText || orgNode.textContent;
137
+ const lineHeight = parseInt(this.win.getComputedStyle(this.getEl('.ellipsis')).lineHeight, 10);
138
+ const targetHeight = lines * lineHeight;
139
+ this.getEl('.ellipsis__handle').style.height = `${targetHeight}px`;
140
+ if (orgNode.offsetHeight <= targetHeight) {
141
+ this.text = lineText;
142
+ this.targetCount = lineText.length;
143
+ }
144
+ else {
145
+ // bisection
146
+ const len = lineText.length;
147
+ const mid = Math.ceil(len / 2);
148
+ const count = this.bisection(targetHeight, mid, 0, len, lineText, shadowTextEl.nativeElement.firstChild);
149
+ this.text = lineText;
150
+ this.targetCount = count;
151
+ }
152
+ ngZone.run(() => cdr.detectChanges());
153
+ }
154
+ }
155
+ getEl(cls) {
156
+ return this.el.nativeElement.querySelector(cls);
157
+ }
158
+ executeOnStable(fn) {
159
+ if (this.ngZone.isStable) {
160
+ fn();
161
+ }
162
+ else {
163
+ this.ngZone.onStable.asObservable().pipe(take(1)).subscribe(fn);
164
+ }
165
+ }
166
+ refresh() {
167
+ this.genType();
168
+ const { type, dom, orgEl, cdr } = this;
169
+ const html = orgEl.nativeElement.innerHTML;
170
+ this.orgHtml = dom.bypassSecurityTrustHtml(html);
171
+ cdr.detectChanges();
172
+ this.executeOnStable(() => {
173
+ this.gen();
174
+ if (type !== 'line') {
175
+ const el = this.getEl('.ellipsis');
176
+ if (el) {
177
+ el.innerHTML = html;
178
+ }
179
+ }
180
+ });
181
+ }
182
+ ngAfterViewInit() {
183
+ this.inited = true;
184
+ this.refresh();
185
+ }
186
+ ngOnChanges() {
187
+ if (this.inited) {
188
+ this.refresh();
189
+ }
190
+ }
191
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: EllipsisComponent, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: i1.DomSanitizer }, { token: DOCUMENT }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
192
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.4", type: EllipsisComponent, selector: "ellipsis", inputs: { tooltip: "tooltip", length: "length", lines: "lines", fullWidthRecognition: "fullWidthRecognition", tail: "tail" }, viewQueries: [{ propertyName: "orgEl", first: true, predicate: ["orgEl"], descendants: true }, { propertyName: "shadowOrgEl", first: true, predicate: ["shadowOrgEl"], descendants: true }, { propertyName: "shadowTextEl", first: true, predicate: ["shadowTextEl"], descendants: true }], exportAs: ["ellipsis"], usesOnChanges: true, ngImport: i0, template: "<div (cdkObserveContent)=\"refresh()\" #orgEl style=\"display: none\"><ng-content></ng-content></div>\n<ng-template #tooltipTpl let-con>\n <span\n *ngIf=\"tooltip; else con\"\n nz-tooltip\n [nzTooltipTitle]=\"titleTpl\"\n [nzTooltipOverlayStyle]=\"{ 'overflow-wrap': 'break-word', 'word-wrap': 'break-word' }\"\n >\n <ng-container *ngTemplateOutlet=\"con\"></ng-container>\n <ng-template #titleTpl><div [innerHTML]=\"orgHtml\"></div></ng-template>\n </span>\n</ng-template>\n<ng-container [ngSwitch]=\"type\">\n <span *ngSwitchCase=\"'default'\" [ngClass]=\"cls\"></span>\n <ng-container *ngSwitchCase=\"'length'\">\n <ng-template [ngTemplateOutlet]=\"tooltipTpl\" [ngTemplateOutletContext]=\"{ $implicit: lengthTpl }\"></ng-template>\n <ng-template #lengthTpl>{{ text }}</ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"'line-clamp'\">\n <ng-template [ngTemplateOutlet]=\"tooltipTpl\" [ngTemplateOutletContext]=\"{ $implicit: lineClampTpl }\"></ng-template>\n <ng-template #lineClampTpl>\n <div [ngClass]=\"cls\" [ngStyle]=\"{ '-webkit-line-clamp': lines, '-webkit-box-orient': 'vertical' }\"></div>\n </ng-template>\n </ng-container>\n <div *ngSwitchCase=\"'line'\" [ngClass]=\"cls\">\n <div class=\"ellipsis__handle\">\n <ng-template [ngTemplateOutlet]=\"tooltipTpl\" [ngTemplateOutletContext]=\"{ $implicit: lineTpl }\"></ng-template>\n <ng-template #lineTpl>{{ linsWord }}</ng-template>\n <div class=\"ellipsis__shadow\" #shadowOrgEl [innerHTML]=\"orgHtml\"></div>\n <div class=\"ellipsis__shadow\" #shadowTextEl>\n <span>{{ text }}</span>\n </div>\n </div>\n </div>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i3.CdkObserveContent, selector: "[cdkObserveContent]", inputs: ["cdkObserveContentDisabled", "debounce"], outputs: ["cdkObserveContent"], exportAs: ["cdkObserveContent"] }, { kind: "directive", type: i4.NzTooltipDirective, selector: "[nz-tooltip]", inputs: ["nzTooltipTitle", "nzTooltipTitleContext", "nz-tooltip", "nzTooltipTrigger", "nzTooltipPlacement", "nzTooltipOrigin", "nzTooltipVisible", "nzTooltipMouseEnterDelay", "nzTooltipMouseLeaveDelay", "nzTooltipOverlayClassName", "nzTooltipOverlayStyle", "nzTooltipArrowPointAtCenter", "nzTooltipColor"], outputs: ["nzTooltipVisibleChange"], exportAs: ["nzTooltip"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
193
+ }
194
+ __decorate([
195
+ InputBoolean()
196
+ ], EllipsisComponent.prototype, "tooltip", void 0);
197
+ __decorate([
198
+ InputNumber(null)
199
+ ], EllipsisComponent.prototype, "length", void 0);
200
+ __decorate([
201
+ InputNumber(null)
202
+ ], EllipsisComponent.prototype, "lines", void 0);
203
+ __decorate([
204
+ InputBoolean()
205
+ ], EllipsisComponent.prototype, "fullWidthRecognition", void 0);
206
+ export { EllipsisComponent };
207
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: EllipsisComponent, decorators: [{
208
+ type: Component,
209
+ args: [{ selector: 'ellipsis', exportAs: 'ellipsis', preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<div (cdkObserveContent)=\"refresh()\" #orgEl style=\"display: none\"><ng-content></ng-content></div>\n<ng-template #tooltipTpl let-con>\n <span\n *ngIf=\"tooltip; else con\"\n nz-tooltip\n [nzTooltipTitle]=\"titleTpl\"\n [nzTooltipOverlayStyle]=\"{ 'overflow-wrap': 'break-word', 'word-wrap': 'break-word' }\"\n >\n <ng-container *ngTemplateOutlet=\"con\"></ng-container>\n <ng-template #titleTpl><div [innerHTML]=\"orgHtml\"></div></ng-template>\n </span>\n</ng-template>\n<ng-container [ngSwitch]=\"type\">\n <span *ngSwitchCase=\"'default'\" [ngClass]=\"cls\"></span>\n <ng-container *ngSwitchCase=\"'length'\">\n <ng-template [ngTemplateOutlet]=\"tooltipTpl\" [ngTemplateOutletContext]=\"{ $implicit: lengthTpl }\"></ng-template>\n <ng-template #lengthTpl>{{ text }}</ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"'line-clamp'\">\n <ng-template [ngTemplateOutlet]=\"tooltipTpl\" [ngTemplateOutletContext]=\"{ $implicit: lineClampTpl }\"></ng-template>\n <ng-template #lineClampTpl>\n <div [ngClass]=\"cls\" [ngStyle]=\"{ '-webkit-line-clamp': lines, '-webkit-box-orient': 'vertical' }\"></div>\n </ng-template>\n </ng-container>\n <div *ngSwitchCase=\"'line'\" [ngClass]=\"cls\">\n <div class=\"ellipsis__handle\">\n <ng-template [ngTemplateOutlet]=\"tooltipTpl\" [ngTemplateOutletContext]=\"{ $implicit: lineTpl }\"></ng-template>\n <ng-template #lineTpl>{{ linsWord }}</ng-template>\n <div class=\"ellipsis__shadow\" #shadowOrgEl [innerHTML]=\"orgHtml\"></div>\n <div class=\"ellipsis__shadow\" #shadowTextEl>\n <span>{{ text }}</span>\n </div>\n </div>\n </div>\n</ng-container>\n" }]
210
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: i1.DomSanitizer }, { type: undefined, decorators: [{
211
+ type: Inject,
212
+ args: [DOCUMENT]
213
+ }] }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { orgEl: [{
214
+ type: ViewChild,
215
+ args: ['orgEl', { static: false }]
216
+ }], shadowOrgEl: [{
217
+ type: ViewChild,
218
+ args: ['shadowOrgEl', { static: false }]
219
+ }], shadowTextEl: [{
220
+ type: ViewChild,
221
+ args: ['shadowTextEl', { static: false }]
222
+ }], tooltip: [{
223
+ type: Input
224
+ }], length: [{
225
+ type: Input
226
+ }], lines: [{
227
+ type: Input
228
+ }], fullWidthRecognition: [{
229
+ type: Input
230
+ }], tail: [{
231
+ type: Input
232
+ }] } });
233
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ellipsis.component.js","sourceRoot":"","sources":["../../../../../packages/abc/ellipsis/ellipsis.component.ts","../../../../../packages/abc/ellipsis/ellipsis.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  NgZone,\n  OnChanges,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { take } from 'rxjs';\n\nimport { BooleanInput, InputBoolean, InputNumber, NumberInput } from '@delon/util/decorator';\nimport type { NzSafeAny } from 'ng-zorro-antd/core/types';\n\n@Component({\n  selector: 'ellipsis',\n  exportAs: 'ellipsis',\n  templateUrl: './ellipsis.component.html',\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None\n})\nexport class EllipsisComponent implements AfterViewInit, OnChanges {\n  static ngAcceptInputType_tooltip: BooleanInput;\n  static ngAcceptInputType_length: NumberInput;\n  static ngAcceptInputType_lines: NumberInput;\n  static ngAcceptInputType_fullWidthRecognition: BooleanInput;\n\n  private isSupportLineClamp = this.doc.body.style['webkitLineClamp'] !== undefined;\n  @ViewChild('orgEl', { static: false }) private orgEl!: ElementRef;\n  @ViewChild('shadowOrgEl', { static: false }) private shadowOrgEl!: ElementRef;\n  @ViewChild('shadowTextEl', { static: false }) private shadowTextEl!: ElementRef;\n  private inited = false;\n  orgHtml!: SafeHtml;\n  type = 'default';\n  cls = {};\n  text = '';\n  targetCount = 0;\n\n  @Input() @InputBoolean() tooltip = false;\n  @Input() @InputNumber(null) length?: number;\n  @Input() @InputNumber(null) lines?: number;\n  @Input() @InputBoolean() fullWidthRecognition = false;\n  @Input() tail = '...';\n\n  get linsWord(): string {\n    const { targetCount, text, tail } = this;\n    return (\n      (targetCount > 0 ? text.substring(0, targetCount) : '') +\n      (targetCount > 0 && targetCount < text.length ? tail : '')\n    );\n  }\n\n  private get win(): NzSafeAny {\n    return this.doc.defaultView || window;\n  }\n\n  constructor(\n    private el: ElementRef,\n    private ngZone: NgZone,\n    private dom: DomSanitizer,\n    @Inject(DOCUMENT) private doc: NzSafeAny,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  private getStrFullLength(str: string): number {\n    return str.split('').reduce((pre, cur) => {\n      const charCode = cur.charCodeAt(0);\n      if (charCode >= 0 && charCode <= 128) {\n        return pre + 1;\n      }\n      return pre + 2;\n    }, 0);\n  }\n\n  private cutStrByFullLength(str: string, maxLength: number): string {\n    let showLength = 0;\n    return str.split('').reduce((pre, cur) => {\n      const charCode = cur.charCodeAt(0);\n      if (charCode >= 0 && charCode <= 128) {\n        showLength += 1;\n      } else {\n        showLength += 2;\n      }\n      if (showLength <= maxLength) {\n        return pre + cur;\n      }\n      return pre;\n    }, '');\n  }\n\n  private bisection(\n    targetHeight: number,\n    mid: number,\n    begin: number,\n    end: number,\n    text: string,\n    node: HTMLElement\n  ): number {\n    const suffix = this.tail;\n    node.innerHTML = text.substring(0, mid) + suffix;\n    let sh = node.offsetHeight;\n\n    if (sh <= targetHeight) {\n      node.innerHTML = text.substring(0, mid + 1) + suffix;\n      sh = node.offsetHeight;\n      if (sh > targetHeight || mid === begin) {\n        return mid;\n      }\n      begin = mid;\n      mid = end - begin === 1 ? begin + 1 : Math.floor((end - begin) / 2) + begin;\n      return this.bisection(targetHeight, mid, begin, end, text, node);\n    }\n    if (mid - 1 < 0) {\n      return mid;\n    }\n    node.innerHTML = text.substring(0, mid - 1) + suffix;\n    sh = node.offsetHeight;\n    if (sh <= targetHeight) {\n      return mid - 1;\n    }\n    end = mid;\n    mid = Math.floor((end - begin) / 2) + begin;\n    return this.bisection(targetHeight, mid, begin, end, text, node);\n  }\n\n  private genType(): void {\n    const { lines, length, isSupportLineClamp } = this;\n    this.cls = {\n      ellipsis: true,\n      ellipsis__lines: lines && !isSupportLineClamp,\n      'ellipsis__line-clamp': lines && isSupportLineClamp\n    };\n    if (!lines && !length) {\n      this.type = 'default';\n    } else if (!lines) {\n      this.type = 'length';\n    } else if (isSupportLineClamp) {\n      this.type = 'line-clamp';\n    } else {\n      this.type = 'line';\n    }\n  }\n\n  private gen(): void {\n    const { type, lines, length, fullWidthRecognition, tail, orgEl, cdr, ngZone } = this;\n    if (type === 'length') {\n      const el = orgEl.nativeElement as HTMLElement;\n      if (el.children.length > 0) {\n        throw new Error('Ellipsis content must be string.');\n      }\n      const lengthText = el.textContent!;\n      const textLength = fullWidthRecognition ? this.getStrFullLength(lengthText) : lengthText.length;\n      if (textLength <= length! || length! < 0) {\n        this.text = lengthText;\n      } else {\n        let displayText: string;\n        if (length! - tail.length <= 0) {\n          displayText = '';\n        } else {\n          displayText = fullWidthRecognition\n            ? this.cutStrByFullLength(lengthText, length!)\n            : lengthText.slice(0, length);\n        }\n        this.text = displayText + tail;\n      }\n      ngZone.run(() => cdr.detectChanges());\n    } else if (type === 'line') {\n      const { shadowOrgEl, shadowTextEl } = this;\n      const orgNode = shadowOrgEl.nativeElement as HTMLElement;\n      const lineText = orgNode.innerText || orgNode.textContent!;\n      const lineHeight = parseInt(this.win.getComputedStyle(this.getEl('.ellipsis')).lineHeight!, 10);\n      const targetHeight = lines! * lineHeight;\n      this.getEl('.ellipsis__handle').style.height = `${targetHeight}px`;\n\n      if (orgNode.offsetHeight <= targetHeight) {\n        this.text = lineText;\n        this.targetCount = lineText.length;\n      } else {\n        // bisection\n        const len = lineText.length;\n        const mid = Math.ceil(len / 2);\n\n        const count = this.bisection(targetHeight, mid, 0, len, lineText, shadowTextEl.nativeElement.firstChild);\n        this.text = lineText;\n        this.targetCount = count;\n      }\n      ngZone.run(() => cdr.detectChanges());\n    }\n  }\n\n  private getEl(cls: string): HTMLElement {\n    return this.el.nativeElement.querySelector(cls);\n  }\n\n  private executeOnStable(fn: () => void): void {\n    if (this.ngZone.isStable) {\n      fn();\n    } else {\n      this.ngZone.onStable.asObservable().pipe(take(1)).subscribe(fn);\n    }\n  }\n\n  refresh(): void {\n    this.genType();\n    const { type, dom, orgEl, cdr } = this;\n    const html = orgEl.nativeElement.innerHTML;\n    this.orgHtml = dom.bypassSecurityTrustHtml(html);\n    cdr.detectChanges();\n    this.executeOnStable(() => {\n      this.gen();\n      if (type !== 'line') {\n        const el = this.getEl('.ellipsis');\n        if (el) {\n          el.innerHTML = html;\n        }\n      }\n    });\n  }\n\n  ngAfterViewInit(): void {\n    this.inited = true;\n    this.refresh();\n  }\n\n  ngOnChanges(): void {\n    if (this.inited) {\n      this.refresh();\n    }\n  }\n}\n","<div (cdkObserveContent)=\"refresh()\" #orgEl style=\"display: none\"><ng-content></ng-content></div>\n<ng-template #tooltipTpl let-con>\n  <span\n    *ngIf=\"tooltip; else con\"\n    nz-tooltip\n    [nzTooltipTitle]=\"titleTpl\"\n    [nzTooltipOverlayStyle]=\"{ 'overflow-wrap': 'break-word', 'word-wrap': 'break-word' }\"\n  >\n    <ng-container *ngTemplateOutlet=\"con\"></ng-container>\n    <ng-template #titleTpl><div [innerHTML]=\"orgHtml\"></div></ng-template>\n  </span>\n</ng-template>\n<ng-container [ngSwitch]=\"type\">\n  <span *ngSwitchCase=\"'default'\" [ngClass]=\"cls\"></span>\n  <ng-container *ngSwitchCase=\"'length'\">\n    <ng-template [ngTemplateOutlet]=\"tooltipTpl\" [ngTemplateOutletContext]=\"{ $implicit: lengthTpl }\"></ng-template>\n    <ng-template #lengthTpl>{{ text }}</ng-template>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"'line-clamp'\">\n    <ng-template [ngTemplateOutlet]=\"tooltipTpl\" [ngTemplateOutletContext]=\"{ $implicit: lineClampTpl }\"></ng-template>\n    <ng-template #lineClampTpl>\n      <div [ngClass]=\"cls\" [ngStyle]=\"{ '-webkit-line-clamp': lines, '-webkit-box-orient': 'vertical' }\"></div>\n    </ng-template>\n  </ng-container>\n  <div *ngSwitchCase=\"'line'\" [ngClass]=\"cls\">\n    <div class=\"ellipsis__handle\">\n      <ng-template [ngTemplateOutlet]=\"tooltipTpl\" [ngTemplateOutletContext]=\"{ $implicit: lineTpl }\"></ng-template>\n      <ng-template #lineTpl>{{ linsWord }}</ng-template>\n      <div class=\"ellipsis__shadow\" #shadowOrgEl [innerHTML]=\"orgHtml\"></div>\n      <div class=\"ellipsis__shadow\" #shadowTextEl>\n        <span>{{ text }}</span>\n      </div>\n    </div>\n  </div>\n</ng-container>\n"]}