huibo-ui 0.3.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 (1214) hide show
  1. package/LICENSE +21 -0
  2. package/dist/cjs/a11y-802de67a.js +123 -0
  3. package/dist/cjs/a11y-802de67a.js.map +1 -0
  4. package/dist/cjs/app-globals-3a1e7e63.js +7 -0
  5. package/dist/cjs/app-globals-3a1e7e63.js.map +1 -0
  6. package/dist/cjs/click-outside-3fcc00dd.js +27 -0
  7. package/dist/cjs/click-outside-3fcc00dd.js.map +1 -0
  8. package/dist/cjs/date-helpers-904747ff.js +134 -0
  9. package/dist/cjs/date-helpers-904747ff.js.map +1 -0
  10. package/dist/cjs/hb-affix.cjs.entry.js +101 -0
  11. package/dist/cjs/hb-affix.cjs.entry.js.map +1 -0
  12. package/dist/cjs/hb-alert.cjs.entry.js +47 -0
  13. package/dist/cjs/hb-alert.cjs.entry.js.map +1 -0
  14. package/dist/cjs/hb-anchor.cjs.entry.js +46 -0
  15. package/dist/cjs/hb-anchor.cjs.entry.js.map +1 -0
  16. package/dist/cjs/hb-aside.cjs.entry.js +30 -0
  17. package/dist/cjs/hb-aside.cjs.entry.js.map +1 -0
  18. package/dist/cjs/hb-avatar.cjs.entry.js +31 -0
  19. package/dist/cjs/hb-avatar.cjs.entry.js.map +1 -0
  20. package/dist/cjs/hb-backtop.cjs.entry.js +100 -0
  21. package/dist/cjs/hb-backtop.cjs.entry.js.map +1 -0
  22. package/dist/cjs/hb-badge.cjs.entry.js +35 -0
  23. package/dist/cjs/hb-badge.cjs.entry.js.map +1 -0
  24. package/dist/cjs/hb-breadcrumb-item.cjs.entry.js +25 -0
  25. package/dist/cjs/hb-breadcrumb-item.cjs.entry.js.map +1 -0
  26. package/dist/cjs/hb-breadcrumb.cjs.entry.js +24 -0
  27. package/dist/cjs/hb-breadcrumb.cjs.entry.js.map +1 -0
  28. package/dist/cjs/hb-button.cjs.entry.js +39 -0
  29. package/dist/cjs/hb-button.cjs.entry.js.map +1 -0
  30. package/dist/cjs/hb-calendar.cjs.entry.js +90 -0
  31. package/dist/cjs/hb-calendar.cjs.entry.js.map +1 -0
  32. package/dist/cjs/hb-card.cjs.entry.js +27 -0
  33. package/dist/cjs/hb-card.cjs.entry.js.map +1 -0
  34. package/dist/cjs/hb-carousel.cjs.entry.js +150 -0
  35. package/dist/cjs/hb-carousel.cjs.entry.js.map +1 -0
  36. package/dist/cjs/hb-cascader.cjs.entry.js +413 -0
  37. package/dist/cjs/hb-cascader.cjs.entry.js.map +1 -0
  38. package/dist/cjs/hb-checkbox-group.cjs.entry.js +117 -0
  39. package/dist/cjs/hb-checkbox-group.cjs.entry.js.map +1 -0
  40. package/dist/cjs/hb-checkbox.cjs.entry.js +130 -0
  41. package/dist/cjs/hb-checkbox.cjs.entry.js.map +1 -0
  42. package/dist/cjs/hb-collapse-item.cjs.entry.js +58 -0
  43. package/dist/cjs/hb-collapse-item.cjs.entry.js.map +1 -0
  44. package/dist/cjs/hb-collapse.cjs.entry.js +41 -0
  45. package/dist/cjs/hb-collapse.cjs.entry.js.map +1 -0
  46. package/dist/cjs/hb-color-picker-panel.cjs.entry.js +86 -0
  47. package/dist/cjs/hb-color-picker-panel.cjs.entry.js.map +1 -0
  48. package/dist/cjs/hb-color-picker.cjs.entry.js +265 -0
  49. package/dist/cjs/hb-color-picker.cjs.entry.js.map +1 -0
  50. package/dist/cjs/hb-config-provider.cjs.entry.js +44 -0
  51. package/dist/cjs/hb-config-provider.cjs.entry.js.map +1 -0
  52. package/dist/cjs/hb-container.cjs.entry.js +30 -0
  53. package/dist/cjs/hb-container.cjs.entry.js.map +1 -0
  54. package/dist/cjs/hb-date-picker-pane.cjs.entry.js +150 -0
  55. package/dist/cjs/hb-date-picker-pane.cjs.entry.js.map +1 -0
  56. package/dist/cjs/hb-date-picker.cjs.entry.js +138 -0
  57. package/dist/cjs/hb-date-picker.cjs.entry.js.map +1 -0
  58. package/dist/cjs/hb-date-range-picker.cjs.entry.js +222 -0
  59. package/dist/cjs/hb-date-range-picker.cjs.entry.js.map +1 -0
  60. package/dist/cjs/hb-date-time-picker.cjs.entry.js +140 -0
  61. package/dist/cjs/hb-date-time-picker.cjs.entry.js.map +1 -0
  62. package/dist/cjs/hb-descriptions.cjs.entry.js +32 -0
  63. package/dist/cjs/hb-descriptions.cjs.entry.js.map +1 -0
  64. package/dist/cjs/hb-dialog.cjs.entry.js +114 -0
  65. package/dist/cjs/hb-dialog.cjs.entry.js.map +1 -0
  66. package/dist/cjs/hb-divider.cjs.entry.js +36 -0
  67. package/dist/cjs/hb-divider.cjs.entry.js.map +1 -0
  68. package/dist/cjs/hb-drawer.cjs.entry.js +89 -0
  69. package/dist/cjs/hb-drawer.cjs.entry.js.map +1 -0
  70. package/dist/cjs/hb-dropdown.cjs.entry.js +80 -0
  71. package/dist/cjs/hb-dropdown.cjs.entry.js.map +1 -0
  72. package/dist/cjs/hb-empty.cjs.entry.js +24 -0
  73. package/dist/cjs/hb-empty.cjs.entry.js.map +1 -0
  74. package/dist/cjs/hb-float-button.cjs.entry.js +57 -0
  75. package/dist/cjs/hb-float-button.cjs.entry.js.map +1 -0
  76. package/dist/cjs/hb-footer.cjs.entry.js +30 -0
  77. package/dist/cjs/hb-footer.cjs.entry.js.map +1 -0
  78. package/dist/cjs/hb-form-item.cjs.entry.js +112 -0
  79. package/dist/cjs/hb-form-item.cjs.entry.js.map +1 -0
  80. package/dist/cjs/hb-form.cjs.entry.js +70 -0
  81. package/dist/cjs/hb-form.cjs.entry.js.map +1 -0
  82. package/dist/cjs/hb-header.cjs.entry.js +30 -0
  83. package/dist/cjs/hb-header.cjs.entry.js.map +1 -0
  84. package/dist/cjs/hb-icon.cjs.entry.js +76 -0
  85. package/dist/cjs/hb-icon.cjs.entry.js.map +1 -0
  86. package/dist/cjs/hb-image-preview.cjs.entry.js +179 -0
  87. package/dist/cjs/hb-image-preview.cjs.entry.js.map +1 -0
  88. package/dist/cjs/hb-image.cjs.entry.js +35 -0
  89. package/dist/cjs/hb-image.cjs.entry.js.map +1 -0
  90. package/dist/cjs/hb-input-number.cjs.entry.js +169 -0
  91. package/dist/cjs/hb-input-number.cjs.entry.js.map +1 -0
  92. package/dist/cjs/hb-input-tag.cjs.entry.js +145 -0
  93. package/dist/cjs/hb-input-tag.cjs.entry.js.map +1 -0
  94. package/dist/cjs/hb-input.cjs.entry.js +252 -0
  95. package/dist/cjs/hb-input.cjs.entry.js.map +1 -0
  96. package/dist/cjs/hb-layout.cjs.entry.js +78 -0
  97. package/dist/cjs/hb-layout.cjs.entry.js.map +1 -0
  98. package/dist/cjs/hb-link.cjs.entry.js +67 -0
  99. package/dist/cjs/hb-link.cjs.entry.js.map +1 -0
  100. package/dist/cjs/hb-loading.cjs.entry.js +32 -0
  101. package/dist/cjs/hb-loading.cjs.entry.js.map +1 -0
  102. package/dist/cjs/hb-main.cjs.entry.js +22 -0
  103. package/dist/cjs/hb-main.cjs.entry.js.map +1 -0
  104. package/dist/cjs/hb-menu-item.cjs.entry.js +50 -0
  105. package/dist/cjs/hb-menu-item.cjs.entry.js.map +1 -0
  106. package/dist/cjs/hb-menu.cjs.entry.js +87 -0
  107. package/dist/cjs/hb-menu.cjs.entry.js.map +1 -0
  108. package/dist/cjs/hb-message.cjs.entry.js +48 -0
  109. package/dist/cjs/hb-message.cjs.entry.js.map +1 -0
  110. package/dist/cjs/hb-notification.cjs.entry.js +67 -0
  111. package/dist/cjs/hb-notification.cjs.entry.js.map +1 -0
  112. package/dist/cjs/hb-page-header.cjs.entry.js +37 -0
  113. package/dist/cjs/hb-page-header.cjs.entry.js.map +1 -0
  114. package/dist/cjs/hb-pagination.cjs.entry.js +107 -0
  115. package/dist/cjs/hb-pagination.cjs.entry.js.map +1 -0
  116. package/dist/cjs/hb-popconfirm.cjs.entry.js +51 -0
  117. package/dist/cjs/hb-popconfirm.cjs.entry.js.map +1 -0
  118. package/dist/cjs/hb-popover.cjs.entry.js +59 -0
  119. package/dist/cjs/hb-popover.cjs.entry.js.map +1 -0
  120. package/dist/cjs/hb-progress.cjs.entry.js +39 -0
  121. package/dist/cjs/hb-progress.cjs.entry.js.map +1 -0
  122. package/dist/cjs/hb-radio.cjs.entry.js +119 -0
  123. package/dist/cjs/hb-radio.cjs.entry.js.map +1 -0
  124. package/dist/cjs/hb-rate.cjs.entry.js +132 -0
  125. package/dist/cjs/hb-rate.cjs.entry.js.map +1 -0
  126. package/dist/cjs/hb-result.cjs.entry.js +57 -0
  127. package/dist/cjs/hb-result.cjs.entry.js.map +1 -0
  128. package/dist/cjs/hb-row.cjs.entry.js +57 -0
  129. package/dist/cjs/hb-row.cjs.entry.js.map +1 -0
  130. package/dist/cjs/hb-scrollbar.cjs.entry.js +204 -0
  131. package/dist/cjs/hb-scrollbar.cjs.entry.js.map +1 -0
  132. package/dist/cjs/hb-segmented.cjs.entry.js +43 -0
  133. package/dist/cjs/hb-segmented.cjs.entry.js.map +1 -0
  134. package/dist/cjs/hb-select.cjs.entry.js +262 -0
  135. package/dist/cjs/hb-select.cjs.entry.js.map +1 -0
  136. package/dist/cjs/hb-skeleton.cjs.entry.js +53 -0
  137. package/dist/cjs/hb-skeleton.cjs.entry.js.map +1 -0
  138. package/dist/cjs/hb-slider.cjs.entry.js +172 -0
  139. package/dist/cjs/hb-slider.cjs.entry.js.map +1 -0
  140. package/dist/cjs/hb-space.cjs.entry.js +72 -0
  141. package/dist/cjs/hb-space.cjs.entry.js.map +1 -0
  142. package/dist/cjs/hb-statistic.cjs.entry.js +66 -0
  143. package/dist/cjs/hb-statistic.cjs.entry.js.map +1 -0
  144. package/dist/cjs/hb-step.cjs.entry.js +24 -0
  145. package/dist/cjs/hb-step.cjs.entry.js.map +1 -0
  146. package/dist/cjs/hb-steps.cjs.entry.js +50 -0
  147. package/dist/cjs/hb-steps.cjs.entry.js.map +1 -0
  148. package/dist/cjs/hb-sub-menu.cjs.entry.js +70 -0
  149. package/dist/cjs/hb-sub-menu.cjs.entry.js.map +1 -0
  150. package/dist/cjs/hb-switch.cjs.entry.js +92 -0
  151. package/dist/cjs/hb-switch.cjs.entry.js.map +1 -0
  152. package/dist/cjs/hb-tab-pane.cjs.entry.js +26 -0
  153. package/dist/cjs/hb-tab-pane.cjs.entry.js.map +1 -0
  154. package/dist/cjs/hb-table.cjs.entry.js +370 -0
  155. package/dist/cjs/hb-table.cjs.entry.js.map +1 -0
  156. package/dist/cjs/hb-tabs.cjs.entry.js +115 -0
  157. package/dist/cjs/hb-tabs.cjs.entry.js.map +1 -0
  158. package/dist/cjs/hb-tag.cjs.entry.js +45 -0
  159. package/dist/cjs/hb-tag.cjs.entry.js.map +1 -0
  160. package/dist/cjs/hb-text.cjs.entry.js +60 -0
  161. package/dist/cjs/hb-text.cjs.entry.js.map +1 -0
  162. package/dist/cjs/hb-time-picker.cjs.entry.js +147 -0
  163. package/dist/cjs/hb-time-picker.cjs.entry.js.map +1 -0
  164. package/dist/cjs/hb-time-select.cjs.entry.js +145 -0
  165. package/dist/cjs/hb-time-select.cjs.entry.js.map +1 -0
  166. package/dist/cjs/hb-timeline.cjs.entry.js +30 -0
  167. package/dist/cjs/hb-timeline.cjs.entry.js.map +1 -0
  168. package/dist/cjs/hb-tooltip.cjs.entry.js +74 -0
  169. package/dist/cjs/hb-tooltip.cjs.entry.js.map +1 -0
  170. package/dist/cjs/hb-tour.cjs.entry.js +119 -0
  171. package/dist/cjs/hb-tour.cjs.entry.js.map +1 -0
  172. package/dist/cjs/hb-transfer.cjs.entry.js +173 -0
  173. package/dist/cjs/hb-transfer.cjs.entry.js.map +1 -0
  174. package/dist/cjs/hb-tree-select.cjs.entry.js +236 -0
  175. package/dist/cjs/hb-tree-select.cjs.entry.js.map +1 -0
  176. package/dist/cjs/hb-tree.cjs.entry.js +313 -0
  177. package/dist/cjs/hb-tree.cjs.entry.js.map +1 -0
  178. package/dist/cjs/hb-upload.cjs.entry.js +184 -0
  179. package/dist/cjs/hb-upload.cjs.entry.js.map +1 -0
  180. package/dist/cjs/hb-watermark.cjs.entry.js +59 -0
  181. package/dist/cjs/hb-watermark.cjs.entry.js.map +1 -0
  182. package/dist/cjs/huibo-ui.cjs.js +27 -0
  183. package/dist/cjs/huibo-ui.cjs.js.map +1 -0
  184. package/dist/cjs/index-5aa5c817.js +1915 -0
  185. package/dist/cjs/index-5aa5c817.js.map +1 -0
  186. package/dist/cjs/index.cjs.js +4 -0
  187. package/dist/cjs/index.cjs.js.map +1 -0
  188. package/dist/cjs/loader.cjs.js +17 -0
  189. package/dist/cjs/loader.cjs.js.map +1 -0
  190. package/dist/cjs/popup-manager-cde53b2f.js +83 -0
  191. package/dist/cjs/popup-manager-cde53b2f.js.map +1 -0
  192. package/dist/collection/collection-manifest.json +97 -0
  193. package/dist/collection/components/Affix/Affix.js +197 -0
  194. package/dist/collection/components/Affix/Affix.js.map +1 -0
  195. package/dist/collection/components/Affix/affix.css +15 -0
  196. package/dist/collection/components/Alert/Alert.js +193 -0
  197. package/dist/collection/components/Alert/Alert.js.map +1 -0
  198. package/dist/collection/components/Alert/alert.css +20 -0
  199. package/dist/collection/components/Anchor/Anchor.js +142 -0
  200. package/dist/collection/components/Anchor/Anchor.js.map +1 -0
  201. package/dist/collection/components/Anchor/anchor.css +53 -0
  202. package/dist/collection/components/Avatar/Avatar.js +129 -0
  203. package/dist/collection/components/Avatar/Avatar.js.map +1 -0
  204. package/dist/collection/components/Avatar/avatar.css +9 -0
  205. package/dist/collection/components/Backtop/Backtop.js +236 -0
  206. package/dist/collection/components/Backtop/Backtop.js.map +1 -0
  207. package/dist/collection/components/Backtop/backtop.css +33 -0
  208. package/dist/collection/components/Badge/Badge.js +136 -0
  209. package/dist/collection/components/Badge/Badge.js.map +1 -0
  210. package/dist/collection/components/Badge/badge.css +17 -0
  211. package/dist/collection/components/Breadcrumb/Breadcrumb.js +49 -0
  212. package/dist/collection/components/Breadcrumb/Breadcrumb.js.map +1 -0
  213. package/dist/collection/components/Breadcrumb/BreadcrumbItem.js +43 -0
  214. package/dist/collection/components/Breadcrumb/BreadcrumbItem.js.map +1 -0
  215. package/dist/collection/components/Breadcrumb/breadcrumb.css +10 -0
  216. package/dist/collection/components/Button/Button.js +144 -0
  217. package/dist/collection/components/Button/Button.js.map +1 -0
  218. package/dist/collection/components/Button/button.css +127 -0
  219. package/dist/collection/components/Calendar/Calendar.js +185 -0
  220. package/dist/collection/components/Calendar/Calendar.js.map +1 -0
  221. package/dist/collection/components/Calendar/calendar.css +101 -0
  222. package/dist/collection/components/Card/Card.js +67 -0
  223. package/dist/collection/components/Card/Card.js.map +1 -0
  224. package/dist/collection/components/Card/card.css +17 -0
  225. package/dist/collection/components/Carousel/Carousel.js +312 -0
  226. package/dist/collection/components/Carousel/Carousel.js.map +1 -0
  227. package/dist/collection/components/Carousel/carousel.css +96 -0
  228. package/dist/collection/components/Cascader/Cascader.js +773 -0
  229. package/dist/collection/components/Cascader/Cascader.js.map +1 -0
  230. package/dist/collection/components/Cascader/cascader.css +276 -0
  231. package/dist/collection/components/Checkbox/Checkbox.js +372 -0
  232. package/dist/collection/components/Checkbox/Checkbox.js.map +1 -0
  233. package/dist/collection/components/Checkbox/CheckboxGroup.js +276 -0
  234. package/dist/collection/components/Checkbox/CheckboxGroup.js.map +1 -0
  235. package/dist/collection/components/Checkbox/checkbox-group.css +17 -0
  236. package/dist/collection/components/Checkbox/checkbox.css +179 -0
  237. package/dist/collection/components/Collapse/Collapse.js +63 -0
  238. package/dist/collection/components/Collapse/Collapse.js.map +1 -0
  239. package/dist/collection/components/Collapse/CollapseItem.js +142 -0
  240. package/dist/collection/components/Collapse/CollapseItem.js.map +1 -0
  241. package/dist/collection/components/Collapse/collapse.css +2 -0
  242. package/dist/collection/components/ColorPicker/ColorPicker.js +416 -0
  243. package/dist/collection/components/ColorPicker/ColorPicker.js.map +1 -0
  244. package/dist/collection/components/ColorPicker/color-picker.css +203 -0
  245. package/dist/collection/components/ColorPickerPanel/ColorPickerPanel.js +195 -0
  246. package/dist/collection/components/ColorPickerPanel/ColorPickerPanel.js.map +1 -0
  247. package/dist/collection/components/ColorPickerPanel/color-picker-panel.css +127 -0
  248. package/dist/collection/components/ConfigProvider/ConfigProvider.js +103 -0
  249. package/dist/collection/components/ConfigProvider/ConfigProvider.js.map +1 -0
  250. package/dist/collection/components/Container/Aside.js +54 -0
  251. package/dist/collection/components/Container/Aside.js.map +1 -0
  252. package/dist/collection/components/Container/Container.js +58 -0
  253. package/dist/collection/components/Container/Container.js.map +1 -0
  254. package/dist/collection/components/Container/Footer.js +54 -0
  255. package/dist/collection/components/Container/Footer.js.map +1 -0
  256. package/dist/collection/components/Container/Header.js +54 -0
  257. package/dist/collection/components/Container/Header.js.map +1 -0
  258. package/dist/collection/components/Container/Main.js +23 -0
  259. package/dist/collection/components/Container/Main.js.map +1 -0
  260. package/dist/collection/components/Container/aside.css +15 -0
  261. package/dist/collection/components/Container/container.css +41 -0
  262. package/dist/collection/components/Container/footer.css +15 -0
  263. package/dist/collection/components/Container/header.css +15 -0
  264. package/dist/collection/components/Container/main.css +14 -0
  265. package/dist/collection/components/DatePicker/DatePicker.js +402 -0
  266. package/dist/collection/components/DatePicker/DatePicker.js.map +1 -0
  267. package/dist/collection/components/DatePicker/date-picker.css +209 -0
  268. package/dist/collection/components/DatePickerPane/DatePickerPane.js +276 -0
  269. package/dist/collection/components/DatePickerPane/DatePickerPane.js.map +1 -0
  270. package/dist/collection/components/DatePickerPane/date-picker-pane.css +140 -0
  271. package/dist/collection/components/DateRangePicker/DateRangePicker.js +438 -0
  272. package/dist/collection/components/DateRangePicker/DateRangePicker.js.map +1 -0
  273. package/dist/collection/components/DateRangePicker/date-range-picker.css +200 -0
  274. package/dist/collection/components/DateTimePicker/DateTimePicker.js +341 -0
  275. package/dist/collection/components/DateTimePicker/DateTimePicker.js.map +1 -0
  276. package/dist/collection/components/DateTimePicker/date-time-picker.css +168 -0
  277. package/dist/collection/components/Descriptions/Descriptions.js +141 -0
  278. package/dist/collection/components/Descriptions/Descriptions.js.map +1 -0
  279. package/dist/collection/components/Descriptions/descriptions.css +52 -0
  280. package/dist/collection/components/Dialog/Dialog.js +348 -0
  281. package/dist/collection/components/Dialog/Dialog.js.map +1 -0
  282. package/dist/collection/components/Dialog/dialog.css +113 -0
  283. package/dist/collection/components/Divider/Divider.js +102 -0
  284. package/dist/collection/components/Divider/Divider.js.map +1 -0
  285. package/dist/collection/components/Divider/divider.css +40 -0
  286. package/dist/collection/components/Drawer/Drawer.js +289 -0
  287. package/dist/collection/components/Drawer/Drawer.js.map +1 -0
  288. package/dist/collection/components/Drawer/drawer.css +18 -0
  289. package/dist/collection/components/Dropdown/Dropdown.js +172 -0
  290. package/dist/collection/components/Dropdown/Dropdown.js.map +1 -0
  291. package/dist/collection/components/Dropdown/dropdown.css +62 -0
  292. package/dist/collection/components/Empty/Empty.js +64 -0
  293. package/dist/collection/components/Empty/Empty.js.map +1 -0
  294. package/dist/collection/components/Empty/empty.css +6 -0
  295. package/dist/collection/components/FloatButton/FloatButton.js +223 -0
  296. package/dist/collection/components/FloatButton/FloatButton.js.map +1 -0
  297. package/dist/collection/components/FloatButton/float-button.css +101 -0
  298. package/dist/collection/components/Form/Form.js +271 -0
  299. package/dist/collection/components/Form/Form.js.map +1 -0
  300. package/dist/collection/components/Form/FormItem.js +300 -0
  301. package/dist/collection/components/Form/FormItem.js.map +1 -0
  302. package/dist/collection/components/Form/form-item.css +43 -0
  303. package/dist/collection/components/Form/form.css +15 -0
  304. package/dist/collection/components/Icon/Icon.js +162 -0
  305. package/dist/collection/components/Icon/Icon.js.map +1 -0
  306. package/dist/collection/components/Icon/icon.css +43 -0
  307. package/dist/collection/components/Image/Image.js +200 -0
  308. package/dist/collection/components/Image/Image.js.map +1 -0
  309. package/dist/collection/components/Image/image.css +7 -0
  310. package/dist/collection/components/ImagePreview/ImagePreview.js +371 -0
  311. package/dist/collection/components/ImagePreview/ImagePreview.js.map +1 -0
  312. package/dist/collection/components/ImagePreview/image-preview.css +125 -0
  313. package/dist/collection/components/Input/Input.js +717 -0
  314. package/dist/collection/components/Input/Input.js.map +1 -0
  315. package/dist/collection/components/Input/input.css +144 -0
  316. package/dist/collection/components/InputNumber/InputNumber.js +510 -0
  317. package/dist/collection/components/InputNumber/InputNumber.js.map +1 -0
  318. package/dist/collection/components/InputNumber/input-number.css +168 -0
  319. package/dist/collection/components/InputTag/InputTag.js +427 -0
  320. package/dist/collection/components/InputTag/InputTag.js.map +1 -0
  321. package/dist/collection/components/InputTag/input-tag.css +159 -0
  322. package/dist/collection/components/Layout/Layout.js +270 -0
  323. package/dist/collection/components/Layout/Layout.js.map +1 -0
  324. package/dist/collection/components/Layout/Row.js +147 -0
  325. package/dist/collection/components/Layout/Row.js.map +1 -0
  326. package/dist/collection/components/Layout/layout.css +89 -0
  327. package/dist/collection/components/Layout/row.css +56 -0
  328. package/dist/collection/components/Link/Link.js +220 -0
  329. package/dist/collection/components/Link/Link.js.map +1 -0
  330. package/dist/collection/components/Link/link.css +87 -0
  331. package/dist/collection/components/Loading/Loading.js +96 -0
  332. package/dist/collection/components/Loading/Loading.js.map +1 -0
  333. package/dist/collection/components/Loading/loading.css +58 -0
  334. package/dist/collection/components/Menu/Menu.js +246 -0
  335. package/dist/collection/components/Menu/Menu.js.map +1 -0
  336. package/dist/collection/components/Menu/MenuItem.js +128 -0
  337. package/dist/collection/components/Menu/MenuItem.js.map +1 -0
  338. package/dist/collection/components/Menu/SubMenu.js +140 -0
  339. package/dist/collection/components/Menu/SubMenu.js.map +1 -0
  340. package/dist/collection/components/Menu/menu.css +143 -0
  341. package/dist/collection/components/Message/Message.js +139 -0
  342. package/dist/collection/components/Message/Message.js.map +1 -0
  343. package/dist/collection/components/Message/show-message.js +24 -0
  344. package/dist/collection/components/Message/show-message.js.map +1 -0
  345. package/dist/collection/components/Notification/Notification.js +262 -0
  346. package/dist/collection/components/Notification/Notification.js.map +1 -0
  347. package/dist/collection/components/Notification/notification.css +160 -0
  348. package/dist/collection/components/Notification/notify.js +53 -0
  349. package/dist/collection/components/Notification/notify.js.map +1 -0
  350. package/dist/collection/components/PageHeader/PageHeader.js +139 -0
  351. package/dist/collection/components/PageHeader/PageHeader.js.map +1 -0
  352. package/dist/collection/components/PageHeader/page-header.css +39 -0
  353. package/dist/collection/components/Pagination/Pagination.js +309 -0
  354. package/dist/collection/components/Pagination/Pagination.js.map +1 -0
  355. package/dist/collection/components/Pagination/pagination.css +83 -0
  356. package/dist/collection/components/Popconfirm/Popconfirm.js +185 -0
  357. package/dist/collection/components/Popconfirm/Popconfirm.js.map +1 -0
  358. package/dist/collection/components/Popconfirm/popconfirm.css +20 -0
  359. package/dist/collection/components/Popover/Popover.js +173 -0
  360. package/dist/collection/components/Popover/Popover.js.map +1 -0
  361. package/dist/collection/components/Popover/popover.css +10 -0
  362. package/dist/collection/components/Progress/Progress.js +139 -0
  363. package/dist/collection/components/Progress/Progress.js.map +1 -0
  364. package/dist/collection/components/Progress/progress.css +5 -0
  365. package/dist/collection/components/Radio/Radio.js +338 -0
  366. package/dist/collection/components/Radio/Radio.js.map +1 -0
  367. package/dist/collection/components/Radio/radio.css +158 -0
  368. package/dist/collection/components/Rate/Rate.js +357 -0
  369. package/dist/collection/components/Rate/Rate.js.map +1 -0
  370. package/dist/collection/components/Rate/rate.css +56 -0
  371. package/dist/collection/components/Result/Result.js +146 -0
  372. package/dist/collection/components/Result/Result.js.map +1 -0
  373. package/dist/collection/components/Result/result.css +47 -0
  374. package/dist/collection/components/Scrollbar/Scrollbar.js +426 -0
  375. package/dist/collection/components/Scrollbar/Scrollbar.js.map +1 -0
  376. package/dist/collection/components/Scrollbar/scrollbar.css +85 -0
  377. package/dist/collection/components/Segmented/Segmented.js +149 -0
  378. package/dist/collection/components/Segmented/Segmented.js.map +1 -0
  379. package/dist/collection/components/Segmented/segmented.css +46 -0
  380. package/dist/collection/components/Select/Select.js +595 -0
  381. package/dist/collection/components/Select/Select.js.map +1 -0
  382. package/dist/collection/components/Select/select.css +223 -0
  383. package/dist/collection/components/Skeleton/Skeleton.js +178 -0
  384. package/dist/collection/components/Skeleton/Skeleton.js.map +1 -0
  385. package/dist/collection/components/Skeleton/skeleton.css +59 -0
  386. package/dist/collection/components/Slider/Slider.js +434 -0
  387. package/dist/collection/components/Slider/Slider.js.map +1 -0
  388. package/dist/collection/components/Slider/slider.css +141 -0
  389. package/dist/collection/components/Space/Space.js +212 -0
  390. package/dist/collection/components/Space/Space.js.map +1 -0
  391. package/dist/collection/components/Space/space.css +57 -0
  392. package/dist/collection/components/Statistic/Statistic.js +188 -0
  393. package/dist/collection/components/Statistic/Statistic.js.map +1 -0
  394. package/dist/collection/components/Statistic/statistic.css +32 -0
  395. package/dist/collection/components/Steps/Step.js +95 -0
  396. package/dist/collection/components/Steps/Step.js.map +1 -0
  397. package/dist/collection/components/Steps/Steps.js +137 -0
  398. package/dist/collection/components/Steps/Steps.js.map +1 -0
  399. package/dist/collection/components/Steps/steps.css +25 -0
  400. package/dist/collection/components/Switch/Switch.js +324 -0
  401. package/dist/collection/components/Switch/Switch.js.map +1 -0
  402. package/dist/collection/components/Switch/switch.css +85 -0
  403. package/dist/collection/components/Table/Table.js +860 -0
  404. package/dist/collection/components/Table/Table.js.map +1 -0
  405. package/dist/collection/components/Table/table.css +289 -0
  406. package/dist/collection/components/Tabs/TabPane.js +82 -0
  407. package/dist/collection/components/Tabs/TabPane.js.map +1 -0
  408. package/dist/collection/components/Tabs/Tabs.js +221 -0
  409. package/dist/collection/components/Tabs/Tabs.js.map +1 -0
  410. package/dist/collection/components/Tabs/tabs.css +66 -0
  411. package/dist/collection/components/Tag/Tag.js +167 -0
  412. package/dist/collection/components/Tag/Tag.js.map +1 -0
  413. package/dist/collection/components/Tag/tag.css +71 -0
  414. package/dist/collection/components/Text/Text.js +203 -0
  415. package/dist/collection/components/Text/Text.js.map +1 -0
  416. package/dist/collection/components/Text/text.css +61 -0
  417. package/dist/collection/components/TimePicker/TimePicker.js +348 -0
  418. package/dist/collection/components/TimePicker/TimePicker.js.map +1 -0
  419. package/dist/collection/components/TimePicker/time-picker.css +151 -0
  420. package/dist/collection/components/TimeSelect/TimeSelect.js +389 -0
  421. package/dist/collection/components/TimeSelect/TimeSelect.js.map +1 -0
  422. package/dist/collection/components/TimeSelect/time-select.css +139 -0
  423. package/dist/collection/components/Timeline/Timeline.js +79 -0
  424. package/dist/collection/components/Timeline/Timeline.js.map +1 -0
  425. package/dist/collection/components/Timeline/timeline.css +71 -0
  426. package/dist/collection/components/Tooltip/Tooltip.js +192 -0
  427. package/dist/collection/components/Tooltip/Tooltip.js.map +1 -0
  428. package/dist/collection/components/Tooltip/tooltip.css +40 -0
  429. package/dist/collection/components/Tour/Tour.js +225 -0
  430. package/dist/collection/components/Tour/Tour.js.map +1 -0
  431. package/dist/collection/components/Tour/tour.css +117 -0
  432. package/dist/collection/components/Transfer/Transfer.js +331 -0
  433. package/dist/collection/components/Transfer/Transfer.js.map +1 -0
  434. package/dist/collection/components/Transfer/transfer.css +183 -0
  435. package/dist/collection/components/Tree/Tree.js +527 -0
  436. package/dist/collection/components/Tree/Tree.js.map +1 -0
  437. package/dist/collection/components/Tree/tree.css +132 -0
  438. package/dist/collection/components/TreeSelect/TreeSelect.js +440 -0
  439. package/dist/collection/components/TreeSelect/TreeSelect.js.map +1 -0
  440. package/dist/collection/components/TreeSelect/tree-select.css +209 -0
  441. package/dist/collection/components/Upload/Upload.js +504 -0
  442. package/dist/collection/components/Upload/Upload.js.map +1 -0
  443. package/dist/collection/components/Upload/upload.css +16 -0
  444. package/dist/collection/components/Watermark/Watermark.js +205 -0
  445. package/dist/collection/components/Watermark/Watermark.js.map +1 -0
  446. package/dist/collection/components/Watermark/watermark.css +26 -0
  447. package/dist/collection/index.js +2 -0
  448. package/dist/collection/index.js.map +1 -0
  449. package/dist/collection/utils/a11y.js +130 -0
  450. package/dist/collection/utils/a11y.js.map +1 -0
  451. package/dist/collection/utils/click-outside.js +22 -0
  452. package/dist/collection/utils/click-outside.js.map +1 -0
  453. package/dist/collection/utils/date-helpers.js +120 -0
  454. package/dist/collection/utils/date-helpers.js.map +1 -0
  455. package/dist/collection/utils/form-input-base.js +48 -0
  456. package/dist/collection/utils/form-input-base.js.map +1 -0
  457. package/dist/collection/utils/popup-manager.js +75 -0
  458. package/dist/collection/utils/popup-manager.js.map +1 -0
  459. package/dist/components/hb-affix.d.ts +11 -0
  460. package/dist/components/hb-affix.js +121 -0
  461. package/dist/components/hb-affix.js.map +1 -0
  462. package/dist/components/hb-alert.d.ts +11 -0
  463. package/dist/components/hb-alert.js +70 -0
  464. package/dist/components/hb-alert.js.map +1 -0
  465. package/dist/components/hb-anchor.d.ts +11 -0
  466. package/dist/components/hb-anchor.js +66 -0
  467. package/dist/components/hb-anchor.js.map +1 -0
  468. package/dist/components/hb-aside.d.ts +11 -0
  469. package/dist/components/hb-aside.js +47 -0
  470. package/dist/components/hb-aside.js.map +1 -0
  471. package/dist/components/hb-avatar.d.ts +11 -0
  472. package/dist/components/hb-avatar.js +52 -0
  473. package/dist/components/hb-avatar.js.map +1 -0
  474. package/dist/components/hb-backtop.d.ts +11 -0
  475. package/dist/components/hb-backtop.js +122 -0
  476. package/dist/components/hb-backtop.js.map +1 -0
  477. package/dist/components/hb-badge.d.ts +11 -0
  478. package/dist/components/hb-badge.js +56 -0
  479. package/dist/components/hb-badge.js.map +1 -0
  480. package/dist/components/hb-breadcrumb-item.d.ts +11 -0
  481. package/dist/components/hb-breadcrumb-item.js +42 -0
  482. package/dist/components/hb-breadcrumb-item.js.map +1 -0
  483. package/dist/components/hb-breadcrumb.d.ts +11 -0
  484. package/dist/components/hb-breadcrumb.js +41 -0
  485. package/dist/components/hb-breadcrumb.js.map +1 -0
  486. package/dist/components/hb-button.d.ts +11 -0
  487. package/dist/components/hb-button.js +60 -0
  488. package/dist/components/hb-button.js.map +1 -0
  489. package/dist/components/hb-calendar.d.ts +11 -0
  490. package/dist/components/hb-calendar.js +113 -0
  491. package/dist/components/hb-calendar.js.map +1 -0
  492. package/dist/components/hb-card.d.ts +11 -0
  493. package/dist/components/hb-card.js +45 -0
  494. package/dist/components/hb-card.js.map +1 -0
  495. package/dist/components/hb-carousel.d.ts +11 -0
  496. package/dist/components/hb-carousel.js +178 -0
  497. package/dist/components/hb-carousel.js.map +1 -0
  498. package/dist/components/hb-cascader.d.ts +11 -0
  499. package/dist/components/hb-cascader.js +451 -0
  500. package/dist/components/hb-cascader.js.map +1 -0
  501. package/dist/components/hb-checkbox-group.d.ts +11 -0
  502. package/dist/components/hb-checkbox-group.js +145 -0
  503. package/dist/components/hb-checkbox-group.js.map +1 -0
  504. package/dist/components/hb-checkbox.d.ts +11 -0
  505. package/dist/components/hb-checkbox.js +161 -0
  506. package/dist/components/hb-checkbox.js.map +1 -0
  507. package/dist/components/hb-collapse-item.d.ts +11 -0
  508. package/dist/components/hb-collapse-item.js +81 -0
  509. package/dist/components/hb-collapse-item.js.map +1 -0
  510. package/dist/components/hb-collapse.d.ts +11 -0
  511. package/dist/components/hb-collapse.js +58 -0
  512. package/dist/components/hb-collapse.js.map +1 -0
  513. package/dist/components/hb-color-picker-panel.d.ts +11 -0
  514. package/dist/components/hb-color-picker-panel.js +109 -0
  515. package/dist/components/hb-color-picker-panel.js.map +1 -0
  516. package/dist/components/hb-color-picker.d.ts +11 -0
  517. package/dist/components/hb-color-picker.js +293 -0
  518. package/dist/components/hb-color-picker.js.map +1 -0
  519. package/dist/components/hb-config-provider.d.ts +11 -0
  520. package/dist/components/hb-config-provider.js +62 -0
  521. package/dist/components/hb-config-provider.js.map +1 -0
  522. package/dist/components/hb-container.d.ts +11 -0
  523. package/dist/components/hb-container.js +47 -0
  524. package/dist/components/hb-container.js.map +1 -0
  525. package/dist/components/hb-date-picker-pane.d.ts +11 -0
  526. package/dist/components/hb-date-picker-pane.js +172 -0
  527. package/dist/components/hb-date-picker-pane.js.map +1 -0
  528. package/dist/components/hb-date-picker.d.ts +11 -0
  529. package/dist/components/hb-date-picker.js +170 -0
  530. package/dist/components/hb-date-picker.js.map +1 -0
  531. package/dist/components/hb-date-range-picker.d.ts +11 -0
  532. package/dist/components/hb-date-range-picker.js +254 -0
  533. package/dist/components/hb-date-range-picker.js.map +1 -0
  534. package/dist/components/hb-date-time-picker.d.ts +11 -0
  535. package/dist/components/hb-date-time-picker.js +170 -0
  536. package/dist/components/hb-date-time-picker.js.map +1 -0
  537. package/dist/components/hb-descriptions.d.ts +11 -0
  538. package/dist/components/hb-descriptions.js +53 -0
  539. package/dist/components/hb-descriptions.js.map +1 -0
  540. package/dist/components/hb-dialog.d.ts +11 -0
  541. package/dist/components/hb-dialog.js +141 -0
  542. package/dist/components/hb-dialog.js.map +1 -0
  543. package/dist/components/hb-divider.d.ts +11 -0
  544. package/dist/components/hb-divider.js +55 -0
  545. package/dist/components/hb-divider.js.map +1 -0
  546. package/dist/components/hb-drawer.d.ts +11 -0
  547. package/dist/components/hb-drawer.js +116 -0
  548. package/dist/components/hb-drawer.js.map +1 -0
  549. package/dist/components/hb-dropdown.d.ts +11 -0
  550. package/dist/components/hb-dropdown.js +100 -0
  551. package/dist/components/hb-dropdown.js.map +1 -0
  552. package/dist/components/hb-empty.d.ts +11 -0
  553. package/dist/components/hb-empty.js +42 -0
  554. package/dist/components/hb-empty.js.map +1 -0
  555. package/dist/components/hb-float-button.d.ts +11 -0
  556. package/dist/components/hb-float-button.js +80 -0
  557. package/dist/components/hb-float-button.js.map +1 -0
  558. package/dist/components/hb-footer.d.ts +11 -0
  559. package/dist/components/hb-footer.js +47 -0
  560. package/dist/components/hb-footer.js.map +1 -0
  561. package/dist/components/hb-form-item.d.ts +11 -0
  562. package/dist/components/hb-form-item.js +139 -0
  563. package/dist/components/hb-form-item.js.map +1 -0
  564. package/dist/components/hb-form.d.ts +11 -0
  565. package/dist/components/hb-form.js +96 -0
  566. package/dist/components/hb-form.js.map +1 -0
  567. package/dist/components/hb-header.d.ts +11 -0
  568. package/dist/components/hb-header.js +47 -0
  569. package/dist/components/hb-header.js.map +1 -0
  570. package/dist/components/hb-icon.d.ts +11 -0
  571. package/dist/components/hb-icon.js +96 -0
  572. package/dist/components/hb-icon.js.map +1 -0
  573. package/dist/components/hb-image-preview.d.ts +11 -0
  574. package/dist/components/hb-image-preview.js +207 -0
  575. package/dist/components/hb-image-preview.js.map +1 -0
  576. package/dist/components/hb-image.d.ts +11 -0
  577. package/dist/components/hb-image.js +62 -0
  578. package/dist/components/hb-image.js.map +1 -0
  579. package/dist/components/hb-input-number.d.ts +11 -0
  580. package/dist/components/hb-input-number.js +202 -0
  581. package/dist/components/hb-input-number.js.map +1 -0
  582. package/dist/components/hb-input-tag.d.ts +11 -0
  583. package/dist/components/hb-input-tag.js +174 -0
  584. package/dist/components/hb-input-tag.js.map +1 -0
  585. package/dist/components/hb-input.d.ts +11 -0
  586. package/dist/components/hb-input.js +294 -0
  587. package/dist/components/hb-input.js.map +1 -0
  588. package/dist/components/hb-layout.d.ts +11 -0
  589. package/dist/components/hb-layout.js +103 -0
  590. package/dist/components/hb-layout.js.map +1 -0
  591. package/dist/components/hb-link.d.ts +11 -0
  592. package/dist/components/hb-link.js +89 -0
  593. package/dist/components/hb-link.js.map +1 -0
  594. package/dist/components/hb-loading.d.ts +11 -0
  595. package/dist/components/hb-loading.js +51 -0
  596. package/dist/components/hb-loading.js.map +1 -0
  597. package/dist/components/hb-main.d.ts +11 -0
  598. package/dist/components/hb-main.js +37 -0
  599. package/dist/components/hb-main.js.map +1 -0
  600. package/dist/components/hb-menu-item.d.ts +11 -0
  601. package/dist/components/hb-menu-item.js +70 -0
  602. package/dist/components/hb-menu-item.js.map +1 -0
  603. package/dist/components/hb-menu.d.ts +11 -0
  604. package/dist/components/hb-menu.js +113 -0
  605. package/dist/components/hb-menu.js.map +1 -0
  606. package/dist/components/hb-message.d.ts +11 -0
  607. package/dist/components/hb-message.js +69 -0
  608. package/dist/components/hb-message.js.map +1 -0
  609. package/dist/components/hb-notification.d.ts +11 -0
  610. package/dist/components/hb-notification.js +91 -0
  611. package/dist/components/hb-notification.js.map +1 -0
  612. package/dist/components/hb-page-header.d.ts +11 -0
  613. package/dist/components/hb-page-header.js +57 -0
  614. package/dist/components/hb-page-header.js.map +1 -0
  615. package/dist/components/hb-pagination.d.ts +11 -0
  616. package/dist/components/hb-pagination.js +134 -0
  617. package/dist/components/hb-pagination.js.map +1 -0
  618. package/dist/components/hb-popconfirm.d.ts +11 -0
  619. package/dist/components/hb-popconfirm.js +75 -0
  620. package/dist/components/hb-popconfirm.js.map +1 -0
  621. package/dist/components/hb-popover.d.ts +11 -0
  622. package/dist/components/hb-popover.js +82 -0
  623. package/dist/components/hb-popover.js.map +1 -0
  624. package/dist/components/hb-progress.d.ts +11 -0
  625. package/dist/components/hb-progress.js +60 -0
  626. package/dist/components/hb-progress.js.map +1 -0
  627. package/dist/components/hb-radio.d.ts +11 -0
  628. package/dist/components/hb-radio.js +149 -0
  629. package/dist/components/hb-radio.js.map +1 -0
  630. package/dist/components/hb-rate.d.ts +11 -0
  631. package/dist/components/hb-rate.js +161 -0
  632. package/dist/components/hb-rate.js.map +1 -0
  633. package/dist/components/hb-result.d.ts +11 -0
  634. package/dist/components/hb-result.js +77 -0
  635. package/dist/components/hb-result.js.map +1 -0
  636. package/dist/components/hb-row.d.ts +11 -0
  637. package/dist/components/hb-row.js +77 -0
  638. package/dist/components/hb-row.js.map +1 -0
  639. package/dist/components/hb-scrollbar.d.ts +11 -0
  640. package/dist/components/hb-scrollbar.js +235 -0
  641. package/dist/components/hb-scrollbar.js.map +1 -0
  642. package/dist/components/hb-segmented.d.ts +11 -0
  643. package/dist/components/hb-segmented.js +63 -0
  644. package/dist/components/hb-segmented.js.map +1 -0
  645. package/dist/components/hb-select.d.ts +11 -0
  646. package/dist/components/hb-select.js +299 -0
  647. package/dist/components/hb-select.js.map +1 -0
  648. package/dist/components/hb-skeleton.d.ts +11 -0
  649. package/dist/components/hb-skeleton.js +75 -0
  650. package/dist/components/hb-skeleton.js.map +1 -0
  651. package/dist/components/hb-slider.d.ts +11 -0
  652. package/dist/components/hb-slider.js +202 -0
  653. package/dist/components/hb-slider.js.map +1 -0
  654. package/dist/components/hb-space.d.ts +11 -0
  655. package/dist/components/hb-space.js +94 -0
  656. package/dist/components/hb-space.js.map +1 -0
  657. package/dist/components/hb-statistic.d.ts +11 -0
  658. package/dist/components/hb-statistic.js +88 -0
  659. package/dist/components/hb-statistic.js.map +1 -0
  660. package/dist/components/hb-step.d.ts +11 -0
  661. package/dist/components/hb-step.js +42 -0
  662. package/dist/components/hb-step.js.map +1 -0
  663. package/dist/components/hb-steps.d.ts +11 -0
  664. package/dist/components/hb-steps.js +71 -0
  665. package/dist/components/hb-steps.js.map +1 -0
  666. package/dist/components/hb-sub-menu.d.ts +11 -0
  667. package/dist/components/hb-sub-menu.js +91 -0
  668. package/dist/components/hb-sub-menu.js.map +1 -0
  669. package/dist/components/hb-switch.d.ts +11 -0
  670. package/dist/components/hb-switch.js +118 -0
  671. package/dist/components/hb-switch.js.map +1 -0
  672. package/dist/components/hb-tab-pane.d.ts +11 -0
  673. package/dist/components/hb-tab-pane.js +43 -0
  674. package/dist/components/hb-tab-pane.js.map +1 -0
  675. package/dist/components/hb-table.d.ts +11 -0
  676. package/dist/components/hb-table.js +412 -0
  677. package/dist/components/hb-table.js.map +1 -0
  678. package/dist/components/hb-tabs.d.ts +11 -0
  679. package/dist/components/hb-tabs.js +138 -0
  680. package/dist/components/hb-tabs.js.map +1 -0
  681. package/dist/components/hb-tag.d.ts +11 -0
  682. package/dist/components/hb-tag.js +66 -0
  683. package/dist/components/hb-tag.js.map +1 -0
  684. package/dist/components/hb-text.d.ts +11 -0
  685. package/dist/components/hb-text.js +82 -0
  686. package/dist/components/hb-text.js.map +1 -0
  687. package/dist/components/hb-time-picker.d.ts +11 -0
  688. package/dist/components/hb-time-picker.js +178 -0
  689. package/dist/components/hb-time-picker.js.map +1 -0
  690. package/dist/components/hb-time-select.d.ts +11 -0
  691. package/dist/components/hb-time-select.js +175 -0
  692. package/dist/components/hb-time-select.js.map +1 -0
  693. package/dist/components/hb-timeline.d.ts +11 -0
  694. package/dist/components/hb-timeline.js +48 -0
  695. package/dist/components/hb-timeline.js.map +1 -0
  696. package/dist/components/hb-tooltip.d.ts +11 -0
  697. package/dist/components/hb-tooltip.js +97 -0
  698. package/dist/components/hb-tooltip.js.map +1 -0
  699. package/dist/components/hb-tour.d.ts +11 -0
  700. package/dist/components/hb-tour.js +139 -0
  701. package/dist/components/hb-tour.js.map +1 -0
  702. package/dist/components/hb-transfer.d.ts +11 -0
  703. package/dist/components/hb-transfer.js +199 -0
  704. package/dist/components/hb-transfer.js.map +1 -0
  705. package/dist/components/hb-tree-select.d.ts +11 -0
  706. package/dist/components/hb-tree-select.js +263 -0
  707. package/dist/components/hb-tree-select.js.map +1 -0
  708. package/dist/components/hb-tree.d.ts +11 -0
  709. package/dist/components/hb-tree.js +344 -0
  710. package/dist/components/hb-tree.js.map +1 -0
  711. package/dist/components/hb-upload.d.ts +11 -0
  712. package/dist/components/hb-upload.js +213 -0
  713. package/dist/components/hb-upload.js.map +1 -0
  714. package/dist/components/hb-watermark.d.ts +11 -0
  715. package/dist/components/hb-watermark.js +82 -0
  716. package/dist/components/hb-watermark.js.map +1 -0
  717. package/dist/components/index.d.ts +33 -0
  718. package/dist/components/index.js +3 -0
  719. package/dist/components/index.js.map +1 -0
  720. package/dist/components/p-1407a5e8.js +1662 -0
  721. package/dist/components/p-1407a5e8.js.map +1 -0
  722. package/dist/components/p-4ef5a884.js +25 -0
  723. package/dist/components/p-4ef5a884.js.map +1 -0
  724. package/dist/components/p-cc0aeb50.js +119 -0
  725. package/dist/components/p-cc0aeb50.js.map +1 -0
  726. package/dist/components/p-cf94cbf6.js +123 -0
  727. package/dist/components/p-cf94cbf6.js.map +1 -0
  728. package/dist/components/p-ecce2b5e.js +78 -0
  729. package/dist/components/p-ecce2b5e.js.map +1 -0
  730. package/dist/esm/a11y-f9ab2964.js +119 -0
  731. package/dist/esm/a11y-f9ab2964.js.map +1 -0
  732. package/dist/esm/app-globals-0f993ce5.js +5 -0
  733. package/dist/esm/app-globals-0f993ce5.js.map +1 -0
  734. package/dist/esm/click-outside-291294f9.js +25 -0
  735. package/dist/esm/click-outside-291294f9.js.map +1 -0
  736. package/dist/esm/date-helpers-e4d85a67.js +123 -0
  737. package/dist/esm/date-helpers-e4d85a67.js.map +1 -0
  738. package/dist/esm/hb-affix.entry.js +97 -0
  739. package/dist/esm/hb-affix.entry.js.map +1 -0
  740. package/dist/esm/hb-alert.entry.js +43 -0
  741. package/dist/esm/hb-alert.entry.js.map +1 -0
  742. package/dist/esm/hb-anchor.entry.js +42 -0
  743. package/dist/esm/hb-anchor.entry.js.map +1 -0
  744. package/dist/esm/hb-aside.entry.js +26 -0
  745. package/dist/esm/hb-aside.entry.js.map +1 -0
  746. package/dist/esm/hb-avatar.entry.js +27 -0
  747. package/dist/esm/hb-avatar.entry.js.map +1 -0
  748. package/dist/esm/hb-backtop.entry.js +96 -0
  749. package/dist/esm/hb-backtop.entry.js.map +1 -0
  750. package/dist/esm/hb-badge.entry.js +31 -0
  751. package/dist/esm/hb-badge.entry.js.map +1 -0
  752. package/dist/esm/hb-breadcrumb-item.entry.js +21 -0
  753. package/dist/esm/hb-breadcrumb-item.entry.js.map +1 -0
  754. package/dist/esm/hb-breadcrumb.entry.js +20 -0
  755. package/dist/esm/hb-breadcrumb.entry.js.map +1 -0
  756. package/dist/esm/hb-button.entry.js +35 -0
  757. package/dist/esm/hb-button.entry.js.map +1 -0
  758. package/dist/esm/hb-calendar.entry.js +86 -0
  759. package/dist/esm/hb-calendar.entry.js.map +1 -0
  760. package/dist/esm/hb-card.entry.js +23 -0
  761. package/dist/esm/hb-card.entry.js.map +1 -0
  762. package/dist/esm/hb-carousel.entry.js +146 -0
  763. package/dist/esm/hb-carousel.entry.js.map +1 -0
  764. package/dist/esm/hb-cascader.entry.js +409 -0
  765. package/dist/esm/hb-cascader.entry.js.map +1 -0
  766. package/dist/esm/hb-checkbox-group.entry.js +113 -0
  767. package/dist/esm/hb-checkbox-group.entry.js.map +1 -0
  768. package/dist/esm/hb-checkbox.entry.js +126 -0
  769. package/dist/esm/hb-checkbox.entry.js.map +1 -0
  770. package/dist/esm/hb-collapse-item.entry.js +54 -0
  771. package/dist/esm/hb-collapse-item.entry.js.map +1 -0
  772. package/dist/esm/hb-collapse.entry.js +37 -0
  773. package/dist/esm/hb-collapse.entry.js.map +1 -0
  774. package/dist/esm/hb-color-picker-panel.entry.js +82 -0
  775. package/dist/esm/hb-color-picker-panel.entry.js.map +1 -0
  776. package/dist/esm/hb-color-picker.entry.js +261 -0
  777. package/dist/esm/hb-color-picker.entry.js.map +1 -0
  778. package/dist/esm/hb-config-provider.entry.js +40 -0
  779. package/dist/esm/hb-config-provider.entry.js.map +1 -0
  780. package/dist/esm/hb-container.entry.js +26 -0
  781. package/dist/esm/hb-container.entry.js.map +1 -0
  782. package/dist/esm/hb-date-picker-pane.entry.js +146 -0
  783. package/dist/esm/hb-date-picker-pane.entry.js.map +1 -0
  784. package/dist/esm/hb-date-picker.entry.js +134 -0
  785. package/dist/esm/hb-date-picker.entry.js.map +1 -0
  786. package/dist/esm/hb-date-range-picker.entry.js +218 -0
  787. package/dist/esm/hb-date-range-picker.entry.js.map +1 -0
  788. package/dist/esm/hb-date-time-picker.entry.js +136 -0
  789. package/dist/esm/hb-date-time-picker.entry.js.map +1 -0
  790. package/dist/esm/hb-descriptions.entry.js +28 -0
  791. package/dist/esm/hb-descriptions.entry.js.map +1 -0
  792. package/dist/esm/hb-dialog.entry.js +110 -0
  793. package/dist/esm/hb-dialog.entry.js.map +1 -0
  794. package/dist/esm/hb-divider.entry.js +32 -0
  795. package/dist/esm/hb-divider.entry.js.map +1 -0
  796. package/dist/esm/hb-drawer.entry.js +85 -0
  797. package/dist/esm/hb-drawer.entry.js.map +1 -0
  798. package/dist/esm/hb-dropdown.entry.js +76 -0
  799. package/dist/esm/hb-dropdown.entry.js.map +1 -0
  800. package/dist/esm/hb-empty.entry.js +20 -0
  801. package/dist/esm/hb-empty.entry.js.map +1 -0
  802. package/dist/esm/hb-float-button.entry.js +53 -0
  803. package/dist/esm/hb-float-button.entry.js.map +1 -0
  804. package/dist/esm/hb-footer.entry.js +26 -0
  805. package/dist/esm/hb-footer.entry.js.map +1 -0
  806. package/dist/esm/hb-form-item.entry.js +108 -0
  807. package/dist/esm/hb-form-item.entry.js.map +1 -0
  808. package/dist/esm/hb-form.entry.js +66 -0
  809. package/dist/esm/hb-form.entry.js.map +1 -0
  810. package/dist/esm/hb-header.entry.js +26 -0
  811. package/dist/esm/hb-header.entry.js.map +1 -0
  812. package/dist/esm/hb-icon.entry.js +72 -0
  813. package/dist/esm/hb-icon.entry.js.map +1 -0
  814. package/dist/esm/hb-image-preview.entry.js +175 -0
  815. package/dist/esm/hb-image-preview.entry.js.map +1 -0
  816. package/dist/esm/hb-image.entry.js +31 -0
  817. package/dist/esm/hb-image.entry.js.map +1 -0
  818. package/dist/esm/hb-input-number.entry.js +165 -0
  819. package/dist/esm/hb-input-number.entry.js.map +1 -0
  820. package/dist/esm/hb-input-tag.entry.js +141 -0
  821. package/dist/esm/hb-input-tag.entry.js.map +1 -0
  822. package/dist/esm/hb-input.entry.js +248 -0
  823. package/dist/esm/hb-input.entry.js.map +1 -0
  824. package/dist/esm/hb-layout.entry.js +74 -0
  825. package/dist/esm/hb-layout.entry.js.map +1 -0
  826. package/dist/esm/hb-link.entry.js +63 -0
  827. package/dist/esm/hb-link.entry.js.map +1 -0
  828. package/dist/esm/hb-loading.entry.js +28 -0
  829. package/dist/esm/hb-loading.entry.js.map +1 -0
  830. package/dist/esm/hb-main.entry.js +18 -0
  831. package/dist/esm/hb-main.entry.js.map +1 -0
  832. package/dist/esm/hb-menu-item.entry.js +46 -0
  833. package/dist/esm/hb-menu-item.entry.js.map +1 -0
  834. package/dist/esm/hb-menu.entry.js +83 -0
  835. package/dist/esm/hb-menu.entry.js.map +1 -0
  836. package/dist/esm/hb-message.entry.js +44 -0
  837. package/dist/esm/hb-message.entry.js.map +1 -0
  838. package/dist/esm/hb-notification.entry.js +63 -0
  839. package/dist/esm/hb-notification.entry.js.map +1 -0
  840. package/dist/esm/hb-page-header.entry.js +33 -0
  841. package/dist/esm/hb-page-header.entry.js.map +1 -0
  842. package/dist/esm/hb-pagination.entry.js +103 -0
  843. package/dist/esm/hb-pagination.entry.js.map +1 -0
  844. package/dist/esm/hb-popconfirm.entry.js +47 -0
  845. package/dist/esm/hb-popconfirm.entry.js.map +1 -0
  846. package/dist/esm/hb-popover.entry.js +55 -0
  847. package/dist/esm/hb-popover.entry.js.map +1 -0
  848. package/dist/esm/hb-progress.entry.js +35 -0
  849. package/dist/esm/hb-progress.entry.js.map +1 -0
  850. package/dist/esm/hb-radio.entry.js +115 -0
  851. package/dist/esm/hb-radio.entry.js.map +1 -0
  852. package/dist/esm/hb-rate.entry.js +128 -0
  853. package/dist/esm/hb-rate.entry.js.map +1 -0
  854. package/dist/esm/hb-result.entry.js +53 -0
  855. package/dist/esm/hb-result.entry.js.map +1 -0
  856. package/dist/esm/hb-row.entry.js +53 -0
  857. package/dist/esm/hb-row.entry.js.map +1 -0
  858. package/dist/esm/hb-scrollbar.entry.js +200 -0
  859. package/dist/esm/hb-scrollbar.entry.js.map +1 -0
  860. package/dist/esm/hb-segmented.entry.js +39 -0
  861. package/dist/esm/hb-segmented.entry.js.map +1 -0
  862. package/dist/esm/hb-select.entry.js +258 -0
  863. package/dist/esm/hb-select.entry.js.map +1 -0
  864. package/dist/esm/hb-skeleton.entry.js +49 -0
  865. package/dist/esm/hb-skeleton.entry.js.map +1 -0
  866. package/dist/esm/hb-slider.entry.js +168 -0
  867. package/dist/esm/hb-slider.entry.js.map +1 -0
  868. package/dist/esm/hb-space.entry.js +68 -0
  869. package/dist/esm/hb-space.entry.js.map +1 -0
  870. package/dist/esm/hb-statistic.entry.js +62 -0
  871. package/dist/esm/hb-statistic.entry.js.map +1 -0
  872. package/dist/esm/hb-step.entry.js +20 -0
  873. package/dist/esm/hb-step.entry.js.map +1 -0
  874. package/dist/esm/hb-steps.entry.js +46 -0
  875. package/dist/esm/hb-steps.entry.js.map +1 -0
  876. package/dist/esm/hb-sub-menu.entry.js +66 -0
  877. package/dist/esm/hb-sub-menu.entry.js.map +1 -0
  878. package/dist/esm/hb-switch.entry.js +88 -0
  879. package/dist/esm/hb-switch.entry.js.map +1 -0
  880. package/dist/esm/hb-tab-pane.entry.js +22 -0
  881. package/dist/esm/hb-tab-pane.entry.js.map +1 -0
  882. package/dist/esm/hb-table.entry.js +366 -0
  883. package/dist/esm/hb-table.entry.js.map +1 -0
  884. package/dist/esm/hb-tabs.entry.js +111 -0
  885. package/dist/esm/hb-tabs.entry.js.map +1 -0
  886. package/dist/esm/hb-tag.entry.js +41 -0
  887. package/dist/esm/hb-tag.entry.js.map +1 -0
  888. package/dist/esm/hb-text.entry.js +56 -0
  889. package/dist/esm/hb-text.entry.js.map +1 -0
  890. package/dist/esm/hb-time-picker.entry.js +143 -0
  891. package/dist/esm/hb-time-picker.entry.js.map +1 -0
  892. package/dist/esm/hb-time-select.entry.js +141 -0
  893. package/dist/esm/hb-time-select.entry.js.map +1 -0
  894. package/dist/esm/hb-timeline.entry.js +26 -0
  895. package/dist/esm/hb-timeline.entry.js.map +1 -0
  896. package/dist/esm/hb-tooltip.entry.js +70 -0
  897. package/dist/esm/hb-tooltip.entry.js.map +1 -0
  898. package/dist/esm/hb-tour.entry.js +115 -0
  899. package/dist/esm/hb-tour.entry.js.map +1 -0
  900. package/dist/esm/hb-transfer.entry.js +169 -0
  901. package/dist/esm/hb-transfer.entry.js.map +1 -0
  902. package/dist/esm/hb-tree-select.entry.js +232 -0
  903. package/dist/esm/hb-tree-select.entry.js.map +1 -0
  904. package/dist/esm/hb-tree.entry.js +309 -0
  905. package/dist/esm/hb-tree.entry.js.map +1 -0
  906. package/dist/esm/hb-upload.entry.js +180 -0
  907. package/dist/esm/hb-upload.entry.js.map +1 -0
  908. package/dist/esm/hb-watermark.entry.js +55 -0
  909. package/dist/esm/hb-watermark.entry.js.map +1 -0
  910. package/dist/esm/huibo-ui.js +22 -0
  911. package/dist/esm/huibo-ui.js.map +1 -0
  912. package/dist/esm/index-fdf7135e.js +1886 -0
  913. package/dist/esm/index-fdf7135e.js.map +1 -0
  914. package/dist/esm/index.js +3 -0
  915. package/dist/esm/index.js.map +1 -0
  916. package/dist/esm/loader.js +13 -0
  917. package/dist/esm/loader.js.map +1 -0
  918. package/dist/esm/popup-manager-128cc685.js +78 -0
  919. package/dist/esm/popup-manager-128cc685.js.map +1 -0
  920. package/dist/huibo-ui/huibo-ui.css +6 -0
  921. package/dist/huibo-ui/huibo-ui.esm.js +2 -0
  922. package/dist/huibo-ui/huibo-ui.esm.js.map +1 -0
  923. package/dist/huibo-ui/index.esm.js +2 -0
  924. package/dist/huibo-ui/index.esm.js.map +1 -0
  925. package/dist/huibo-ui/p-003cee87.entry.js +2 -0
  926. package/dist/huibo-ui/p-003cee87.entry.js.map +1 -0
  927. package/dist/huibo-ui/p-06ec8d02.entry.js +2 -0
  928. package/dist/huibo-ui/p-06ec8d02.entry.js.map +1 -0
  929. package/dist/huibo-ui/p-079a4130.entry.js +2 -0
  930. package/dist/huibo-ui/p-079a4130.entry.js.map +1 -0
  931. package/dist/huibo-ui/p-0a033738.entry.js +2 -0
  932. package/dist/huibo-ui/p-0a033738.entry.js.map +1 -0
  933. package/dist/huibo-ui/p-0bef78ac.entry.js +2 -0
  934. package/dist/huibo-ui/p-0bef78ac.entry.js.map +1 -0
  935. package/dist/huibo-ui/p-0e65e1bd.entry.js +2 -0
  936. package/dist/huibo-ui/p-0e65e1bd.entry.js.map +1 -0
  937. package/dist/huibo-ui/p-0f189251.entry.js +2 -0
  938. package/dist/huibo-ui/p-0f189251.entry.js.map +1 -0
  939. package/dist/huibo-ui/p-10c088f3.entry.js +2 -0
  940. package/dist/huibo-ui/p-10c088f3.entry.js.map +1 -0
  941. package/dist/huibo-ui/p-1b5acd6d.entry.js +2 -0
  942. package/dist/huibo-ui/p-1b5acd6d.entry.js.map +1 -0
  943. package/dist/huibo-ui/p-1e5abc8a.entry.js +2 -0
  944. package/dist/huibo-ui/p-1e5abc8a.entry.js.map +1 -0
  945. package/dist/huibo-ui/p-1f0b1662.entry.js +2 -0
  946. package/dist/huibo-ui/p-1f0b1662.entry.js.map +1 -0
  947. package/dist/huibo-ui/p-21682e92.entry.js +2 -0
  948. package/dist/huibo-ui/p-21682e92.entry.js.map +1 -0
  949. package/dist/huibo-ui/p-231a7335.entry.js +2 -0
  950. package/dist/huibo-ui/p-231a7335.entry.js.map +1 -0
  951. package/dist/huibo-ui/p-24ad7eec.entry.js +2 -0
  952. package/dist/huibo-ui/p-24ad7eec.entry.js.map +1 -0
  953. package/dist/huibo-ui/p-2b286698.entry.js +2 -0
  954. package/dist/huibo-ui/p-2b286698.entry.js.map +1 -0
  955. package/dist/huibo-ui/p-2e6584ea.entry.js +2 -0
  956. package/dist/huibo-ui/p-2e6584ea.entry.js.map +1 -0
  957. package/dist/huibo-ui/p-315feadf.entry.js +2 -0
  958. package/dist/huibo-ui/p-315feadf.entry.js.map +1 -0
  959. package/dist/huibo-ui/p-332c8877.entry.js +2 -0
  960. package/dist/huibo-ui/p-332c8877.entry.js.map +1 -0
  961. package/dist/huibo-ui/p-3c7f73c8.entry.js +2 -0
  962. package/dist/huibo-ui/p-3c7f73c8.entry.js.map +1 -0
  963. package/dist/huibo-ui/p-4001c08d.entry.js +2 -0
  964. package/dist/huibo-ui/p-4001c08d.entry.js.map +1 -0
  965. package/dist/huibo-ui/p-44c48246.entry.js +2 -0
  966. package/dist/huibo-ui/p-44c48246.entry.js.map +1 -0
  967. package/dist/huibo-ui/p-463de26d.entry.js +2 -0
  968. package/dist/huibo-ui/p-463de26d.entry.js.map +1 -0
  969. package/dist/huibo-ui/p-465dcb4c.entry.js +2 -0
  970. package/dist/huibo-ui/p-465dcb4c.entry.js.map +1 -0
  971. package/dist/huibo-ui/p-476527c1.entry.js +2 -0
  972. package/dist/huibo-ui/p-476527c1.entry.js.map +1 -0
  973. package/dist/huibo-ui/p-477d8568.entry.js +2 -0
  974. package/dist/huibo-ui/p-477d8568.entry.js.map +1 -0
  975. package/dist/huibo-ui/p-4d0dff15.entry.js +2 -0
  976. package/dist/huibo-ui/p-4d0dff15.entry.js.map +1 -0
  977. package/dist/huibo-ui/p-4d8b1404.entry.js +2 -0
  978. package/dist/huibo-ui/p-4d8b1404.entry.js.map +1 -0
  979. package/dist/huibo-ui/p-4ef5a884.js +2 -0
  980. package/dist/huibo-ui/p-4ef5a884.js.map +1 -0
  981. package/dist/huibo-ui/p-58d20809.entry.js +2 -0
  982. package/dist/huibo-ui/p-58d20809.entry.js.map +1 -0
  983. package/dist/huibo-ui/p-58ebb9b3.entry.js +2 -0
  984. package/dist/huibo-ui/p-58ebb9b3.entry.js.map +1 -0
  985. package/dist/huibo-ui/p-59b2e61c.entry.js +2 -0
  986. package/dist/huibo-ui/p-59b2e61c.entry.js.map +1 -0
  987. package/dist/huibo-ui/p-5df47135.entry.js +2 -0
  988. package/dist/huibo-ui/p-5df47135.entry.js.map +1 -0
  989. package/dist/huibo-ui/p-64ca0980.entry.js +2 -0
  990. package/dist/huibo-ui/p-64ca0980.entry.js.map +1 -0
  991. package/dist/huibo-ui/p-672076c3.entry.js +2 -0
  992. package/dist/huibo-ui/p-672076c3.entry.js.map +1 -0
  993. package/dist/huibo-ui/p-6a1ec3ff.entry.js +2 -0
  994. package/dist/huibo-ui/p-6a1ec3ff.entry.js.map +1 -0
  995. package/dist/huibo-ui/p-6ac242fe.entry.js +2 -0
  996. package/dist/huibo-ui/p-6ac242fe.entry.js.map +1 -0
  997. package/dist/huibo-ui/p-6b381d0e.entry.js +2 -0
  998. package/dist/huibo-ui/p-6b381d0e.entry.js.map +1 -0
  999. package/dist/huibo-ui/p-710f38de.entry.js +2 -0
  1000. package/dist/huibo-ui/p-710f38de.entry.js.map +1 -0
  1001. package/dist/huibo-ui/p-756acbdb.entry.js +2 -0
  1002. package/dist/huibo-ui/p-756acbdb.entry.js.map +1 -0
  1003. package/dist/huibo-ui/p-75a93de3.entry.js +2 -0
  1004. package/dist/huibo-ui/p-75a93de3.entry.js.map +1 -0
  1005. package/dist/huibo-ui/p-769960f4.entry.js +2 -0
  1006. package/dist/huibo-ui/p-769960f4.entry.js.map +1 -0
  1007. package/dist/huibo-ui/p-77017274.entry.js +2 -0
  1008. package/dist/huibo-ui/p-77017274.entry.js.map +1 -0
  1009. package/dist/huibo-ui/p-7f6975ad.entry.js +2 -0
  1010. package/dist/huibo-ui/p-7f6975ad.entry.js.map +1 -0
  1011. package/dist/huibo-ui/p-80aca641.entry.js +2 -0
  1012. package/dist/huibo-ui/p-80aca641.entry.js.map +1 -0
  1013. package/dist/huibo-ui/p-85f68526.entry.js +2 -0
  1014. package/dist/huibo-ui/p-85f68526.entry.js.map +1 -0
  1015. package/dist/huibo-ui/p-88127de1.entry.js +2 -0
  1016. package/dist/huibo-ui/p-88127de1.entry.js.map +1 -0
  1017. package/dist/huibo-ui/p-8b027491.entry.js +2 -0
  1018. package/dist/huibo-ui/p-8b027491.entry.js.map +1 -0
  1019. package/dist/huibo-ui/p-8b1ae77e.entry.js +2 -0
  1020. package/dist/huibo-ui/p-8b1ae77e.entry.js.map +1 -0
  1021. package/dist/huibo-ui/p-8c80a765.entry.js +2 -0
  1022. package/dist/huibo-ui/p-8c80a765.entry.js.map +1 -0
  1023. package/dist/huibo-ui/p-8c987d57.entry.js +2 -0
  1024. package/dist/huibo-ui/p-8c987d57.entry.js.map +1 -0
  1025. package/dist/huibo-ui/p-8d615521.entry.js +2 -0
  1026. package/dist/huibo-ui/p-8d615521.entry.js.map +1 -0
  1027. package/dist/huibo-ui/p-8d925e3d.entry.js +2 -0
  1028. package/dist/huibo-ui/p-8d925e3d.entry.js.map +1 -0
  1029. package/dist/huibo-ui/p-9319c650.entry.js +2 -0
  1030. package/dist/huibo-ui/p-9319c650.entry.js.map +1 -0
  1031. package/dist/huibo-ui/p-953b9514.entry.js +2 -0
  1032. package/dist/huibo-ui/p-953b9514.entry.js.map +1 -0
  1033. package/dist/huibo-ui/p-965d4d02.entry.js +2 -0
  1034. package/dist/huibo-ui/p-965d4d02.entry.js.map +1 -0
  1035. package/dist/huibo-ui/p-a0015341.entry.js +2 -0
  1036. package/dist/huibo-ui/p-a0015341.entry.js.map +1 -0
  1037. package/dist/huibo-ui/p-a042e3d0.entry.js +2 -0
  1038. package/dist/huibo-ui/p-a042e3d0.entry.js.map +1 -0
  1039. package/dist/huibo-ui/p-ad6b0c6e.entry.js +2 -0
  1040. package/dist/huibo-ui/p-ad6b0c6e.entry.js.map +1 -0
  1041. package/dist/huibo-ui/p-b489a526.entry.js +2 -0
  1042. package/dist/huibo-ui/p-b489a526.entry.js.map +1 -0
  1043. package/dist/huibo-ui/p-be48d2aa.entry.js +2 -0
  1044. package/dist/huibo-ui/p-be48d2aa.entry.js.map +1 -0
  1045. package/dist/huibo-ui/p-c1a059d9.entry.js +2 -0
  1046. package/dist/huibo-ui/p-c1a059d9.entry.js.map +1 -0
  1047. package/dist/huibo-ui/p-c1b4eacb.entry.js +2 -0
  1048. package/dist/huibo-ui/p-c1b4eacb.entry.js.map +1 -0
  1049. package/dist/huibo-ui/p-c321c4aa.entry.js +2 -0
  1050. package/dist/huibo-ui/p-c321c4aa.entry.js.map +1 -0
  1051. package/dist/huibo-ui/p-c3e665f6.entry.js +2 -0
  1052. package/dist/huibo-ui/p-c3e665f6.entry.js.map +1 -0
  1053. package/dist/huibo-ui/p-c3e8893d.entry.js +2 -0
  1054. package/dist/huibo-ui/p-c3e8893d.entry.js.map +1 -0
  1055. package/dist/huibo-ui/p-c922d672.entry.js +2 -0
  1056. package/dist/huibo-ui/p-c922d672.entry.js.map +1 -0
  1057. package/dist/huibo-ui/p-cc0aeb50.js +2 -0
  1058. package/dist/huibo-ui/p-cc0aeb50.js.map +1 -0
  1059. package/dist/huibo-ui/p-cf94cbf6.js +2 -0
  1060. package/dist/huibo-ui/p-cf94cbf6.js.map +1 -0
  1061. package/dist/huibo-ui/p-d3939d44.entry.js +2 -0
  1062. package/dist/huibo-ui/p-d3939d44.entry.js.map +1 -0
  1063. package/dist/huibo-ui/p-d64b91ef.entry.js +2 -0
  1064. package/dist/huibo-ui/p-d64b91ef.entry.js.map +1 -0
  1065. package/dist/huibo-ui/p-d7815b4f.entry.js +2 -0
  1066. package/dist/huibo-ui/p-d7815b4f.entry.js.map +1 -0
  1067. package/dist/huibo-ui/p-d87fc21a.entry.js +2 -0
  1068. package/dist/huibo-ui/p-d87fc21a.entry.js.map +1 -0
  1069. package/dist/huibo-ui/p-dd05cb2c.entry.js +2 -0
  1070. package/dist/huibo-ui/p-dd05cb2c.entry.js.map +1 -0
  1071. package/dist/huibo-ui/p-dfaf7e37.entry.js +2 -0
  1072. package/dist/huibo-ui/p-dfaf7e37.entry.js.map +1 -0
  1073. package/dist/huibo-ui/p-e004fc81.entry.js +2 -0
  1074. package/dist/huibo-ui/p-e004fc81.entry.js.map +1 -0
  1075. package/dist/huibo-ui/p-e0768565.entry.js +2 -0
  1076. package/dist/huibo-ui/p-e0768565.entry.js.map +1 -0
  1077. package/dist/huibo-ui/p-e0ab9010.entry.js +2 -0
  1078. package/dist/huibo-ui/p-e0ab9010.entry.js.map +1 -0
  1079. package/dist/huibo-ui/p-e1255160.js +2 -0
  1080. package/dist/huibo-ui/p-e1255160.js.map +1 -0
  1081. package/dist/huibo-ui/p-e2a8a396.entry.js +2 -0
  1082. package/dist/huibo-ui/p-e2a8a396.entry.js.map +1 -0
  1083. package/dist/huibo-ui/p-e36bbe6f.entry.js +2 -0
  1084. package/dist/huibo-ui/p-e36bbe6f.entry.js.map +1 -0
  1085. package/dist/huibo-ui/p-e42dfa95.js +3 -0
  1086. package/dist/huibo-ui/p-e42dfa95.js.map +1 -0
  1087. package/dist/huibo-ui/p-e6f2d71d.entry.js +2 -0
  1088. package/dist/huibo-ui/p-e6f2d71d.entry.js.map +1 -0
  1089. package/dist/huibo-ui/p-e9490259.entry.js +2 -0
  1090. package/dist/huibo-ui/p-e9490259.entry.js.map +1 -0
  1091. package/dist/huibo-ui/p-ea74fcae.entry.js +2 -0
  1092. package/dist/huibo-ui/p-ea74fcae.entry.js.map +1 -0
  1093. package/dist/huibo-ui/p-ebd04656.entry.js +2 -0
  1094. package/dist/huibo-ui/p-ebd04656.entry.js.map +1 -0
  1095. package/dist/huibo-ui/p-ecce2b5e.js +2 -0
  1096. package/dist/huibo-ui/p-ecce2b5e.js.map +1 -0
  1097. package/dist/huibo-ui/p-ed0ff857.entry.js +2 -0
  1098. package/dist/huibo-ui/p-ed0ff857.entry.js.map +1 -0
  1099. package/dist/huibo-ui/p-f0ac7db5.entry.js +2 -0
  1100. package/dist/huibo-ui/p-f0ac7db5.entry.js.map +1 -0
  1101. package/dist/huibo-ui/p-f1c084c5.entry.js +2 -0
  1102. package/dist/huibo-ui/p-f1c084c5.entry.js.map +1 -0
  1103. package/dist/huibo-ui/p-f374d5a3.entry.js +2 -0
  1104. package/dist/huibo-ui/p-f374d5a3.entry.js.map +1 -0
  1105. package/dist/huibo-ui/p-f81ec512.entry.js +2 -0
  1106. package/dist/huibo-ui/p-f81ec512.entry.js.map +1 -0
  1107. package/dist/huibo-ui/p-fd19813c.entry.js +2 -0
  1108. package/dist/huibo-ui/p-fd19813c.entry.js.map +1 -0
  1109. package/dist/index.cjs.js +1 -0
  1110. package/dist/index.js +1 -0
  1111. package/dist/types/components/Affix/Affix.d.ts +27 -0
  1112. package/dist/types/components/Alert/Alert.d.ts +23 -0
  1113. package/dist/types/components/Anchor/Anchor.d.ts +28 -0
  1114. package/dist/types/components/Avatar/Avatar.d.ts +9 -0
  1115. package/dist/types/components/Backtop/Backtop.d.ts +33 -0
  1116. package/dist/types/components/Badge/Badge.d.ts +9 -0
  1117. package/dist/types/components/Breadcrumb/Breadcrumb.d.ts +9 -0
  1118. package/dist/types/components/Breadcrumb/BreadcrumbItem.d.ts +9 -0
  1119. package/dist/types/components/Button/Button.d.ts +17 -0
  1120. package/dist/types/components/Calendar/Calendar.d.ts +35 -0
  1121. package/dist/types/components/Card/Card.d.ts +6 -0
  1122. package/dist/types/components/Carousel/Carousel.d.ts +45 -0
  1123. package/dist/types/components/Cascader/Cascader.d.ts +150 -0
  1124. package/dist/types/components/Checkbox/Checkbox.d.ts +66 -0
  1125. package/dist/types/components/Checkbox/CheckboxGroup.d.ts +46 -0
  1126. package/dist/types/components/Collapse/Collapse.d.ts +7 -0
  1127. package/dist/types/components/Collapse/CollapseItem.d.ts +17 -0
  1128. package/dist/types/components/ColorPicker/ColorPicker.d.ts +59 -0
  1129. package/dist/types/components/ColorPickerPanel/ColorPickerPanel.d.ts +35 -0
  1130. package/dist/types/components/ConfigProvider/ConfigProvider.d.ts +17 -0
  1131. package/dist/types/components/Container/Aside.d.ts +11 -0
  1132. package/dist/types/components/Container/Container.d.ts +12 -0
  1133. package/dist/types/components/Container/Footer.d.ts +11 -0
  1134. package/dist/types/components/Container/Header.d.ts +11 -0
  1135. package/dist/types/components/Container/Main.d.ts +7 -0
  1136. package/dist/types/components/DatePicker/DatePicker.d.ts +53 -0
  1137. package/dist/types/components/DatePickerPane/DatePickerPane.d.ts +40 -0
  1138. package/dist/types/components/DateRangePicker/DateRangePicker.d.ts +68 -0
  1139. package/dist/types/components/DateTimePicker/DateTimePicker.d.ts +41 -0
  1140. package/dist/types/components/Descriptions/Descriptions.d.ts +22 -0
  1141. package/dist/types/components/Dialog/Dialog.d.ts +42 -0
  1142. package/dist/types/components/Divider/Divider.d.ts +14 -0
  1143. package/dist/types/components/Drawer/Drawer.d.ts +24 -0
  1144. package/dist/types/components/Dropdown/Dropdown.d.ts +32 -0
  1145. package/dist/types/components/Empty/Empty.d.ts +5 -0
  1146. package/dist/types/components/FloatButton/FloatButton.d.ts +29 -0
  1147. package/dist/types/components/Form/Form.d.ts +41 -0
  1148. package/dist/types/components/Form/FormItem.d.ts +30 -0
  1149. package/dist/types/components/Icon/Icon.d.ts +17 -0
  1150. package/dist/types/components/Image/Image.d.ts +16 -0
  1151. package/dist/types/components/ImagePreview/ImagePreview.d.ts +59 -0
  1152. package/dist/types/components/Input/Input.d.ts +133 -0
  1153. package/dist/types/components/InputNumber/InputNumber.d.ts +89 -0
  1154. package/dist/types/components/InputTag/InputTag.d.ts +79 -0
  1155. package/dist/types/components/Layout/Layout.d.ts +48 -0
  1156. package/dist/types/components/Layout/Row.d.ts +26 -0
  1157. package/dist/types/components/Link/Link.d.ts +40 -0
  1158. package/dist/types/components/Loading/Loading.d.ts +13 -0
  1159. package/dist/types/components/Menu/Menu.d.ts +34 -0
  1160. package/dist/types/components/Menu/MenuItem.d.ts +17 -0
  1161. package/dist/types/components/Menu/SubMenu.d.ts +30 -0
  1162. package/dist/types/components/Message/Message.d.ts +20 -0
  1163. package/dist/types/components/Message/show-message.d.ts +13 -0
  1164. package/dist/types/components/Notification/Notification.d.ts +33 -0
  1165. package/dist/types/components/Notification/notify.d.ts +19 -0
  1166. package/dist/types/components/PageHeader/PageHeader.d.ts +19 -0
  1167. package/dist/types/components/Pagination/Pagination.d.ts +35 -0
  1168. package/dist/types/components/Popconfirm/Popconfirm.d.ts +20 -0
  1169. package/dist/types/components/Popover/Popover.d.ts +18 -0
  1170. package/dist/types/components/Progress/Progress.d.ts +9 -0
  1171. package/dist/types/components/Radio/Radio.d.ts +57 -0
  1172. package/dist/types/components/Rate/Rate.d.ts +64 -0
  1173. package/dist/types/components/Result/Result.d.ts +22 -0
  1174. package/dist/types/components/Scrollbar/Scrollbar.d.ts +75 -0
  1175. package/dist/types/components/Segmented/Segmented.d.ts +24 -0
  1176. package/dist/types/components/Select/Select.d.ts +100 -0
  1177. package/dist/types/components/Skeleton/Skeleton.d.ts +22 -0
  1178. package/dist/types/components/Slider/Slider.d.ts +81 -0
  1179. package/dist/types/components/Space/Space.d.ts +37 -0
  1180. package/dist/types/components/Statistic/Statistic.d.ts +25 -0
  1181. package/dist/types/components/Steps/Step.d.ts +7 -0
  1182. package/dist/types/components/Steps/Steps.d.ts +15 -0
  1183. package/dist/types/components/Switch/Switch.d.ts +58 -0
  1184. package/dist/types/components/Table/Table.d.ts +184 -0
  1185. package/dist/types/components/Tabs/TabPane.d.ts +12 -0
  1186. package/dist/types/components/Tabs/Tabs.d.ts +32 -0
  1187. package/dist/types/components/Tag/Tag.d.ts +21 -0
  1188. package/dist/types/components/Text/Text.d.ts +37 -0
  1189. package/dist/types/components/TimePicker/TimePicker.d.ts +62 -0
  1190. package/dist/types/components/TimeSelect/TimeSelect.d.ts +69 -0
  1191. package/dist/types/components/Timeline/Timeline.d.ts +16 -0
  1192. package/dist/types/components/Tooltip/Tooltip.d.ts +28 -0
  1193. package/dist/types/components/Tour/Tour.d.ts +39 -0
  1194. package/dist/types/components/Transfer/Transfer.d.ts +73 -0
  1195. package/dist/types/components/Tree/Tree.d.ts +113 -0
  1196. package/dist/types/components/TreeSelect/TreeSelect.d.ts +71 -0
  1197. package/dist/types/components/Upload/Upload.d.ts +55 -0
  1198. package/dist/types/components/Watermark/Watermark.d.ts +25 -0
  1199. package/dist/types/components.d.ts +8261 -0
  1200. package/dist/types/index.d.ts +10 -0
  1201. package/dist/types/stencil-public-runtime.d.ts +1680 -0
  1202. package/dist/types/utils/a11y.d.ts +66 -0
  1203. package/dist/types/utils/click-outside.d.ts +20 -0
  1204. package/dist/types/utils/date-helpers.d.ts +41 -0
  1205. package/dist/types/utils/form-input-base.d.ts +62 -0
  1206. package/dist/types/utils/popup-manager.d.ts +17 -0
  1207. package/loader/cdn.js +1 -0
  1208. package/loader/index.cjs.js +1 -0
  1209. package/loader/index.d.ts +24 -0
  1210. package/loader/index.es2017.js +1 -0
  1211. package/loader/index.js +2 -0
  1212. package/loader/package.json +11 -0
  1213. package/package.json +93 -0
  1214. package/readme.md +111 -0
@@ -0,0 +1 @@
1
+ {"version":3,"names":["cascaderCss","HbCascaderStyle0","Cascader","modelValue","options","placeholder","disabled","size","clearable","showAllLevels","name","inputId","separator","emitPath","filterable","lazy","load","isOpen","inputValue","searchValue","loadingKeys","Set","filteredPaths","activePath","hbChange","hbExpandChange","clickOutside","createClickOutsideHandler","host","this","onClose","closeAndClearSearch","componentDidLoad","el","connect","updateInputValue","disconnectedCallback","disconnect","handleValueChange","length","lastValue","option","findOptionByValue","label","labels","currentOptions","value","find","opt","push","children","join","found","handleInputClick","handleSearchInput","e","target","collectFilteredPaths","keyword","trimmed","trim","toLowerCase","results","walk","opts","ancestors","currentPath","includes","handleSearchSelect","path","valuePath","map","last","isLeaf","leaf","emit","handleClear","stopPropagation","undefined","handleSelect","newPath","selectedOption","pathValue","loadChildren","node","replaceOptionChildren","err","console","error","slice","indexOf","next","delete","targetValue","newChildren","render","h","key","class","onClick","type","id","readonly","role","onInput","renderSearchResults","renderCascaderMenus","menus","renderMenu","i","has","renderLoadingMenu","labelPath","selected","every","v","idx","isSelected","isInPath","val"],"sources":["src/components/Cascader/cascader.css?tag=hb-cascader&encapsulation=shadow","src/components/Cascader/Cascader.tsx"],"sourcesContent":[":host {\n display: inline-block;\n position: relative;\n --hb-cascader-font-size: 14px;\n --hb-cascader-font-size-large: 16px;\n --hb-cascader-font-size-small: 12px;\n --hb-cascader-border-color: var(--hb-border-color, #dcdfe6);\n --hb-cascader-border-color-hover: var(--hb-color-primary);\n --hb-cascader-bg-color: var(--hb-color-white, #ffffff);\n --hb-cascader-text-color: var(--hb-color-text-regular, #606266);\n --hb-cascader-placeholder-color: var(--hb-color-text-placeholder, #c0c4cc);\n --hb-cascader-disabled-color: var(--hb-color-text-disabled, #c0c4cc);\n --hb-cascader-disabled-bg-color: var(--hb-fill-color-light, #f5f7fa);\n}\n\n.hb-cascader {\n display: inline-block;\n position: relative;\n font-size: var(--hb-cascader-font-size);\n line-height: 32px;\n}\n\n.hb-cascader__input-wrapper {\n position: relative;\n display: inline-block;\n width: 100%;\n cursor: pointer;\n}\n\n.hb-cascader__input {\n display: inline-block;\n width: 100%;\n height: 32px;\n line-height: 32px;\n padding: 0 30px 0 15px;\n font-size: var(--hb-cascader-font-size);\n color: var(--hb-cascader-text-color);\n background-color: var(--hb-cascader-bg-color);\n border: 1px solid var(--hb-cascader-border-color);\n border-radius: 4px;\n box-sizing: border-box;\n cursor: pointer;\n outline: none;\n transition: border-color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1);\n}\n\n.hb-cascader__input::placeholder {\n color: var(--hb-cascader-placeholder-color);\n}\n\n.hb-cascader__input:hover:not(:disabled) {\n border-color: var(--hb-cascader-border-color-hover);\n}\n\n.hb-cascader__input:focus {\n border-color: var(--hb-cascader-border-color-hover);\n}\n\n.hb-cascader__input:disabled {\n background-color: var(--hb-cascader-disabled-bg-color);\n border-color: var(--hb-cascader-border-color);\n color: var(--hb-cascader-disabled-color);\n cursor: not-allowed;\n}\n\n.hb-cascader__suffix {\n position: absolute;\n right: 8px;\n top: 50%;\n transform: translateY(-50%);\n display: flex;\n align-items: center;\n color: var(--hb-cascader-text-color);\n}\n\n.hb-cascader__clear {\n margin-right: 8px;\n cursor: pointer;\n font-size: 16px;\n color: var(--hb-cascader-placeholder-color);\n transition: color 0.2s;\n}\n\n.hb-cascader__clear:hover {\n color: var(--hb-cascader-text-color);\n}\n\n.hb-cascader__arrow {\n font-size: 12px;\n transition: transform 0.3s;\n}\n\n.hb-cascader--open .hb-cascader__arrow {\n transform: rotate(180deg);\n}\n\n.hb-cascader__dropdown {\n position: absolute;\n top: 100%;\n left: 0;\n margin-top: 4px;\n background-color: var(--hb-cascader-bg-color);\n border: 1px solid var(--hb-cascader-border-color);\n border-radius: 4px;\n box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);\n z-index: 1000;\n min-width: 180px;\n max-height: 300px;\n overflow-y: auto;\n width: max-content;\n}\n\n.hb-cascader__menus {\n display: flex;\n padding: 6px 0;\n}\n\n.hb-cascader__menu {\n min-width: 180px;\n max-height: 300px;\n overflow-y: auto;\n border-right: 1px solid var(--hb-cascader-border-color);\n}\n\n.hb-cascader__menu:last-child {\n border-right: none;\n}\n\n.hb-cascader__menu-list {\n margin: 0;\n padding: 0;\n list-style: none;\n}\n\n.hb-cascader__menu-item {\n display: flex;\n align-items: center;\n justify-content: space-between;\n padding: 8px 20px;\n font-size: var(--hb-cascader-font-size);\n color: var(--hb-cascader-text-color);\n cursor: pointer;\n transition: background-color 0.2s;\n}\n\n.hb-cascader__menu-item:hover:not(.hb-cascader__menu-item--disabled) {\n background-color: var(--hb-fill-color-light, #f5f7fa);\n}\n\n.hb-cascader__menu-item--selected {\n color: var(--hb-color-primary);\n font-weight: 600;\n}\n\n.hb-cascader__menu-item--disabled {\n color: var(--hb-cascader-disabled-color);\n cursor: not-allowed;\n}\n\n.hb-cascader__menu-item-label {\n flex: 1;\n}\n\n.hb-cascader__menu-item-arrow {\n margin-left: 8px;\n font-size: 12px;\n color: var(--hb-cascader-placeholder-color);\n}\n\n.hb-cascader__menu-item-loading {\n margin-left: 8px;\n font-size: 12px;\n color: var(--hb-color-primary, #1677ff);\n animation: hb-cascader-spin 0.8s linear infinite;\n}\n\n.hb-cascader__menu-list--loading .hb-cascader__menu-item--loading {\n color: var(--hb-color-text-placeholder, #c0c4cc);\n justify-content: center;\n}\n\n@keyframes hb-cascader-spin {\n from { transform: rotate(0deg); }\n to { transform: rotate(360deg); }\n}\n\n.hb-cascader--large {\n font-size: var(--hb-cascader-font-size-large);\n line-height: 40px;\n}\n\n.hb-cascader--large .hb-cascader__input {\n height: 40px;\n line-height: 40px;\n font-size: var(--hb-cascader-font-size-large);\n}\n\n.hb-cascader--small {\n font-size: var(--hb-cascader-font-size-small);\n line-height: 24px;\n}\n\n.hb-cascader--small .hb-cascader__input {\n height: 24px;\n line-height: 24px;\n font-size: var(--hb-cascader-font-size-small);\n padding: 0 25px 0 12px;\n}\n\n.hb-cascader--disabled {\n cursor: not-allowed;\n}\n\n/* ---- 可搜索(filterable)---- */\n.hb-cascader__search {\n padding: 8px;\n border-bottom: 1px solid var(--hb-cascader-border-color);\n}\n\n.hb-cascader__search-input {\n width: 100%;\n height: 28px;\n line-height: 28px;\n padding: 0 8px;\n font-size: var(--hb-cascader-font-size);\n color: var(--hb-cascader-text-color);\n background-color: var(--hb-cascader-bg-color);\n border: 1px solid var(--hb-cascader-border-color);\n border-radius: 4px;\n box-sizing: border-box;\n outline: none;\n transition: border-color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1);\n cursor: text;\n}\n\n.hb-cascader__search-input:focus {\n border-color: var(--hb-cascader-border-color-hover);\n}\n\n.hb-cascader__search-results {\n padding: 6px 0;\n max-height: 264px;\n overflow-y: auto;\n min-width: 180px;\n}\n\n.hb-cascader__search-item {\n padding: 8px 20px;\n font-size: var(--hb-cascader-font-size);\n color: var(--hb-cascader-text-color);\n cursor: pointer;\n white-space: nowrap;\n transition: background-color 0.2s;\n}\n\n.hb-cascader__search-item:hover:not(.hb-cascader__search-item--disabled) {\n background-color: var(--hb-fill-color-light, #f5f7fa);\n}\n\n.hb-cascader__search-item--selected {\n color: var(--hb-color-primary);\n font-weight: 600;\n}\n\n.hb-cascader__search-item--disabled {\n color: var(--hb-cascader-disabled-color);\n cursor: not-allowed;\n}\n\n.hb-cascader__search-empty {\n padding: 16px 0;\n text-align: center;\n color: var(--hb-cascader-placeholder-color);\n font-size: var(--hb-cascader-font-size);\n}\n\n","import { Component, h, Prop, Event, EventEmitter, State, Element, Watch } from '@stencil/core';\nimport { createClickOutsideHandler } from '../../utils/click-outside';\n\nexport interface CascaderOption {\n value: string | number;\n label: string;\n children?: CascaderOption[];\n disabled?: boolean;\n leaf?: boolean;\n}\n\n/**\n * Cascader 级联选择器组件\n * 当一个数据集合有清晰的层级结构时,可通过级联选择器逐级查看并选择\n */\n@Component({\n tag: 'hb-cascader',\n styleUrl: 'cascader.css',\n shadow: true,\n})\nexport class Cascader {\n @Element() el: HTMLElement;\n\n /**\n * 选中项绑定值\n */\n @Prop({ mutable: true }) modelValue?: (string | number)[];\n\n /**\n * 可选项数据源\n */\n @Prop() options: CascaderOption[] = [];\n\n /**\n * 输入框占位文本\n */\n @Prop() placeholder: string = '请选择';\n\n /**\n * 是否禁用\n * @default false\n */\n @Prop() disabled: boolean = false;\n\n /**\n * 输入框尺寸\n */\n @Prop() size: 'large' | 'default' | 'small' = 'default';\n\n /**\n * 是否可清空\n * @default false\n */\n @Prop() clearable: boolean = false;\n\n /**\n * 是否显示完整路径\n * @default true\n */\n @Prop() showAllLevels: boolean = true;\n\n /**\n * 输入框的原生属性\n */\n @Prop() name?: string;\n\n /**\n * 输入框的原生属性\n */\n @Prop() inputId?: string;\n\n /**\n * 分隔符\n * @default ' / '\n */\n @Prop() separator: string = ' / ';\n\n /**\n * 是否动态加载子节点\n * @default true\n */\n @Prop() emitPath: boolean = true;\n\n /**\n * 是否可搜索(filterable)\n * 开启后下拉顶部渲染搜索输入框,输入时按 label(含所有子级)扁平化过滤,\n * 匹配项以完整路径展示,点击即选中其完整路径。\n * @default false\n */\n @Prop() filterable: boolean = false;\n\n /**\n * 是否开启动态加载(lazy load)。开启后,展开含 children=undefined 的节点时,\n * 调用 load(node) 获取其子级并填充进 options,加载中显示 loading 态。\n * @default false\n */\n @Prop() lazy: boolean = false;\n\n /**\n * 动态加载子节点的函数(仅在 lazy=true 时生效)。\n * 接收被展开的节点,返回其子节点数组(Promise)。\n * 加载结果会以不可变方式合并进 options 树(替换该节点 children)。\n */\n @Prop() load?: (node: CascaderOption) => Promise<CascaderOption[]>;\n\n @State() isOpen: boolean = false;\n @State() inputValue: string = '';\n @State() searchValue: string = '';\n /**\n * 正在动态加载子级的节点 value 集合(用于渲染 loading 态)。\n */\n @State() loadingKeys: Set<string | number> = new Set();\n /**\n * 扁平化搜索结果:每一项是一个从根到匹配节点的完整路径(用于点击选中)。\n * 仅在 filterable 且 searchValue 非空时使用。\n */\n @State() filteredPaths: CascaderOption[][] = [];\n @State() activePath: (string | number)[] = [];\n\n /**\n * 值改变事件\n */\n @Event() hbChange: EventEmitter<(string | number)[] | undefined>;\n\n /**\n * 展开节点发生变化时触发\n */\n @Event() hbExpandChange: EventEmitter<(string | number)[]>;\n\n private clickOutside = createClickOutsideHandler({\n host: null as any,\n isOpen: () => this.isOpen,\n onClose: () => { this.closeAndClearSearch(); },\n });\n\n componentDidLoad() {\n this.clickOutside = createClickOutsideHandler({\n host: this.el,\n isOpen: () => this.isOpen,\n onClose: () => { this.closeAndClearSearch(); },\n });\n this.clickOutside.connect();\n this.updateInputValue();\n }\n\n /** 关闭下拉并清空搜索态(filterable 模式下避免重开时残留搜索结果) */\n private closeAndClearSearch() {\n this.isOpen = false;\n this.searchValue = '';\n this.filteredPaths = [];\n }\n\n disconnectedCallback() {\n this.clickOutside.disconnect();\n }\n\n @Watch('modelValue')\n handleValueChange() {\n this.updateInputValue();\n }\n\n private updateInputValue() {\n if (!this.modelValue || this.modelValue.length === 0) {\n this.inputValue = '';\n return;\n }\n\n if (!this.showAllLevels) {\n const lastValue = this.modelValue[this.modelValue.length - 1];\n const option = this.findOptionByValue(this.options, lastValue);\n this.inputValue = option ? option.label : '';\n return;\n }\n\n const labels: string[] = [];\n let currentOptions = this.options;\n \n for (const value of this.modelValue) {\n const option = currentOptions.find(opt => opt.value === value);\n if (option) {\n labels.push(option.label);\n currentOptions = option.children || [];\n } else {\n break;\n }\n }\n\n this.inputValue = labels.join(this.separator);\n }\n\n private findOptionByValue(options: CascaderOption[], value: string | number): CascaderOption | null {\n for (const option of options) {\n if (option.value === value) {\n return option;\n }\n if (option.children) {\n const found = this.findOptionByValue(option.children, value);\n if (found) return found;\n }\n }\n return null;\n }\n\n private handleInputClick = () => {\n if (this.disabled) return;\n if (this.isOpen) {\n // 关闭时清空搜索态\n this.closeAndClearSearch();\n } else {\n this.isOpen = true;\n }\n };\n\n /** 搜索输入:仅更新 searchValue,过滤在 render 前的 @State 派生 */\n private handleSearchInput = (e: Event) => {\n const target = e.target as HTMLInputElement;\n this.searchValue = target.value;\n this.filteredPaths = this.collectFilteredPaths(this.searchValue);\n };\n\n /**\n * 扁平化全树搜索:把 options 深度遍历,收集所有「节点 label 含关键字」的完整路径。\n * 一个节点的完整路径 = 从根到该节点(含自身)的 CascaderOption 数组。\n * 关键字为空时返回空数组(交由正常级联视图渲染)。\n *\n * 注意:这里按 label 子串匹配(大小写不敏感),匹配任意层级的节点,\n * 并保留其祖先链以便点击时还原完整路径。\n */\n private collectFilteredPaths(keyword: string): CascaderOption[][] {\n const trimmed = keyword.trim().toLowerCase();\n if (!trimmed) return [];\n\n const results: CascaderOption[][] = [];\n const walk = (opts: CascaderOption[], ancestors: CascaderOption[]) => {\n for (const opt of opts) {\n const currentPath = [...ancestors, opt];\n if (opt.label.toLowerCase().includes(trimmed)) {\n results.push(currentPath);\n }\n if (opt.children && opt.children.length > 0) {\n walk(opt.children, currentPath);\n }\n }\n };\n walk(this.options, []);\n return results;\n }\n\n /** 从扁平搜索结果路径中点击叶子(或非叶子)项:直接以该路径的 value 数组作为选中值 */\n private handleSearchSelect = (path: CascaderOption[]) => {\n const valuePath = path.map((opt) => opt.value);\n const last = path[path.length - 1];\n const isLeaf = !last.children || last.children.length === 0 || last.leaf;\n this.searchValue = '';\n this.filteredPaths = [];\n if (isLeaf) {\n // 叶子:选中并关闭\n this.modelValue = valuePath;\n this.updateInputValue();\n this.hbChange.emit(valuePath);\n this.isOpen = false;\n this.activePath = [];\n } else {\n // 非叶子:进入该路径的级联展开(便于继续选下级)\n this.activePath = valuePath;\n this.hbExpandChange.emit(valuePath);\n }\n };\n\n private handleClear = (e: Event) => {\n e.stopPropagation();\n this.modelValue = undefined;\n this.inputValue = '';\n this.isOpen = false;\n this.hbChange.emit(undefined);\n };\n\n private handleSelect = (value: string | number, path: (string | number)[]) => {\n const newPath = [...path, value];\n\n // Find the selected option\n let currentOptions = this.options;\n let selectedOption: CascaderOption | null = null;\n\n for (const pathValue of newPath) {\n selectedOption = currentOptions.find(opt => opt.value === pathValue) || null;\n if (!selectedOption) break;\n currentOptions = selectedOption.children || [];\n }\n\n // lazy + load:节点 children 尚未加载(children === undefined 且 leaf 未声明)→ 触发加载\n if (\n this.lazy &&\n this.load &&\n selectedOption &&\n selectedOption.children === undefined &&\n !selectedOption.leaf\n ) {\n // 先展开该路径(显示 loading 态的下一级面板占位),再异步填充\n this.activePath = newPath;\n this.hbExpandChange.emit(newPath);\n void this.loadChildren(selectedOption, newPath);\n return;\n }\n\n // Check if it's a leaf node\n if (!selectedOption || !selectedOption.children || selectedOption.children.length === 0 || selectedOption.leaf) {\n // Leaf node - select and close\n this.modelValue = newPath;\n this.updateInputValue();\n this.hbChange.emit(newPath);\n this.isOpen = false;\n this.activePath = [];\n } else {\n // Has children - expand to next level\n this.activePath = newPath;\n this.hbExpandChange.emit(newPath);\n }\n };\n\n /**\n * 动态加载某节点的子级。不可变地合并进 options 树(替换该节点 children)。\n * 加载中:把节点 value 加入 loadingKeys(渲染 loading 态);\n * 加载完成:写入 children(新数组,触发 @Watch/重渲染),移出 loadingKeys。\n * 若 load 返回空数组,把 children 设为 [] 以标记该节点为叶子(避免重复加载)。\n */\n private async loadChildren(node: CascaderOption, path: (string | number)[]) {\n if (!this.load) return;\n // 标记 loading\n this.loadingKeys = new Set([...this.loadingKeys, node.value]);\n\n try {\n const children = await this.load(node);\n // 不可变合并:重建 options 树,仅替换目标节点的 children。\n this.options = this.replaceOptionChildren(this.options, node.value, children);\n } catch (err) {\n // 加载失败:回退 activePath,避免卡在 loading;保持 options 不变。\n // eslint-disable-next-line no-console\n console.error('[hb-cascader] lazy load failed:', err);\n this.activePath = this.activePath.slice(0, this.activePath.indexOf(node.value) + 1);\n } finally {\n const next = new Set(this.loadingKeys);\n next.delete(node.value);\n this.loadingKeys = next;\n }\n\n // 重新校验该路径是否还能继续展开(叶子情况则收起下一级面板)\n void path;\n void node;\n }\n\n /**\n * 不可变地替换 options 树中 value===targetValue 节点的 children 字段。\n * 返回一棵全新的 options 树(不修改原数组与原节点对象)。\n */\n private replaceOptionChildren(\n options: CascaderOption[],\n targetValue: string | number,\n newChildren: CascaderOption[]\n ): CascaderOption[] {\n return options.map((opt) => {\n if (opt.value === targetValue) {\n return { ...opt, children: newChildren };\n }\n if (opt.children && opt.children.length > 0) {\n return { ...opt, children: this.replaceOptionChildren(opt.children, targetValue, newChildren) };\n }\n return opt;\n });\n }\n\n render() {\n return (\n <div\n class={{\n 'hb-cascader': true,\n 'hb-cascader--open': this.isOpen,\n 'hb-cascader--disabled': this.disabled,\n [`hb-cascader--${this.size}`]: true,\n }}\n >\n <div class=\"hb-cascader__input-wrapper\" onClick={this.handleInputClick}>\n <input\n type=\"text\"\n id={this.inputId}\n name={this.name}\n class=\"hb-cascader__input\"\n placeholder={this.placeholder}\n value={this.inputValue}\n disabled={this.disabled}\n readonly\n role=\"combobox\"\n aria-haspopup=\"listbox\"\n aria-expanded={this.isOpen ? 'true' : 'false'}\n />\n <span class=\"hb-cascader__suffix\">\n {this.clearable && this.modelValue && this.modelValue.length > 0 && (\n <span class=\"hb-cascader__clear\" role=\"button\" aria-label=\"清空\" onClick={this.handleClear}>\n ×\n </span>\n )}\n <span class=\"hb-cascader__arrow\">▼</span>\n </span>\n </div>\n {this.isOpen && (\n <div class=\"hb-cascader__dropdown\">\n {this.filterable && (\n <div class=\"hb-cascader__search\">\n <input\n type=\"text\"\n class=\"hb-cascader__search-input\"\n placeholder=\"搜索\"\n value={this.searchValue}\n onInput={this.handleSearchInput}\n aria-label=\"搜索选项\"\n />\n </div>\n )}\n {this.filterable && this.searchValue.trim() !== '' ? (\n this.renderSearchResults()\n ) : (\n <div class=\"hb-cascader__menus\" role=\"listbox\" aria-multiselectable=\"false\">\n {this.renderCascaderMenus()}\n </div>\n )}\n </div>\n )}\n </div>\n );\n }\n\n private renderCascaderMenus() {\n const menus: any[] = [];\n let currentOptions = this.options;\n let currentPath: (string | number)[] = [];\n\n // Render first level\n menus.push(this.renderMenu(currentOptions, currentPath));\n\n // Render active path levels\n for (let i = 0; i < this.activePath.length; i++) {\n const pathValue = this.activePath[i];\n const option = currentOptions.find(opt => opt.value === pathValue);\n\n if (!option) break;\n\n // lazy 加载中:节点 children 尚未填充 → 渲染 loading 面板\n if (option.children === undefined && this.loadingKeys.has(option.value)) {\n menus.push(this.renderLoadingMenu());\n break;\n }\n\n if (option.children && option.children.length > 0) {\n currentPath = [...currentPath, pathValue];\n currentOptions = option.children;\n menus.push(this.renderMenu(currentOptions, currentPath));\n } else {\n break;\n }\n }\n\n return menus;\n }\n\n /** lazy 加载中渲染的面板:一个 loading 占位提示 */\n private renderLoadingMenu() {\n return (\n <ul class=\"hb-cascader__menu-list hb-cascader__menu-list--loading\" role=\"status\" aria-live=\"polite\">\n <li class=\"hb-cascader__menu-item hb-cascader__menu-item--loading\">\n <span class=\"hb-cascader__menu-item-label\">加载中…</span>\n </li>\n </ul>\n );\n }\n\n /**\n * 渲染扁平化搜索结果:每一项展示完整路径(label 用 separator 连接),点击选中完整路径。\n * 无匹配时渲染空状态。\n */\n private renderSearchResults() {\n if (this.filteredPaths.length === 0) {\n return (\n <div class=\"hb-cascader__search-empty\" role=\"status\">\n 无匹配数据\n </div>\n );\n }\n\n return (\n <div class=\"hb-cascader__search-results\" role=\"listbox\" aria-label=\"搜索结果\">\n {this.filteredPaths.map((path) => {\n const labelPath = path.map((opt) => opt.label).join(this.separator);\n const valuePath = path.map((opt) => opt.value);\n const last = path[path.length - 1];\n const disabled = !!last.disabled;\n // 当前选中判断:路径 value 与 modelValue 完全一致\n const selected =\n !!this.modelValue &&\n this.modelValue.length === valuePath.length &&\n valuePath.every((v, idx) => this.modelValue && this.modelValue[idx] === v);\n\n return (\n <div\n class={{\n 'hb-cascader__search-item': true,\n 'hb-cascader__search-item--selected': selected,\n 'hb-cascader__search-item--disabled': disabled,\n }}\n role=\"option\"\n aria-selected={selected ? 'true' : 'false'}\n aria-disabled={disabled ? 'true' : undefined}\n onClick={() => !disabled && this.handleSearchSelect(path)}\n >\n {labelPath}\n </div>\n );\n })}\n </div>\n );\n }\n\n private renderMenu(options: CascaderOption[], path: (string | number)[]) {\n if (!options || options.length === 0) {\n return null;\n }\n \n return (\n <ul class=\"hb-cascader__menu-list\" role=\"group\">\n {options.map((option) => {\n const isSelected = path.length > 0 && path[path.length - 1] === option.value;\n const isInPath = this.modelValue && path.length > 0 &&\n path.every((val, idx) => this.modelValue && this.modelValue[idx] === val) &&\n this.modelValue.length === path.length + 1 &&\n this.modelValue[path.length] === option.value;\n\n return (\n <li\n class={{\n 'hb-cascader__menu-item': true,\n 'hb-cascader__menu-item--selected': isSelected || isInPath,\n 'hb-cascader__menu-item--disabled': option.disabled,\n }}\n role=\"option\"\n aria-selected={(isSelected || isInPath) ? 'true' : 'false'}\n aria-disabled={option.disabled ? 'true' : undefined}\n onClick={() => !option.disabled && this.handleSelect(option.value, path)}\n >\n <span class=\"hb-cascader__menu-item-label\">{option.label}</span>\n {this.loadingKeys.has(option.value) ? (\n <span class=\"hb-cascader__menu-item-loading\" aria-hidden=\"true\">⟳</span>\n ) : (option.children && option.children.length > 0) || (this.lazy && option.children === undefined && !option.leaf) ? (\n <span class=\"hb-cascader__menu-item-arrow\">▶</span>\n ) : null}\n </li>\n );\n })}\n </ul>\n );\n }\n}\n\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as e,g as t,h as i}from"./p-e42dfa95.js";const o='/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{border:0 solid;box-sizing:border-box;margin:0;padding:0}::file-selector-button{appearance:button;background-color:#0000;border:0 solid;border-radius:0;box-sizing:border-box;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;margin:0;margin-inline-end:4px;opacity:1;padding:0}:host,html{-webkit-text-size-adjust:100%;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);line-height:1.5;tab-size:4;-webkit-tap-highlight-color:transparent}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-size:1em;font-variation-settings:var(--default-mono-font-variation-settings,normal)}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}button,input,optgroup,select,textarea{background-color:#0000;border-radius:0;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex;padding-block:0}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field,::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.inline{display:inline}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}} /*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer components;:host{display:block}.hb-form{display:flex;flex-direction:column;gap:var(--hb-spacing-md)}.hb-form--inline{flex-flow:wrap;gap:var(--hb-spacing-sm)var(--hb-spacing-lg)}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}';const a=o;const n=class{constructor(t){e(this,t)}get el(){return t(this)}model={};rules={};labelPosition="right";labelWidth="80px";inline=false;size="default";disabled=false;fields=[];fieldRegistry=new Map;componentWillLoad(){this.el.addEventListener("hbFormFieldRegister",(e=>{const{prop:t,validate:i,resetValue:o,getValue:a}=e.detail;this.fieldRegistry.set(t,{prop:t,validate:i,resetValue:o,getValue:a})}))}validate=async()=>{const e=await Promise.all(Array.from(this.fieldRegistry.values()).map((async e=>{const t=await e.validate();return t.length===0})));return e.every(Boolean)};resetFields=()=>{this.fieldRegistry.forEach((e=>e.resetValue()))};render(){return i("form",{key:"233f774fd2e6a7331ce01d7b729c3a77dd5793a9",class:{"hb-form":true,[`hb-form--label-${this.labelPosition}`]:true,"hb-form--inline":this.inline},onSubmit:e=>e.preventDefault(),novalidate:true},i("slot",{key:"99055d1a239483acc153523aeb218ad420bd9610"}))}};n.style=a;export{n as hb_form};
2
+ //# sourceMappingURL=p-0e65e1bd.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["formCss","HbFormStyle0","Form","model","rules","labelPosition","labelWidth","inline","size","disabled","fields","fieldRegistry","Map","componentWillLoad","this","el","addEventListener","e","prop","validate","resetValue","getValue","detail","set","async","results","Promise","all","Array","from","values","map","field","errors","length","every","Boolean","resetFields","forEach","render","h","key","class","onSubmit","preventDefault","novalidate"],"sources":["src/components/Form/form.css?tag=hb-form&encapsulation=shadow","src/components/Form/Form.tsx"],"sourcesContent":[":host {\n display: block;\n}\n\n.hb-form {\n display: flex;\n flex-direction: column;\n gap: var(--hb-spacing-md);\n}\n\n.hb-form--inline {\n flex-direction: row;\n flex-wrap: wrap;\n gap: var(--hb-spacing-sm) var(--hb-spacing-lg);\n}\n","import { Component, h, Prop, State, Element } from '@stencil/core';\n\ninterface FormFieldRegistration {\n prop: string;\n validate: () => Promise<string[]>;\n resetValue: () => void;\n getValue: () => any;\n}\n\n/**\n * Form 表单组件\n * 由输入框、选择器、单选框、多选框等控件组成,配合表单校验\n */\n@Component({\n tag: 'hb-form',\n styleUrl: 'form.css',\n shadow: true,\n})\nexport class Form {\n @Element() el: HTMLElement;\n\n /** 表单数据对象 */\n @Prop() model: Record<string, any> = {};\n\n /** 表单验证规则 */\n @Prop() rules: Record<string, any[]> = {};\n\n /** 标签位置 */\n @Prop() labelPosition: 'left' | 'right' | 'top' = 'right';\n\n /** 标签宽度 */\n @Prop() labelWidth: string = '80px';\n\n /** 是否行内表单 */\n @Prop() inline: boolean = false;\n\n /** 表单尺寸 */\n @Prop() size: 'large' | 'default' | 'small' = 'default';\n\n /** 是否禁用 */\n @Prop() disabled: boolean = false;\n\n @State() fields: FormFieldRegistration[] = [];\n\n private fieldRegistry = new Map<string, FormFieldRegistration>();\n\n // 用 componentWillLoad 而非 componentDidLoad 注册监听器:\n // Stencil 生命周期里子组件(FormItem)的 componentDidLoad 先于父组件(Form)触发,\n // 若在 componentDidLoad 才挂监听,会错过子项派发的 hbFormFieldRegister,\n // 导致 fieldRegistry 为空、validate() 永远返回 true(真实浏览器里复现,mock-doc 被 waitForChanges 掩盖)。\n componentWillLoad() {\n this.el.addEventListener('hbFormFieldRegister', ((e: CustomEvent) => {\n const { prop, validate, resetValue, getValue } = e.detail;\n this.fieldRegistry.set(prop, { prop, validate, resetValue, getValue });\n }) as EventListener);\n }\n\n /**\n * 验证整个表单\n * @returns 是否验证通过\n */\n @Prop() validate = async (): Promise<boolean> => {\n const results = await Promise.all(\n Array.from(this.fieldRegistry.values()).map(async (field) => {\n const errors = await field.validate();\n return errors.length === 0;\n })\n );\n return results.every(Boolean);\n };\n\n /**\n * 重置表单\n */\n @Prop() resetFields = (): void => {\n this.fieldRegistry.forEach((field) => field.resetValue());\n };\n\n render() {\n return (\n <form\n class={{\n 'hb-form': true,\n [`hb-form--label-${this.labelPosition}`]: true,\n 'hb-form--inline': this.inline,\n }}\n onSubmit={(e) => e.preventDefault()}\n novalidate\n >\n <slot />\n </form>\n );\n }\n}\n"],"mappings":"kDAAA,MAAMA,EAAU,uvLAChB,MAAAC,EAAeD,E,MCiBFE,EAAI,M,iDAIPC,MAA6B,GAG7BC,MAA+B,GAG/BC,cAA0C,QAG1CC,WAAqB,OAGrBC,OAAkB,MAGlBC,KAAsC,UAGtCC,SAAoB,MAEnBC,OAAkC,GAEnCC,cAAgB,IAAIC,IAM5B,iBAAAC,GACEC,KAAKC,GAAGC,iBAAiB,uBAAyBC,IAChD,MAAMC,KAAEA,EAAIC,SAAEA,EAAQC,WAAEA,EAAUC,SAAEA,GAAaJ,EAAEK,OACnDR,KAAKH,cAAcY,IAAIL,EAAM,CAAEA,OAAMC,WAAUC,aAAYC,YAC5D,G,CAOKF,SAAWK,UACjB,MAAMC,QAAgBC,QAAQC,IAC5BC,MAAMC,KAAKf,KAAKH,cAAcmB,UAAUC,KAAIP,MAAOQ,IACjD,MAAMC,QAAeD,EAAMb,WAC3B,OAAOc,EAAOC,SAAW,CAAC,KAG9B,OAAOT,EAAQU,MAAMC,QAAQ,EAMvBC,YAAc,KACpBvB,KAAKH,cAAc2B,SAASN,GAAUA,EAAMZ,cAAa,EAG3D,MAAAmB,GACE,OACEC,EAAA,QAAAC,IAAA,2CACEC,MAAO,CACL,UAAW,KACX,CAAC,kBAAkB5B,KAAKT,iBAAkB,KAC1C,kBAAmBS,KAAKP,QAE1BoC,SAAW1B,GAAMA,EAAE2B,iBACnBC,WAAU,MAEVL,EAAA,QAAAC,IAAA,6C","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as t,c as e,g as i,h as o}from"./p-e42dfa95.js";const n=["large","default","small"];function r(t,e){const i=e&&n.includes(e)?e:"default";return`${t}--${i}`}function a(t){return Boolean(t.clearable&&!t.disabled&&!t.readonly&&t.hasValue)}function s(t){if(t===null||t===undefined)return false;if(typeof t==="string")return t.length>0;if(typeof t==="number")return!Number.isNaN(t);if(Array.isArray(t))return t.length>0;return true}function l(t,e){return{[t]:true,[r(t,e)]:true}}const h='/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{border:0 solid;box-sizing:border-box;margin:0;padding:0}::file-selector-button{appearance:button;background-color:#0000;border:0 solid;border-radius:0;box-sizing:border-box;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;margin:0;margin-inline-end:4px;opacity:1;padding:0}:host,html{-webkit-text-size-adjust:100%;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);line-height:1.5;tab-size:4;-webkit-tap-highlight-color:transparent}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-size:1em;font-variation-settings:var(--default-mono-font-variation-settings,normal)}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}button,input,optgroup,select,textarea{background-color:#0000;border-radius:0;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex;padding-block:0}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field,::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.resize{resize:both}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}} /*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer components;:host{--hb-input-font-size:14px;--hb-input-font-size-large:16px;--hb-input-font-size-small:12px;--hb-input-height:32px;--hb-input-height-large:40px;--hb-input-height-small:24px;--hb-input-border-color:var(--hb-border-color,#dcdfe6);--hb-input-border-color-hover:var(--hb-color-primary);--hb-input-bg-color:var(--hb-color-white,#fff);--hb-input-text-color:var(--hb-color-text-regular,#606266);--hb-input-placeholder-color:var(--hb-color-text-placeholder,#c0c4cc);--hb-input-disabled-color:var(--hb-color-text-disabled,#c0c4cc);--hb-input-disabled-bg-color:var(--hb-fill-color-light,#f5f7fa);display:inline-block;position:relative}.hb-input{font-size:var(--hb-input-font-size);position:relative}.hb-input,.hb-input__inner{display:inline-block;width:100%}.hb-input__inner{-webkit-appearance:none;background-color:var(--hb-input-bg-color);background-image:none;border:1px solid var(--hb-input-border-color);border-radius:4px;box-sizing:border-box;color:var(--hb-input-text-color);font-size:inherit;height:var(--hb-input-height);line-height:var(--hb-input-height);outline:none;padding:0 15px;transition:border-color .2s cubic-bezier(.645,.045,.355,1)}.hb-input__inner::placeholder{color:var(--hb-input-placeholder-color)}.hb-input__inner:focus,.hb-input__inner:hover:not(:disabled){border-color:var(--hb-input-border-color-hover)}.hb-input__inner:disabled{background-color:var(--hb-input-disabled-bg-color);border-color:var(--hb-input-border-color);color:var(--hb-input-disabled-color);cursor:not-allowed}.hb-input__inner[readonly]{background-color:var(--hb-input-disabled-bg-color);cursor:default}.hb-input--small .hb-input__inner{font-size:var(--hb-input-font-size-small);height:var(--hb-input-height-small);line-height:var(--hb-input-height-small);padding:0 12px}.hb-input--large .hb-input__inner{font-size:var(--hb-input-font-size-large);height:var(--hb-input-height-large);line-height:var(--hb-input-height-large);padding:0 18px}.hb-input__prefix,.hb-input__suffix{align-items:center;color:var(--hb-input-placeholder-color);display:flex;height:100%;position:absolute;text-align:center;top:0;transition:all .3s}.hb-input__prefix{left:5px}.hb-input__suffix{right:5px}.hb-input__suffix-inner{align-items:center;cursor:pointer;display:flex;-webkit-user-select:none;user-select:none}.hb-input__clear{color:var(--hb-input-placeholder-color);font-size:16px;transition:color .2s}.hb-input__clear:hover{color:var(--hb-input-text-color)}.hb-input__password{cursor:pointer;font-size:16px}.hb-input__inner[type=textarea]{line-height:1.5;min-height:60px;padding:5px 15px;resize:vertical;vertical-align:bottom}.hb-input__count{bottom:5px;color:var(--hb-input-placeholder-color);font-size:12px;position:absolute;right:10px}.hb-input__count-inner{background-color:var(--hb-input-bg-color);padding:0 4px}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}';const d=h;const p=class{constructor(i){t(this,i);this.hbChange=e(this,"hbChange",7);this.hbInput=e(this,"hbInput",7);this.hbFocus=e(this,"hbFocus",7);this.hbBlur=e(this,"hbBlur",7);this.hbClear=e(this,"hbClear",7)}get el(){return i(this)}modelValue="";type="text";size="default";disabled=false;readonly=false;placeholder;clearable=false;showPassword=false;showWordLimit=false;maxlength;minlength;name;inputId;autocomplete;autofocus=false;prefixIcon;suffixIcon;rows=2;autosize=false;resize;isFocused=false;showClear=false;passwordVisible=false;inputValue="";inputRef;hbChange;hbInput;hbFocus;hbBlur;hbClear;handleValueChange(){this.inputValue=this.modelValue;this.updateClearVisible()}componentDidLoad(){this.inputValue=this.modelValue;this.updateClearVisible()}updateClearVisible(){this.showClear=a({clearable:this.clearable,disabled:this.disabled,readonly:this.readonly,hasValue:s(this.inputValue)})}handleInput=t=>{const e=t.target;this.inputValue=e.value;this.modelValue=e.value;this.updateClearVisible();this.hbInput.emit(e.value)};handleChange=t=>{const e=t.target;this.hbChange.emit(e.value)};handleFocus=t=>{this.isFocused=true;this.updateClearVisible();this.hbFocus.emit(t)};handleBlur=t=>{this.isFocused=false;this.updateClearVisible();this.hbBlur.emit(t)};handleClear=t=>{t.stopPropagation();this.inputValue="";this.modelValue="";this.updateClearVisible();this.hbClear.emit();this.hbChange.emit("");if(this.inputRef){this.inputRef.focus()}};togglePasswordVisible=()=>{this.passwordVisible=!this.passwordVisible};getInputType(){if(this.type==="password"&&this.showPassword){return this.passwordVisible?"text":"password"}return this.type}render(){const t=this.type==="textarea";const e=t?"textarea":"input";return o("div",{key:"22b51bd1c9e0c3086ed167eea57f3b5818685785",class:{...l("hb-input",this.size),"hb-input--disabled":this.disabled,"hb-input--focused":this.isFocused}},this.prefixIcon&&o("span",{key:"ef3b02d947c45ac282814a0e2e4909f8473469eb",class:"hb-input__prefix"},o("i",{key:"88f95312bf9aa489d5d27a1f701b2eadc794d7cf",class:this.prefixIcon})),o(e,{key:"fe5de1f3dcf5441aebb5bcc943c64d59221211d7",ref:t=>this.inputRef=t,type:t?undefined:this.getInputType(),id:this.inputId,name:this.name,class:"hb-input__inner",placeholder:this.placeholder,value:this.inputValue,disabled:this.disabled,readonly:this.readonly,autocomplete:this.autocomplete,autofocus:this.autofocus,maxlength:this.maxlength,minlength:this.minlength,rows:t?this.rows:undefined,style:t&&this.resize?{resize:this.resize}:undefined,onInput:this.handleInput,onChange:this.handleChange,onFocus:this.handleFocus,onBlur:this.handleBlur}),(this.showClear||this.suffixIcon||this.type==="password"&&this.showPassword)&&o("span",{key:"db106e66989483c48171aad758cd5a443ef7670a",class:"hb-input__suffix"},this.showClear&&o("span",{key:"3fa676f9860aa3018247c9d61bad432afdea4345",class:"hb-input__suffix-inner hb-input__clear",onClick:this.handleClear},"×"),this.type==="password"&&this.showPassword&&o("span",{key:"8911301b65aa3435f7f3b933b9b8de1b055c266e",class:"hb-input__suffix-inner hb-input__password",onClick:this.togglePasswordVisible},this.passwordVisible?"👁️":"👁️‍🗨️"),this.suffixIcon&&o("span",{key:"14fa885ec429419525ea5cd550fc7d9cec9f3ee4",class:"hb-input__suffix-inner"},o("i",{key:"36995c1f4e5d2c258170e7ad8a012e586d905e62",class:this.suffixIcon}))),this.showWordLimit&&this.maxlength&&o("span",{key:"383d7d25fbbb77dad3df3ebbbf4e0b1fc504a4b4",class:"hb-input__count"},o("span",{key:"564d4a6ac0feae0be61378f52aae3b22872566fb",class:"hb-input__count-inner"},this.inputValue.length," / ",this.maxlength)))}static get watchers(){return{modelValue:["handleValueChange"]}}};p.style=d;export{p as hb_input};
2
+ //# sourceMappingURL=p-0f189251.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["COMPONENT_SIZES","buildSizeClass","base","size","normalized","includes","isClearVisible","options","Boolean","clearable","disabled","readonly","hasValue","hasInputValue","value","undefined","length","Number","isNaN","Array","isArray","sizeClassMap","inputCss","HbInputStyle0","Input","modelValue","type","placeholder","showPassword","showWordLimit","maxlength","minlength","name","inputId","autocomplete","autofocus","prefixIcon","suffixIcon","rows","autosize","resize","isFocused","showClear","passwordVisible","inputValue","inputRef","hbChange","hbInput","hbFocus","hbBlur","hbClear","handleValueChange","this","updateClearVisible","componentDidLoad","handleInput","e","target","emit","handleChange","handleFocus","handleBlur","handleClear","stopPropagation","focus","togglePasswordVisible","getInputType","render","isTextarea","InputTag","h","key","class","ref","el","id","style","onInput","onChange","onFocus","onBlur","onClick"],"sources":["src/utils/form-input-base.ts","src/components/Input/input.css?tag=hb-input&encapsulation=shadow","src/components/Input/Input.tsx"],"sourcesContent":["/**\n * 表单输入组件共享基础\n * 统一 size / disabled / clearable / modelValue 这一组在 Input / Select / Cascader /\n * DatePicker / InputNumber / TimePicker 等组件中重复出现的包装模式。\n *\n * 设计原则:纯函数 + 类型导出,不引入基类继承,避免 Stencil 装饰器在继承链上的隐式行为。\n * 组件按需 import 对应工具,渲染时调用即可。\n */\n\n/** 组件尺寸(与 Ant Design 对齐,便于迁移) */\nexport type ComponentSize = 'large' | 'default' | 'small';\n\n/** 全部合法尺寸,用于运行期校验 */\nexport const COMPONENT_SIZES: readonly ComponentSize[] = ['large', 'default', 'small'] as const;\n\n/**\n * 表单输入组件共享的 prop 契约。\n * 跨框架消费方(React / Vue / 原生)可据此推断任一表单输入组件的通用能力,\n * 各组件在此基础上扩展自身特有 prop。\n */\nexport interface FormInputProps {\n /** 绑定值(双向,配合 hbChange 事件) */\n modelValue: unknown;\n /** 尺寸 */\n size?: ComponentSize;\n /** 是否禁用 */\n disabled?: boolean;\n /** 是否只读 */\n readonly?: boolean;\n /** 是否可清空 */\n clearable?: boolean;\n /** 占位文本 */\n placeholder?: string;\n}\n\n/**\n * 生成尺寸 class 名:buildSizeClass('hb-input', 'large') -> 'hb-input--large'\n * 用于替代各组件 render 中重复的 `[`hb-input--${this.size}`]: true` 模板字面量。\n */\nexport function buildSizeClass(base: string, size: ComponentSize | undefined): string {\n const normalized = size && COMPONENT_SIZES.includes(size) ? size : 'default';\n return `${base}--${normalized}`;\n}\n\n/** 清空按钮可见性判定参数 */\nexport interface ClearVisibleOptions {\n /** 是否声明了 clearable */\n clearable: boolean;\n /** 是否禁用(禁用时不显示) */\n disabled?: boolean;\n /** 是否只读(只读时不显示) */\n readonly?: boolean;\n /** 当前是否有值(无值时不显示) */\n hasValue: boolean;\n}\n\n/**\n * 判定清空按钮是否应显示。\n * 抽取自 Input/Select/Cascader 中重复的 `clearable && !disabled && !readonly && hasValue`。\n */\nexport function isClearVisible(options: ClearVisibleOptions): boolean {\n return Boolean(options.clearable && !options.disabled && !options.readonly && options.hasValue);\n}\n\n/**\n * 判定一个值是否「非空」(用于清空按钮显隐)。\n * 兼容字符串、数字、数组(多选)。\n */\nexport function hasInputValue(value: unknown): boolean {\n if (value === null || value === undefined) return false;\n if (typeof value === 'string') return value.length > 0;\n if (typeof value === 'number') return !Number.isNaN(value);\n if (Array.isArray(value)) return value.length > 0;\n return true;\n}\n\n/**\n * 尺寸 class 集合生成器:返回包含 base 与 size class 的对象,可直接展开进 JSX class 绑定。\n * 例:sizeClassMap('hb-input', 'large', this.size) -> { 'hb-input': true, 'hb-input--large': true }\n */\nexport function sizeClassMap(base: string, size: ComponentSize | undefined): Record<string, boolean> {\n return { [base]: true, [buildSizeClass(base, size)]: true };\n}\n",":host {\n display: inline-block;\n position: relative;\n --hb-input-font-size: 14px;\n --hb-input-font-size-large: 16px;\n --hb-input-font-size-small: 12px;\n --hb-input-height: 32px;\n --hb-input-height-large: 40px;\n --hb-input-height-small: 24px;\n --hb-input-border-color: var(--hb-border-color, #dcdfe6);\n --hb-input-border-color-hover: var(--hb-color-primary);\n --hb-input-bg-color: var(--hb-color-white, #ffffff);\n --hb-input-text-color: var(--hb-color-text-regular, #606266);\n --hb-input-placeholder-color: var(--hb-color-text-placeholder, #c0c4cc);\n --hb-input-disabled-color: var(--hb-color-text-disabled, #c0c4cc);\n --hb-input-disabled-bg-color: var(--hb-fill-color-light, #f5f7fa);\n}\n\n.hb-input {\n position: relative;\n font-size: var(--hb-input-font-size);\n display: inline-block;\n width: 100%;\n}\n\n.hb-input__inner {\n -webkit-appearance: none;\n background-color: var(--hb-input-bg-color);\n background-image: none;\n border-radius: 4px;\n border: 1px solid var(--hb-input-border-color);\n box-sizing: border-box;\n color: var(--hb-input-text-color);\n display: inline-block;\n font-size: inherit;\n height: var(--hb-input-height);\n line-height: var(--hb-input-height);\n outline: none;\n padding: 0 15px;\n transition: border-color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1);\n width: 100%;\n}\n\n.hb-input__inner::placeholder {\n color: var(--hb-input-placeholder-color);\n}\n\n.hb-input__inner:hover:not(:disabled) {\n border-color: var(--hb-input-border-color-hover);\n}\n\n.hb-input__inner:focus {\n border-color: var(--hb-input-border-color-hover);\n}\n\n.hb-input__inner:disabled {\n background-color: var(--hb-input-disabled-bg-color);\n border-color: var(--hb-input-border-color);\n color: var(--hb-input-disabled-color);\n cursor: not-allowed;\n}\n\n.hb-input__inner[readonly] {\n background-color: var(--hb-input-disabled-bg-color);\n cursor: default;\n}\n\n.hb-input--small .hb-input__inner {\n height: var(--hb-input-height-small);\n line-height: var(--hb-input-height-small);\n font-size: var(--hb-input-font-size-small);\n padding: 0 12px;\n}\n\n.hb-input--large .hb-input__inner {\n height: var(--hb-input-height-large);\n line-height: var(--hb-input-height-large);\n font-size: var(--hb-input-font-size-large);\n padding: 0 18px;\n}\n\n.hb-input__prefix,\n.hb-input__suffix {\n position: absolute;\n top: 0;\n height: 100%;\n text-align: center;\n color: var(--hb-input-placeholder-color);\n transition: all 0.3s;\n display: flex;\n align-items: center;\n}\n\n.hb-input__prefix {\n left: 5px;\n}\n\n.hb-input__suffix {\n right: 5px;\n}\n\n.hb-input__suffix-inner {\n display: flex;\n align-items: center;\n cursor: pointer;\n user-select: none;\n}\n\n.hb-input__clear {\n font-size: 16px;\n color: var(--hb-input-placeholder-color);\n transition: color 0.2s;\n}\n\n.hb-input__clear:hover {\n color: var(--hb-input-text-color);\n}\n\n.hb-input__password {\n font-size: 16px;\n cursor: pointer;\n}\n\n.hb-input__inner[type=\"textarea\"] {\n min-height: 60px;\n padding: 5px 15px;\n line-height: 1.5;\n vertical-align: bottom;\n resize: vertical;\n}\n\n.hb-input__count {\n position: absolute;\n bottom: 5px;\n right: 10px;\n font-size: 12px;\n color: var(--hb-input-placeholder-color);\n}\n\n.hb-input__count-inner {\n background-color: var(--hb-input-bg-color);\n padding: 0 4px;\n}\n\n","import { Component, h, Prop, Event, EventEmitter, State, Watch, Element } from '@stencil/core';\nimport { ComponentSize, hasInputValue, isClearVisible, sizeClassMap } from '../../utils/form-input-base';\n\n/**\n * Input 输入框组件\n * 通过鼠标或键盘输入字符\n */\n@Component({\n tag: 'hb-input',\n styleUrl: 'input.css',\n shadow: true,\n})\nexport class Input {\n @Element() el: HTMLElement;\n\n /**\n * 绑定值\n */\n @Prop({ mutable: true }) modelValue: string = '';\n\n /**\n * 输入框类型\n */\n @Prop() type: string = 'text';\n\n /**\n * 输入框尺寸\n */\n @Prop() size: ComponentSize = 'default';\n\n /**\n * 是否禁用\n * @default false\n */\n @Prop() disabled: boolean = false;\n\n /**\n * 是否只读\n * @default false\n */\n @Prop() readonly: boolean = false;\n\n /**\n * 输入框占位文本\n */\n @Prop() placeholder?: string;\n\n /**\n * 是否可清空\n * @default false\n */\n @Prop() clearable: boolean = false;\n\n /**\n * 是否显示密码可见性切换\n * @default false\n */\n @Prop() showPassword: boolean = false;\n\n /**\n * 是否显示字数统计\n * @default false\n */\n @Prop() showWordLimit: boolean = false;\n\n /**\n * 最大输入长度\n */\n @Prop() maxlength?: number;\n\n /**\n * 最小输入长度\n */\n @Prop() minlength?: number;\n\n /**\n * 原生 name 属性\n */\n @Prop() name?: string;\n\n /**\n * 原生 id 属性\n */\n @Prop() inputId?: string;\n\n /**\n * 原生 autocomplete 属性\n */\n @Prop() autocomplete?: string;\n\n /**\n * 原生 autofocus 属性\n */\n @Prop() autofocus: boolean = false;\n\n /**\n * 输入框头部图标\n */\n @Prop() prefixIcon?: string;\n\n /**\n * 输入框尾部图标\n */\n @Prop() suffixIcon?: string;\n\n /**\n * 输入框行数,仅 type 为 'textarea' 时有效\n */\n @Prop() rows: number = 2;\n\n /**\n * 是否自适应内容高度,仅 type 为 'textarea' 时有效\n */\n @Prop() autosize: boolean | { minRows?: number; maxRows?: number } = false;\n\n /**\n * 是否调整 textarea 大小\n */\n @Prop() resize?: 'none' | 'both' | 'horizontal' | 'vertical';\n\n @State() isFocused: boolean = false;\n @State() showClear: boolean = false;\n @State() passwordVisible: boolean = false;\n @State() inputValue: string = '';\n\n private inputRef?: HTMLInputElement | HTMLTextAreaElement;\n\n /**\n * 值改变事件\n */\n @Event() hbChange: EventEmitter<string>;\n\n /**\n * 输入事件\n */\n @Event() hbInput: EventEmitter<string>;\n\n /**\n * 聚焦事件\n */\n @Event() hbFocus: EventEmitter<FocusEvent>;\n\n /**\n * 失焦事件\n */\n @Event() hbBlur: EventEmitter<FocusEvent>;\n\n /**\n * 清空事件\n */\n @Event() hbClear: EventEmitter<void>;\n\n @Watch('modelValue')\n handleValueChange() {\n this.inputValue = this.modelValue;\n this.updateClearVisible();\n }\n\n componentDidLoad() {\n this.inputValue = this.modelValue;\n this.updateClearVisible();\n }\n\n private updateClearVisible() {\n this.showClear = isClearVisible({\n clearable: this.clearable,\n disabled: this.disabled,\n readonly: this.readonly,\n hasValue: hasInputValue(this.inputValue),\n });\n }\n\n private handleInput = (e: Event) => {\n const target = e.target as HTMLInputElement | HTMLTextAreaElement;\n this.inputValue = target.value;\n this.modelValue = target.value;\n this.updateClearVisible();\n this.hbInput.emit(target.value);\n };\n\n private handleChange = (e: Event) => {\n const target = e.target as HTMLInputElement | HTMLTextAreaElement;\n this.hbChange.emit(target.value);\n };\n\n private handleFocus = (e: FocusEvent) => {\n this.isFocused = true;\n this.updateClearVisible();\n this.hbFocus.emit(e);\n };\n\n private handleBlur = (e: FocusEvent) => {\n this.isFocused = false;\n this.updateClearVisible();\n this.hbBlur.emit(e);\n };\n\n private handleClear = (e: Event) => {\n e.stopPropagation();\n this.inputValue = '';\n this.modelValue = '';\n this.updateClearVisible();\n this.hbClear.emit();\n this.hbChange.emit('');\n if (this.inputRef) {\n this.inputRef.focus();\n }\n };\n\n private togglePasswordVisible = () => {\n this.passwordVisible = !this.passwordVisible;\n };\n\n private getInputType(): string {\n if (this.type === 'password' && this.showPassword) {\n return this.passwordVisible ? 'text' : 'password';\n }\n return this.type;\n }\n\n render() {\n const isTextarea = this.type === 'textarea';\n const InputTag = isTextarea ? 'textarea' : 'input';\n\n return (\n <div\n class={{\n ...sizeClassMap('hb-input', this.size),\n 'hb-input--disabled': this.disabled,\n 'hb-input--focused': this.isFocused,\n }}\n >\n {this.prefixIcon && (\n <span class=\"hb-input__prefix\">\n <i class={this.prefixIcon}></i>\n </span>\n )}\n <InputTag\n ref={(el) => (this.inputRef = el)}\n type={isTextarea ? undefined : this.getInputType()}\n id={this.inputId}\n name={this.name}\n class=\"hb-input__inner\"\n placeholder={this.placeholder}\n value={this.inputValue}\n disabled={this.disabled}\n readonly={this.readonly}\n autocomplete={this.autocomplete}\n autofocus={this.autofocus}\n maxlength={this.maxlength}\n minlength={this.minlength}\n rows={isTextarea ? this.rows : undefined}\n style={isTextarea && this.resize ? { resize: this.resize } : undefined}\n onInput={this.handleInput}\n onChange={this.handleChange}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n />\n {(this.showClear || this.suffixIcon || (this.type === 'password' && this.showPassword)) && (\n <span class=\"hb-input__suffix\">\n {this.showClear && (\n <span class=\"hb-input__suffix-inner hb-input__clear\" onClick={this.handleClear}>\n ×\n </span>\n )}\n {this.type === 'password' && this.showPassword && (\n <span class=\"hb-input__suffix-inner hb-input__password\" onClick={this.togglePasswordVisible}>\n {this.passwordVisible ? '👁️' : '👁️‍🗨️'}\n </span>\n )}\n {this.suffixIcon && (\n <span class=\"hb-input__suffix-inner\">\n <i class={this.suffixIcon}></i>\n </span>\n )}\n </span>\n )}\n {this.showWordLimit && this.maxlength && (\n <span class=\"hb-input__count\">\n <span class=\"hb-input__count-inner\">\n {this.inputValue.length} / {this.maxlength}\n </span>\n </span>\n )}\n </div>\n );\n }\n}\n\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as i,c as t,g as o,h as e}from"./p-e42dfa95.js";const n='/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{border:0 solid;box-sizing:border-box;margin:0;padding:0}::file-selector-button{appearance:button;background-color:#0000;border:0 solid;border-radius:0;box-sizing:border-box;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;margin:0;margin-inline-end:4px;opacity:1;padding:0}:host,html{-webkit-text-size-adjust:100%;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);line-height:1.5;tab-size:4;-webkit-tap-highlight-color:transparent}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-size:1em;font-variation-settings:var(--default-mono-font-variation-settings,normal)}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}button,input,optgroup,select,textarea{background-color:#0000;border-radius:0;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex;padding-block:0}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field,::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.container{width:100%}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}} /*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer components;:host{display:block}.hb-notification{align-items:flex-start;background-color:var(--hb-color-bg-elevated);border-left:4px solid var(--hb-color-primary);border-radius:var(--hb-border-radius-base);box-shadow:var(--hb-box-shadow-lg);color:var(--hb-color-text);display:flex;font-size:var(--hb-font-size-sm);gap:var(--hb-spacing-sm);max-width:calc(100vw - 32px);opacity:0;padding:var(--hb-spacing-md)var(--hb-spacing-lg);pointer-events:auto;transform:translate(0);transition:opacity .3s,transform .3s;width:320px}.hb-notification--visible{opacity:1}.hb-notification--bottom-right,.hb-notification--top-right{transform:translate(24px)}.hb-notification--bottom-right.hb-notification--visible,.hb-notification--top-right.hb-notification--visible{transform:translate(0)}.hb-notification--bottom-left,.hb-notification--top-left{transform:translate(-24px)}.hb-notification--bottom-left.hb-notification--visible,.hb-notification--top-left.hb-notification--visible{transform:translate(0)}.hb-notification--success{border-left-color:var(--hb-color-success)}.hb-notification--warning{border-left-color:var(--hb-color-warning)}.hb-notification--error{border-left-color:var(--hb-color-danger)}.hb-notification--info{border-left-color:var(--hb-color-primary)}.hb-notification__icon{align-items:center;display:inline-flex;flex-shrink:0;height:18px;justify-content:center;margin-top:2px;width:18px}.hb-notification__icon-sign{border-radius:50%;display:inline-block;height:18px;position:relative;width:18px}.hb-notification__icon-sign:after{content:"";inset:0;position:absolute}.hb-notification__icon-sign--success{background-color:var(--hb-color-success)}.hb-notification__icon-sign--success:after{color:#fff;content:"✓";font-size:12px;inset:auto 0 0;line-height:18px;text-align:center}.hb-notification__icon-sign--warning{background-color:var(--hb-color-warning)}.hb-notification__icon-sign--warning:after{color:#fff;content:"!";font-size:12px;inset:auto 0 0;line-height:18px;text-align:center}.hb-notification__icon-sign--error{background-color:var(--hb-color-danger)}.hb-notification__icon-sign--error:after{color:#fff;content:"✕";font-size:10px;inset:auto 0 0;line-height:18px;text-align:center}.hb-notification__icon-sign--info{background-color:var(--hb-color-primary)}.hb-notification__icon-sign--info:after{color:#fff;content:"i";font-size:12px;font-style:italic;font-weight:700;inset:auto 0 0;line-height:18px;text-align:center}.hb-notification__content{flex:1;min-width:0}.hb-notification__title{color:var(--hb-color-text-primary);font-size:var(--hb-font-size-base);font-weight:600;line-height:1.4;margin-bottom:var(--hb-spacing-xxs)}.hb-notification__message{color:var(--hb-color-text-secondary);line-height:1.5;word-break:break-word}.hb-notification__close{align-items:center;background:0 0;border:none;border-radius:50%;color:var(--hb-color-text-tertiary);cursor:pointer;display:inline-flex;flex-shrink:0;font-size:16px;height:20px;justify-content:center;margin-left:var(--hb-spacing-xs);transition:background-color var(--hb-transition-duration),color var(--hb-transition-duration);width:20px}.hb-notification__close:hover{background-color:var(--hb-color-fill-tertiary);color:var(--hb-color-text-secondary)}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}';const a=n;const r=class{constructor(o){i(this,o);this.hbClose=t(this,"hbClose",7)}get el(){return o(this)}id="";type="info";title="";message="";duration=4500;position="top-right";showClose=true;visible=true;hbClose;timer=null;componentDidLoad(){if(this.visible&&this.duration>0){this.timer=setTimeout((()=>this.close()),this.duration)}}disconnectedCallback(){if(this.timer){clearTimeout(this.timer);this.timer=null}}close=()=>{if(this.timer){clearTimeout(this.timer);this.timer=null}this.visible=false;this.hbClose.emit(this.id)};render(){return e("div",{key:"9848b6a924f89df2fa9996742f06986ad8c33da5",class:{"hb-notification":true,[`hb-notification--${this.type}`]:true,[`hb-notification--${this.position}`]:true,"hb-notification--visible":this.visible},role:"alert"},e("div",{key:"a15adaf1401116e0dd462fa2a9abf56595052069",class:"hb-notification__icon","aria-hidden":"true"},e("span",{key:"7d56d7ce4760963f1bd7c214c5d19c9003e302ee",class:`hb-notification__icon-sign hb-notification__icon-sign--${this.type}`})),e("div",{key:"881c23e049f6870a4f2a4db347fdfaedc331708e",class:"hb-notification__content"},this.title&&e("div",{key:"034c55a3d5b0b4bbb27657db8f2f35bf917caf91",class:"hb-notification__title"},this.title),this.message&&e("div",{key:"0d49cebbf4e1db0baa953691c7519a2a8469563d",class:"hb-notification__message"},this.message)),this.showClose&&e("button",{key:"180dc1d07aa4993a25ef97e92eb8ab4700e6c120",type:"button",class:"hb-notification__close",onClick:this.close,"aria-label":"关闭"},"×"))}};r.style=a;export{r as hb_notification};
2
+ //# sourceMappingURL=p-10c088f3.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["notificationCss","HbNotificationStyle0","Notification","id","type","title","message","duration","position","showClose","visible","hbClose","timer","componentDidLoad","this","setTimeout","close","disconnectedCallback","clearTimeout","emit","render","h","key","class","role","onClick"],"sources":["src/components/Notification/notification.css?tag=hb-notification&encapsulation=shadow","src/components/Notification/Notification.tsx"],"sourcesContent":[":host {\n display: block;\n}\n\n.hb-notification {\n display: flex;\n align-items: flex-start;\n gap: var(--hb-spacing-sm);\n width: 320px;\n max-width: calc(100vw - 32px);\n padding: var(--hb-spacing-md) var(--hb-spacing-lg);\n background-color: var(--hb-color-bg-elevated);\n border-radius: var(--hb-border-radius-base);\n box-shadow: var(--hb-box-shadow-lg);\n border-left: 4px solid var(--hb-color-primary);\n font-size: var(--hb-font-size-sm);\n color: var(--hb-color-text);\n pointer-events: auto;\n opacity: 0;\n transform: translateX(0);\n transition: opacity 0.3s, transform 0.3s;\n}\n\n.hb-notification--visible {\n opacity: 1;\n}\n\n.hb-notification--top-right,\n.hb-notification--bottom-right {\n transform: translateX(24px);\n}\n.hb-notification--top-right.hb-notification--visible,\n.hb-notification--bottom-right.hb-notification--visible {\n transform: translateX(0);\n}\n\n.hb-notification--top-left,\n.hb-notification--bottom-left {\n transform: translateX(-24px);\n}\n.hb-notification--top-left.hb-notification--visible,\n.hb-notification--bottom-left.hb-notification--visible {\n transform: translateX(0);\n}\n\n/* 类型边框色 */\n.hb-notification--success { border-left-color: var(--hb-color-success); }\n.hb-notification--warning { border-left-color: var(--hb-color-warning); }\n.hb-notification--error { border-left-color: var(--hb-color-danger); }\n.hb-notification--info { border-left-color: var(--hb-color-primary); }\n\n.hb-notification__icon {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n flex-shrink: 0;\n width: 18px;\n height: 18px;\n margin-top: 2px;\n}\n\n/* 用纯 CSS 形态表示图标,避免依赖 hb-icon */\n.hb-notification__icon-sign {\n display: inline-block;\n width: 18px;\n height: 18px;\n border-radius: 50%;\n position: relative;\n}\n.hb-notification__icon-sign::after {\n content: '';\n position: absolute;\n inset: 0;\n}\n.hb-notification__icon-sign--success {\n background-color: var(--hb-color-success);\n}\n.hb-notification__icon-sign--success::after {\n content: '✓';\n color: #fff;\n font-size: 12px;\n line-height: 18px;\n text-align: center;\n inset: auto 0 0 0;\n}\n.hb-notification__icon-sign--warning {\n background-color: var(--hb-color-warning);\n}\n.hb-notification__icon-sign--warning::after {\n content: '!';\n color: #fff;\n font-size: 12px;\n line-height: 18px;\n text-align: center;\n inset: auto 0 0 0;\n}\n.hb-notification__icon-sign--error {\n background-color: var(--hb-color-danger);\n}\n.hb-notification__icon-sign--error::after {\n content: '✕';\n color: #fff;\n font-size: 10px;\n line-height: 18px;\n text-align: center;\n inset: auto 0 0 0;\n}\n.hb-notification__icon-sign--info {\n background-color: var(--hb-color-primary);\n}\n.hb-notification__icon-sign--info::after {\n content: 'i';\n color: #fff;\n font-size: 12px;\n line-height: 18px;\n text-align: center;\n font-style: italic;\n font-weight: bold;\n inset: auto 0 0 0;\n}\n\n.hb-notification__content {\n flex: 1;\n min-width: 0;\n}\n\n.hb-notification__title {\n font-size: var(--hb-font-size-base);\n font-weight: 600;\n color: var(--hb-color-text-primary);\n margin-bottom: var(--hb-spacing-xxs);\n line-height: 1.4;\n}\n\n.hb-notification__message {\n color: var(--hb-color-text-secondary);\n line-height: 1.5;\n word-break: break-word;\n}\n\n.hb-notification__close {\n flex-shrink: 0;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: 20px;\n height: 20px;\n margin-left: var(--hb-spacing-xs);\n cursor: pointer;\n font-size: 16px;\n color: var(--hb-color-text-tertiary);\n border: none;\n background: transparent;\n border-radius: 50%;\n transition: background-color var(--hb-transition-duration), color var(--hb-transition-duration);\n}\n.hb-notification__close:hover {\n background-color: var(--hb-color-fill-tertiary);\n color: var(--hb-color-text-secondary);\n}\n","import { Component, h, Prop, Event, EventEmitter, Element } from '@stencil/core';\n\nexport type NotificationType = 'success' | 'warning' | 'info' | 'error';\nexport type NotificationPosition = 'top-right' | 'top-left' | 'bottom-right' | 'bottom-left';\n\n/**\n * Notification 通知提醒组件\n * 悬浮出现在页面角落,用于系统中较复杂的反馈。\n */\n@Component({\n tag: 'hb-notification',\n styleUrl: 'notification.css',\n shadow: true,\n})\nexport class Notification {\n @Element() el: HTMLElement;\n\n /** 唯一标识 */\n @Prop() id: string = '';\n\n /** 通知类型 */\n @Prop() type: NotificationType = 'info';\n\n /** 标题 */\n @Prop() title: string = '';\n\n /** 描述文字 */\n @Prop() message: string = '';\n\n /** 显示时间(毫秒),0 为不自动关闭 */\n @Prop() duration: number = 4500;\n\n /** 出现位置 */\n @Prop() position: NotificationPosition = 'top-right';\n\n /** 是否显示关闭按钮 */\n @Prop() showClose: boolean = true;\n\n /** 是否显示(受控) */\n @Prop({ mutable: true }) visible: boolean = true;\n\n /** 关闭事件 */\n @Event() hbClose: EventEmitter<string>;\n\n private timer: ReturnType<typeof setTimeout> | null = null;\n\n componentDidLoad() {\n if (this.visible && this.duration > 0) {\n this.timer = setTimeout(() => this.close(), this.duration);\n }\n }\n\n disconnectedCallback() {\n if (this.timer) {\n clearTimeout(this.timer);\n this.timer = null;\n }\n }\n\n private close = () => {\n if (this.timer) {\n clearTimeout(this.timer);\n this.timer = null;\n }\n this.visible = false;\n this.hbClose.emit(this.id);\n };\n\n render() {\n return (\n <div\n class={{\n 'hb-notification': true,\n [`hb-notification--${this.type}`]: true,\n [`hb-notification--${this.position}`]: true,\n 'hb-notification--visible': this.visible,\n }}\n role=\"alert\"\n >\n <div class=\"hb-notification__icon\" aria-hidden=\"true\">\n <span class={`hb-notification__icon-sign hb-notification__icon-sign--${this.type}`} />\n </div>\n <div class=\"hb-notification__content\">\n {this.title && <div class=\"hb-notification__title\">{this.title}</div>}\n {this.message && <div class=\"hb-notification__message\">{this.message}</div>}\n </div>\n {this.showClose && (\n <button type=\"button\" class=\"hb-notification__close\" onClick={this.close} aria-label=\"关闭\">\n ×\n </button>\n )}\n </div>\n );\n }\n}\n"],"mappings":"yDAAA,MAAMA,EAAkB,m/RACxB,MAAAC,EAAeD,E,MCaFE,EAAY,M,kFAIfC,GAAa,GAGbC,KAAyB,OAGzBC,MAAgB,GAGhBC,QAAkB,GAGlBC,SAAmB,KAGnBC,SAAiC,YAGjCC,UAAqB,KAGJC,QAAmB,KAGnCC,QAEDC,MAA8C,KAEtD,gBAAAC,GACE,GAAIC,KAAKJ,SAAWI,KAAKP,SAAW,EAAG,CACrCO,KAAKF,MAAQG,YAAW,IAAMD,KAAKE,SAASF,KAAKP,S,EAIrD,oBAAAU,GACE,GAAIH,KAAKF,MAAO,CACdM,aAAaJ,KAAKF,OAClBE,KAAKF,MAAQ,I,EAITI,MAAQ,KACd,GAAIF,KAAKF,MAAO,CACdM,aAAaJ,KAAKF,OAClBE,KAAKF,MAAQ,I,CAEfE,KAAKJ,QAAU,MACfI,KAAKH,QAAQQ,KAAKL,KAAKX,GAAG,EAG5B,MAAAiB,GACE,OACEC,EAAA,OAAAC,IAAA,2CACEC,MAAO,CACL,kBAAmB,KACnB,CAAC,oBAAoBT,KAAKV,QAAS,KACnC,CAAC,oBAAoBU,KAAKN,YAAa,KACvC,2BAA4BM,KAAKJ,SAEnCc,KAAK,SAELH,EAAA,OAAAC,IAAA,2CAAKC,MAAM,wBAAuB,cAAa,QAC7CF,EAAA,QAAAC,IAAA,2CAAMC,MAAO,0DAA0DT,KAAKV,UAE9EiB,EAAA,OAAAC,IAAA,2CAAKC,MAAM,4BACRT,KAAKT,OAASgB,EAAA,OAAAC,IAAA,2CAAKC,MAAM,0BAA0BT,KAAKT,OACxDS,KAAKR,SAAWe,EAAA,OAAAC,IAAA,2CAAKC,MAAM,4BAA4BT,KAAKR,UAE9DQ,KAAKL,WACJY,EAAA,UAAAC,IAAA,2CAAQlB,KAAK,SAASmB,MAAM,yBAAyBE,QAASX,KAAKE,MAAK,aAAa,MAAI,K","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as e,g as t,h as i}from"./p-e42dfa95.js";import{c as o,g as a}from"./p-ecce2b5e.js";const r='/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{border:0 solid;box-sizing:border-box;margin:0;padding:0}::file-selector-button{appearance:button;background-color:#0000;border:0 solid;border-radius:0;box-sizing:border-box;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;margin:0;margin-inline-end:4px;opacity:1;padding:0}:host,html{-webkit-text-size-adjust:100%;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);line-height:1.5;tab-size:4;-webkit-tap-highlight-color:transparent}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-size:1em;font-variation-settings:var(--default-mono-font-variation-settings,normal)}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}button,input,optgroup,select,textarea{background-color:#0000;border-radius:0;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex;padding-block:0}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field,::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}} /*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer components;.hb-popover__trigger,:host{display:inline-block}.hb-popover__popup{animation:hb-popover-fade .15s ease-out;background:var(--hb-color-bg-elevated);border-radius:var(--hb-border-radius-base);box-shadow:var(--hb-box-shadow);padding:var(--hb-spacing-sm)0;pointer-events:auto;position:fixed}.hb-popover__title{border-bottom:1px solid var(--hb-color-border-secondary);font-size:var(--hb-font-size-sm);font-weight:600;padding:var(--hb-spacing-xs)var(--hb-spacing-md)}.hb-popover__body{color:var(--hb-color-text);font-size:var(--hb-font-size-sm);padding:var(--hb-spacing-sm)var(--hb-spacing-md)}@keyframes hb-popover-fade{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}';const n=r;const s=class{constructor(t){e(this,t)}get el(){return t(this)}title="";width="240px";placement="bottom";trigger="hover";disabled=false;visible=false;popupStyle={};triggerRef;popupRef;show=()=>{if(!this.disabled){this.visible=true;requestAnimationFrame((()=>this.updatePosition()))}};hide=()=>{this.visible=false};toggle=()=>{if(this.visible){this.hide()}else{this.show()}};updatePosition(){if(!this.triggerRef||!this.popupRef)return;const e=this.triggerRef.getBoundingClientRect();const{width:t,height:i}=this.popupRef.getBoundingClientRect();const r=o(e,t,i,this.placement,8);this.popupStyle={top:`${r.top}px`,left:`${r.left}px`,zIndex:String(a())}}render(){const e=this.trigger==="hover"?{onMouseEnter:this.show,onMouseLeave:this.hide}:{onClick:this.toggle};return i("div",{key:"b094fdab875b54a1334489467d87cab19d5d495c",class:"hb-popover",...e},i("div",{key:"0d87497b9f31c97aab530a5298722b594388a036",ref:e=>{this.triggerRef=e},class:"hb-popover__trigger"},i("slot",{key:"93740d59a42e448997f44fe9a636e2858d15121a"})),this.visible&&i("div",{key:"54f77abc1aa942b45e69bf4c63ec6b8f4fd49bad",ref:e=>{this.popupRef=e},class:"hb-popover__popup",style:{...this.popupStyle,width:this.width},onMouseEnter:()=>this.trigger==="hover"&&this.show(),onMouseLeave:()=>this.trigger==="hover"&&this.hide()},this.title&&i("div",{key:"44f71196d287712f9895546d03d1849ba2092241",class:"hb-popover__title"},this.title),i("div",{key:"7f558d395de6937bb453f9a3453509654fb14514",class:"hb-popover__body"},i("slot",{key:"19677384409687a3936393b2aaf6722c071de5eb",name:"content"}))))}};s.style=n;export{s as hb_popover};
2
+ //# sourceMappingURL=p-1b5acd6d.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["popoverCss","HbPopoverStyle0","Popover","title","width","placement","trigger","disabled","visible","popupStyle","triggerRef","popupRef","show","this","requestAnimationFrame","updatePosition","hide","toggle","rect","getBoundingClientRect","pw","height","ph","pos","computePosition","top","left","zIndex","String","getNextZIndex","render","events","onMouseEnter","onMouseLeave","onClick","h","key","class","ref","el","style","name"],"sources":["src/components/Popover/popover.css?tag=hb-popover&encapsulation=shadow","src/components/Popover/Popover.tsx"],"sourcesContent":[":host { display: inline-block; }\n.hb-popover__trigger { display: inline-block; }\n.hb-popover__popup {\n position: fixed; background: var(--hb-color-bg-elevated);\n border-radius: var(--hb-border-radius-base); box-shadow: var(--hb-box-shadow);\n padding: var(--hb-spacing-sm) 0; animation: hb-popover-fade 0.15s ease-out; pointer-events: auto;\n}\n.hb-popover__title { padding: var(--hb-spacing-xs) var(--hb-spacing-md); font-weight: 600; font-size: var(--hb-font-size-sm); border-bottom: 1px solid var(--hb-color-border-secondary); }\n.hb-popover__body { padding: var(--hb-spacing-sm) var(--hb-spacing-md); font-size: var(--hb-font-size-sm); color: var(--hb-color-text); }\n@keyframes hb-popover-fade { from { opacity: 0; transform: scale(0.95); } to { opacity: 1; transform: scale(1); } }\n","import { Component, h, Prop, State, Element } from '@stencil/core';\nimport { computePosition, getNextZIndex, Placement } from '../../utils/popup-manager';\n\n@Component({ tag: 'hb-popover', styleUrl: 'popover.css', shadow: true })\nexport class Popover {\n @Element() el: HTMLElement;\n // 注意:使用默认值使其成为 required string,避免与 HTMLElement.title(string)\n // 的可选类型冲突;同时保留 Ant Design 兼容的 `title` API。\n @Prop() title: string = '';\n @Prop() width: string = '240px';\n @Prop() placement: Placement = 'bottom';\n @Prop() trigger: 'hover' | 'click' = 'hover';\n @Prop() disabled: boolean = false;\n @State() visible: boolean = false;\n @State() popupStyle: Record<string, string> = {};\n\n private triggerRef?: HTMLElement;\n private popupRef?: HTMLDivElement;\n\n private show = () => { if (!this.disabled) { this.visible = true; requestAnimationFrame(() => this.updatePosition()); } };\n private hide = () => { this.visible = false; };\n private toggle = () => {\n if (this.visible) {\n this.hide();\n } else {\n this.show();\n }\n };\n\n private updatePosition() {\n if (!this.triggerRef || !this.popupRef) return;\n const rect = this.triggerRef.getBoundingClientRect();\n const { width: pw, height: ph } = this.popupRef.getBoundingClientRect();\n const pos = computePosition(rect, pw, ph, this.placement, 8);\n this.popupStyle = { top: `${pos.top}px`, left: `${pos.left}px`, zIndex: String(getNextZIndex()) };\n }\n\n render() {\n const events = this.trigger === 'hover' ? { onMouseEnter: this.show, onMouseLeave: this.hide } : { onClick: this.toggle };\n return (\n <div class=\"hb-popover\" {...events}>\n <div ref={(el: any) => { this.triggerRef = el; }} class=\"hb-popover__trigger\"><slot /></div>\n {this.visible && (\n <div ref={(el: any) => { this.popupRef = el; }} class=\"hb-popover__popup\" style={{ ...this.popupStyle, width: this.width }}\n onMouseEnter={() => this.trigger === 'hover' && this.show()} onMouseLeave={() => this.trigger === 'hover' && this.hide()}>\n {this.title && <div class=\"hb-popover__title\">{this.title}</div>}\n <div class=\"hb-popover__body\"><slot name=\"content\" /></div>\n </div>\n )}\n </div>\n );\n }\n}\n"],"mappings":"6FAAA,MAAMA,EAAa,+vMACnB,MAAAC,EAAeD,E,MCGFE,EAAO,M,iDAIVC,MAAgB,GAChBC,MAAgB,QAChBC,UAAuB,SACvBC,QAA6B,QAC7BC,SAAoB,MACnBC,QAAmB,MACnBC,WAAqC,GAEtCC,WACAC,SAEAC,KAAO,KAAQ,IAAKC,KAAKN,SAAU,CAAEM,KAAKL,QAAU,KAAMM,uBAAsB,IAAMD,KAAKE,kB,GAC3FC,KAAO,KAAQH,KAAKL,QAAU,KAAK,EACnCS,OAAS,KACf,GAAIJ,KAAKL,QAAS,CAChBK,KAAKG,M,KACA,CACLH,KAAKD,M,GAID,cAAAG,GACN,IAAKF,KAAKH,aAAeG,KAAKF,SAAU,OACxC,MAAMO,EAAOL,KAAKH,WAAWS,wBAC7B,MAAQf,MAAOgB,EAAIC,OAAQC,GAAOT,KAAKF,SAASQ,wBAChD,MAAMI,EAAMC,EAAgBN,EAAME,EAAIE,EAAIT,KAAKR,UAAW,GAC1DQ,KAAKJ,WAAa,CAAEgB,IAAK,GAAGF,EAAIE,QAASC,KAAM,GAAGH,EAAIG,SAAUC,OAAQC,OAAOC,K,CAGjF,MAAAC,GACE,MAAMC,EAASlB,KAAKP,UAAY,QAAU,CAAE0B,aAAcnB,KAAKD,KAAMqB,aAAcpB,KAAKG,MAAS,CAAEkB,QAASrB,KAAKI,QACjH,OACEkB,EAAA,OAAAC,IAAA,2CAAKC,MAAM,gBAAiBN,GAC1BI,EAAA,OAAAC,IAAA,2CAAKE,IAAMC,IAAc1B,KAAKH,WAAa6B,CAAE,EAAKF,MAAM,uBAAsBF,EAAA,QAAAC,IAAA,8CAC7EvB,KAAKL,SACJ2B,EAAA,OAAAC,IAAA,2CAAKE,IAAMC,IAAc1B,KAAKF,SAAW4B,CAAE,EAAKF,MAAM,oBAAoBG,MAAO,IAAK3B,KAAKJ,WAAYL,MAAOS,KAAKT,OACjH4B,aAAc,IAAMnB,KAAKP,UAAY,SAAWO,KAAKD,OAAQqB,aAAc,IAAMpB,KAAKP,UAAY,SAAWO,KAAKG,QACjHH,KAAKV,OAASgC,EAAA,OAAAC,IAAA,2CAAKC,MAAM,qBAAqBxB,KAAKV,OACpDgC,EAAA,OAAAC,IAAA,2CAAKC,MAAM,oBAAmBF,EAAA,QAAAC,IAAA,2CAAMK,KAAK,c","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as t,c as e,g as i,h as o}from"./p-e42dfa95.js";const r='/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{border:0 solid;box-sizing:border-box;margin:0;padding:0}::file-selector-button{appearance:button;background-color:#0000;border:0 solid;border-radius:0;box-sizing:border-box;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;margin:0;margin-inline-end:4px;opacity:1;padding:0}:host,html{-webkit-text-size-adjust:100%;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);line-height:1.5;tab-size:4;-webkit-tap-highlight-color:transparent}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-size:1em;font-variation-settings:var(--default-mono-font-variation-settings,normal)}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}button,input,optgroup,select,textarea{background-color:#0000;border-radius:0;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex;padding-block:0}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field,::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}} /*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer components;:host{display:block}.hb-tour{inset:0;pointer-events:auto;position:fixed;z-index:var(--hb-z-index-popover)}.hb-tour__mask{background:0 0;cursor:default;inset:0;position:absolute}.hb-tour__card{background-color:var(--hb-color-bg-elevated);border-radius:var(--hb-border-radius-base);box-shadow:var(--hb-box-shadow-lg);color:var(--hb-color-text);font-size:var(--hb-font-size-sm);max-width:calc(100vw - 32px);padding:var(--hb-spacing-lg);position:absolute;width:340px;z-index:1}.hb-tour__header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--hb-spacing-sm)}.hb-tour__title{color:var(--hb-color-text-primary);font-size:var(--hb-font-size-lg);font-weight:600}.hb-tour__close{align-items:center;background:0 0;border:none;border-radius:50%;color:var(--hb-color-text-tertiary);cursor:pointer;display:inline-flex;font-size:18px;height:24px;justify-content:center;line-height:1;transition:background-color var(--hb-transition-duration),color var(--hb-transition-duration);width:24px}.hb-tour__close:hover{background-color:var(--hb-color-fill-tertiary);color:var(--hb-color-text-secondary)}.hb-tour__body{color:var(--hb-color-text-secondary);line-height:1.6;margin-bottom:var(--hb-spacing-lg)}.hb-tour__footer{align-items:center;display:flex;justify-content:space-between}.hb-tour__indicator{color:var(--hb-color-text-tertiary);font-size:var(--hb-font-size-xs)}.hb-tour__actions{gap:var(--hb-spacing-xs)}.hb-tour__actions,.hb-tour__btn{align-items:center;display:inline-flex}.hb-tour__btn{background-color:var(--hb-color-bg-elevated);border:1px solid var(--hb-color-border);border-radius:var(--hb-border-radius-base);color:var(--hb-color-text);cursor:pointer;font-size:var(--hb-font-size-sm);height:32px;justify-content:center;padding:0 var(--hb-spacing-lg);transition:all var(--hb-transition-duration)}.hb-tour__btn:hover{border-color:var(--hb-color-primary-border);color:var(--hb-color-primary)}.hb-tour__btn--next{background-color:var(--hb-color-primary);border-color:var(--hb-color-primary);color:var(--hb-color-text-inverse)}.hb-tour__btn--next:hover{background-color:var(--hb-color-primary-hover);border-color:var(--hb-color-primary-hover);color:var(--hb-color-text-inverse)}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}';const n=r;const a=class{constructor(i){t(this,i);this.hbChange=e(this,"hbChange",7);this.hbClose=e(this,"hbClose",7)}get el(){return i(this)}visible=false;steps=[];current=0;hbChange;hbClose;targetRect=null;get currentStep(){return this.steps[this.current]}get isLast(){return this.current>=this.steps.length-1}get isFirst(){return this.current<=0}componentDidRender(){this.updateTargetRect()}componentDidUpdate(){this.updateTargetRect()}updateTargetRect(){const t=this.currentStep;if(!t||!this.visible){this.targetRect=null;return}const e=document.querySelector(t.target);if(e){this.targetRect=e.getBoundingClientRect()}else{this.targetRect=null}}goNext=()=>{if(this.isLast){this.finish();return}this.current=this.current+1;this.hbChange.emit(this.current)};goPrev=()=>{if(this.isFirst)return;this.current=this.current-1;this.hbChange.emit(this.current)};finish=()=>{this.visible=false;this.hbClose.emit()};cardStyle(){const t=this.targetRect;if(t&&(t.width>0||t.height>0)){return{left:`${t.right+12}px`,top:`${t.top}px`}}return{left:"50%",top:"50%",transform:"translate(-50%, -50%)"}}maskStyle(){const t=this.targetRect;if(t&&(t.width>0||t.height>0)){const e=t.top;const i=window.innerWidth-t.right;const o=window.innerHeight-t.bottom;const r=t.left;return{boxShadow:[`0 0 0 9999px var(--hb-color-bg-mask)`,`${r}px ${o}px 0 ${i}px transparent`,`${r}px ${e}px 0 ${i}px transparent`,`0 ${o}px 0 ${i}px transparent`,`0 ${e}px 0 ${r}px transparent`].join(", ")}}return{background:"var(--hb-color-bg-mask)"}}render(){if(!this.visible||this.steps.length===0)return null;const t=this.currentStep;if(!t)return null;return o("div",{class:"hb-tour"},o("div",{class:"hb-tour__mask",style:this.maskStyle(),onClick:this.finish}),o("div",{class:"hb-tour__card",style:this.cardStyle(),role:"dialog","aria-modal":"true"},o("div",{class:"hb-tour__header"},o("span",{class:"hb-tour__title"},t.title),o("button",{type:"button",class:"hb-tour__close",onClick:this.finish,"aria-label":"关闭"},"×")),o("div",{class:"hb-tour__body"},t.description),o("div",{class:"hb-tour__footer"},o("span",{class:"hb-tour__indicator"},this.current+1," / ",this.steps.length),o("div",{class:"hb-tour__actions"},!this.isFirst&&o("button",{type:"button",class:"hb-tour__btn hb-tour__btn--prev",onClick:this.goPrev},"上一步"),o("button",{type:"button",class:"hb-tour__btn hb-tour__btn--next",onClick:this.goNext},this.isLast?"完成":"下一步")))))}};a.style=n;export{a as hb_tour};
2
+ //# sourceMappingURL=p-1e5abc8a.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["tourCss","HbTourStyle0","Tour","visible","steps","current","hbChange","hbClose","targetRect","currentStep","this","isLast","length","isFirst","componentDidRender","updateTargetRect","componentDidUpdate","step","targetEl","document","querySelector","target","getBoundingClientRect","goNext","finish","emit","goPrev","cardStyle","rect","width","height","left","right","top","transform","maskStyle","window","innerWidth","bottom","innerHeight","boxShadow","join","background","render","h","class","style","onClick","role","title","type","description"],"sources":["src/components/Tour/tour.css?tag=hb-tour&encapsulation=shadow","src/components/Tour/Tour.tsx"],"sourcesContent":[":host {\n display: block;\n}\n\n.hb-tour {\n position: fixed;\n inset: 0;\n z-index: var(--hb-z-index-popover);\n pointer-events: auto;\n}\n\n/* 镂空遮罩(box-shadow 多段方案;jsdom 下退化为纯色遮罩) */\n.hb-tour__mask {\n position: absolute;\n inset: 0;\n background: transparent;\n cursor: default;\n}\n\n.hb-tour__card {\n position: absolute;\n width: 340px;\n max-width: calc(100vw - 32px);\n padding: var(--hb-spacing-lg);\n background-color: var(--hb-color-bg-elevated);\n border-radius: var(--hb-border-radius-base);\n box-shadow: var(--hb-box-shadow-lg);\n color: var(--hb-color-text);\n font-size: var(--hb-font-size-sm);\n z-index: 1;\n}\n\n.hb-tour__header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n margin-bottom: var(--hb-spacing-sm);\n}\n\n.hb-tour__title {\n font-size: var(--hb-font-size-lg);\n font-weight: 600;\n color: var(--hb-color-text-primary);\n}\n\n.hb-tour__close {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: 24px;\n height: 24px;\n border: none;\n background: transparent;\n color: var(--hb-color-text-tertiary);\n cursor: pointer;\n font-size: 18px;\n line-height: 1;\n border-radius: 50%;\n transition: background-color var(--hb-transition-duration), color var(--hb-transition-duration);\n}\n.hb-tour__close:hover {\n background-color: var(--hb-color-fill-tertiary);\n color: var(--hb-color-text-secondary);\n}\n\n.hb-tour__body {\n color: var(--hb-color-text-secondary);\n line-height: 1.6;\n margin-bottom: var(--hb-spacing-lg);\n}\n\n.hb-tour__footer {\n display: flex;\n align-items: center;\n justify-content: space-between;\n}\n\n.hb-tour__indicator {\n color: var(--hb-color-text-tertiary);\n font-size: var(--hb-font-size-xs);\n}\n\n.hb-tour__actions {\n display: inline-flex;\n align-items: center;\n gap: var(--hb-spacing-xs);\n}\n\n.hb-tour__btn {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n height: 32px;\n padding: 0 var(--hb-spacing-lg);\n font-size: var(--hb-font-size-sm);\n border-radius: var(--hb-border-radius-base);\n border: 1px solid var(--hb-color-border);\n background-color: var(--hb-color-bg-elevated);\n color: var(--hb-color-text);\n cursor: pointer;\n transition: all var(--hb-transition-duration);\n}\n.hb-tour__btn:hover {\n color: var(--hb-color-primary);\n border-color: var(--hb-color-primary-border);\n}\n\n.hb-tour__btn--next {\n background-color: var(--hb-color-primary);\n border-color: var(--hb-color-primary);\n color: var(--hb-color-text-inverse);\n}\n.hb-tour__btn--next:hover {\n background-color: var(--hb-color-primary-hover);\n border-color: var(--hb-color-primary-hover);\n color: var(--hb-color-text-inverse);\n}\n","import { Component, h, Prop, Event, EventEmitter, State, Element } from '@stencil/core';\n\nexport interface TourStep {\n /** 目标元素 CSS selector */\n target: string;\n /** 步骤标题 */\n title: string;\n /** 步骤描述 */\n description: string;\n}\n\n/**\n * Tour 引导组件\n * 通过遮罩 + 高亮卡片引导用户关注页面元素。\n */\n@Component({\n tag: 'hb-tour',\n styleUrl: 'tour.css',\n shadow: true,\n})\nexport class Tour {\n @Element() el: HTMLElement;\n\n /** 是否显示(受控) */\n @Prop({ mutable: true }) visible: boolean = false;\n\n /** 步骤列表 */\n @Prop() steps: TourStep[] = [];\n\n /** 当前步骤索引 */\n @Prop({ mutable: true }) current: number = 0;\n\n /** 步骤变化事件,detail 为新 current */\n @Event() hbChange: EventEmitter<number>;\n\n /** 关闭事件 */\n @Event() hbClose: EventEmitter<void>;\n\n @State() private targetRect: DOMRect | null = null;\n\n private get currentStep(): TourStep | undefined {\n return this.steps[this.current];\n }\n\n private get isLast(): boolean {\n return this.current >= this.steps.length - 1;\n }\n\n private get isFirst(): boolean {\n return this.current <= 0;\n }\n\n componentDidRender() {\n this.updateTargetRect();\n }\n\n componentDidUpdate() {\n this.updateTargetRect();\n }\n\n private updateTargetRect() {\n const step = this.currentStep;\n if (!step || !this.visible) {\n this.targetRect = null;\n return;\n }\n const targetEl = document.querySelector(step.target) as HTMLElement | null;\n if (targetEl) {\n this.targetRect = targetEl.getBoundingClientRect();\n } else {\n this.targetRect = null;\n }\n }\n\n private goNext = () => {\n if (this.isLast) {\n this.finish();\n return;\n }\n this.current = this.current + 1;\n this.hbChange.emit(this.current);\n };\n\n private goPrev = () => {\n if (this.isFirst) return;\n this.current = this.current - 1;\n this.hbChange.emit(this.current);\n };\n\n private finish = () => {\n this.visible = false;\n this.hbClose.emit();\n };\n\n private cardStyle(): Record<string, string> {\n const rect = this.targetRect;\n // jsdom 下 getBoundingClientRect 返回 0 尺寸,提供兜底位置\n if (rect && (rect.width > 0 || rect.height > 0)) {\n return {\n left: `${rect.right + 12}px`,\n top: `${rect.top}px`,\n };\n }\n return { left: '50%', top: '50%', transform: 'translate(-50%, -50%)' };\n }\n\n private maskStyle(): Record<string, string> {\n const rect = this.targetRect;\n if (rect && (rect.width > 0 || rect.height > 0)) {\n // 4 段 box-shadow 实现镂空遮罩\n const top = rect.top;\n const right = window.innerWidth - rect.right;\n const bottom = window.innerHeight - rect.bottom;\n const left = rect.left;\n return {\n boxShadow: [\n `0 0 0 9999px var(--hb-color-bg-mask)`,\n `${left}px ${bottom}px 0 ${right}px transparent`,\n `${left}px ${top}px 0 ${right}px transparent`,\n `0 ${bottom}px 0 ${right}px transparent`,\n `0 ${top}px 0 ${left}px transparent`,\n ].join(', '),\n };\n }\n return { background: 'var(--hb-color-bg-mask)' };\n }\n\n render() {\n if (!this.visible || this.steps.length === 0) return null;\n\n const step = this.currentStep;\n if (!step) return null;\n\n return (\n <div class=\"hb-tour\">\n <div\n class=\"hb-tour__mask\"\n style={this.maskStyle()}\n onClick={this.finish}\n />\n <div\n class=\"hb-tour__card\"\n style={this.cardStyle()}\n role=\"dialog\"\n aria-modal=\"true\"\n >\n <div class=\"hb-tour__header\">\n <span class=\"hb-tour__title\">{step.title}</span>\n <button\n type=\"button\"\n class=\"hb-tour__close\"\n onClick={this.finish}\n aria-label=\"关闭\"\n >\n ×\n </button>\n </div>\n <div class=\"hb-tour__body\">{step.description}</div>\n <div class=\"hb-tour__footer\">\n <span class=\"hb-tour__indicator\">\n {this.current + 1} / {this.steps.length}\n </span>\n <div class=\"hb-tour__actions\">\n {!this.isFirst && (\n <button type=\"button\" class=\"hb-tour__btn hb-tour__btn--prev\" onClick={this.goPrev}>\n 上一步\n </button>\n )}\n <button type=\"button\" class=\"hb-tour__btn hb-tour__btn--next\" onClick={this.goNext}>\n {this.isLast ? '完成' : '下一步'}\n </button>\n </div>\n </div>\n </div>\n </div>\n );\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as t,c as i,h as e}from"./p-e42dfa95.js";const o='/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{border:0 solid;box-sizing:border-box;margin:0;padding:0}::file-selector-button{appearance:button;background-color:#0000;border:0 solid;border-radius:0;box-sizing:border-box;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;margin:0;margin-inline-end:4px;opacity:1;padding:0}:host,html{-webkit-text-size-adjust:100%;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);line-height:1.5;tab-size:4;-webkit-tap-highlight-color:transparent}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-size:1em;font-variation-settings:var(--default-mono-font-variation-settings,normal)}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}button,input,optgroup,select,textarea{background-color:#0000;border-radius:0;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex;padding-block:0}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field,::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.sticky{position:sticky}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}} /*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer components;:host{display:inline-block}.hb-anchor{padding-left:var(--hb-spacing-md);position:relative}.hb-anchor__ink{background-color:var(--hb-color-border,var(--hb-color-fill-secondary));border-radius:var(--hb-border-radius-xs);bottom:0;left:0;position:absolute;top:0;width:2px}.hb-anchor__list{list-style:none;margin:0;padding:0}.hb-anchor__item{margin-bottom:var(--hb-spacing-xs)}.hb-anchor__item:last-child{margin-bottom:0}.hb-anchor__link{border-radius:var(--hb-border-radius-xs);color:var(--hb-color-text-secondary);cursor:pointer;display:inline-block;font-size:var(--hb-font-size-sm);line-height:1.5;padding:var(--hb-spacing-xxs)var(--hb-spacing-xs);text-decoration:none;transition:color var(--hb-transition-duration)var(--hb-transition-function)}.hb-anchor__link--active,.hb-anchor__link:hover{color:var(--hb-color-primary)}.hb-anchor__link--active{font-weight:500}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}';const n=o;const a=class{constructor(e){t(this,e);this.hbClick=i(this,"hbClick",7)}items=[];top;affix=true;activeKey="";hbClick;handleClick=(t,i)=>{i.preventDefault();this.activeKey=t.key;this.hbClick.emit({key:t.key,href:t.href})};render(){const t={};if(this.affix&&this.top!==undefined){t.position="sticky";t.top=`${this.top}px`}return e("div",{key:"dc32d578ca843183041cfa36765c16972d96eb0a",class:"hb-anchor",style:t},e("div",{key:"9d70c1be7984c61815bb596328aa78486f077b37",class:"hb-anchor__ink","aria-hidden":"true"}),e("ul",{key:"208c2b0f328c8815e360347a06531146fdf34359",class:"hb-anchor__list"},this.items.map((t=>e("li",{class:"hb-anchor__item"},e("a",{class:{"hb-anchor__link":true,"hb-anchor__link--active":this.activeKey===t.key},href:t.href,"data-key":t.key,onClick:i=>this.handleClick(t,i)},t.title))))))}};a.style=n;export{a as hb_anchor};
2
+ //# sourceMappingURL=p-1f0b1662.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["anchorCss","HbAnchorStyle0","Anchor","items","top","affix","activeKey","hbClick","handleClick","item","e","preventDefault","this","key","emit","href","render","wrapperStyle","undefined","position","h","class","style","map","onClick","title"],"sources":["src/components/Anchor/anchor.css?tag=hb-anchor&encapsulation=shadow","src/components/Anchor/Anchor.tsx"],"sourcesContent":[":host {\n display: inline-block;\n}\n\n.hb-anchor {\n position: relative;\n padding-left: var(--hb-spacing-md);\n}\n\n.hb-anchor__ink {\n position: absolute;\n left: 0;\n top: 0;\n bottom: 0;\n width: 2px;\n background-color: var(--hb-color-border, var(--hb-color-fill-secondary));\n border-radius: var(--hb-border-radius-xs);\n}\n\n.hb-anchor__list {\n list-style: none;\n margin: 0;\n padding: 0;\n}\n\n.hb-anchor__item {\n margin-bottom: var(--hb-spacing-xs);\n}\n\n.hb-anchor__item:last-child {\n margin-bottom: 0;\n}\n\n.hb-anchor__link {\n display: inline-block;\n padding: var(--hb-spacing-xxs) var(--hb-spacing-xs);\n font-size: var(--hb-font-size-sm);\n line-height: 1.5;\n color: var(--hb-color-text-secondary);\n text-decoration: none;\n cursor: pointer;\n border-radius: var(--hb-border-radius-xs);\n transition: color var(--hb-transition-duration) var(--hb-transition-function);\n}\n\n.hb-anchor__link:hover {\n color: var(--hb-color-primary);\n}\n\n.hb-anchor__link--active {\n color: var(--hb-color-primary);\n font-weight: 500;\n}\n","import { Component, h, Prop, State, Event, EventEmitter } from '@stencil/core';\n\nexport interface AnchorItem {\n key: string;\n href: string;\n title: string;\n}\n\nexport interface AnchorClickDetail {\n key: string;\n href: string;\n}\n\n/**\n * Anchor 锚点组件\n * 用于跳转到页面内指定锚点位置的超链接列表\n */\n@Component({\n tag: 'hb-anchor',\n styleUrl: 'anchor.css',\n shadow: true,\n})\nexport class Anchor {\n /** 锚点项数组 */\n @Prop() items: AnchorItem[] = [];\n\n /** 距离窗口顶部偏移(固定时使用) */\n @Prop() top: number | undefined;\n\n /** 是否启用固钉模式(affix 包裹) */\n @Prop() affix: boolean = true;\n\n /** 当前选中项的 key */\n @State() activeKey: string = '';\n\n /** 点击锚点项事件 */\n @Event() hbClick: EventEmitter<AnchorClickDetail>;\n\n private handleClick = (item: AnchorItem, e: MouseEvent) => {\n e.preventDefault();\n this.activeKey = item.key;\n this.hbClick.emit({ key: item.key, href: item.href });\n };\n\n render() {\n const wrapperStyle: Record<string, string> = {};\n if (this.affix && this.top !== undefined) {\n wrapperStyle.position = 'sticky';\n wrapperStyle.top = `${this.top}px`;\n }\n\n return (\n <div class=\"hb-anchor\" style={wrapperStyle}>\n <div class=\"hb-anchor__ink\" aria-hidden=\"true\"></div>\n <ul class=\"hb-anchor__list\">\n {this.items.map((item) => (\n <li class=\"hb-anchor__item\">\n <a\n class={{\n 'hb-anchor__link': true,\n 'hb-anchor__link--active': this.activeKey === item.key,\n }}\n href={item.href}\n data-key={item.key}\n onClick={(e) => this.handleClick(item, e)}\n >\n {item.title}\n </a>\n </li>\n ))}\n </ul>\n </div>\n );\n }\n}\n"],"mappings":"kDAAA,MAAMA,EAAY,g7MAClB,MAAAC,EAAeD,E,MCqBFE,EAAM,M,0DAETC,MAAsB,GAGtBC,IAGAC,MAAiB,KAGhBC,UAAoB,GAGpBC,QAEDC,YAAc,CAACC,EAAkBC,KACvCA,EAAEC,iBACFC,KAAKN,UAAYG,EAAKI,IACtBD,KAAKL,QAAQO,KAAK,CAAED,IAAKJ,EAAKI,IAAKE,KAAMN,EAAKM,MAAO,EAGvD,MAAAC,GACE,MAAMC,EAAuC,GAC7C,GAAIL,KAAKP,OAASO,KAAKR,MAAQc,UAAW,CACxCD,EAAaE,SAAW,SACxBF,EAAab,IAAM,GAAGQ,KAAKR,O,CAG7B,OACEgB,EAAA,OAAAP,IAAA,2CAAKQ,MAAM,YAAYC,MAAOL,GAC5BG,EAAA,OAAAP,IAAA,2CAAKQ,MAAM,iBAAgB,cAAa,SACxCD,EAAA,MAAAP,IAAA,2CAAIQ,MAAM,mBACPT,KAAKT,MAAMoB,KAAKd,GACfW,EAAA,MAAIC,MAAM,mBACRD,EAAA,KACEC,MAAO,CACL,kBAAmB,KACnB,0BAA2BT,KAAKN,YAAcG,EAAKI,KAErDE,KAAMN,EAAKM,KAAI,WACLN,EAAKI,IACfW,QAAUd,GAAME,KAAKJ,YAAYC,EAAMC,IAEtCD,EAAKgB,W","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as t,h as e}from"./p-e42dfa95.js";const i='/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{border:0 solid;box-sizing:border-box;margin:0;padding:0}::file-selector-button{appearance:button;background-color:#0000;border:0 solid;border-radius:0;box-sizing:border-box;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;margin:0;margin-inline-end:4px;opacity:1;padding:0}:host,html{-webkit-text-size-adjust:100%;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);line-height:1.5;tab-size:4;-webkit-tap-highlight-color:transparent}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-size:1em;font-variation-settings:var(--default-mono-font-variation-settings,normal)}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}button,input,optgroup,select,textarea{background-color:#0000;border-radius:0;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex;padding-block:0}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field,::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}} /*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer components;:host{--hb-aside-width:200px;--hb-aside-padding:20px;--hb-aside-bg-color:var(--hb-color-white,#fff);display:block}.hb-aside{background-color:var(--hb-aside-bg-color);box-sizing:border-box;overflow:auto;padding:var(--hb-aside-padding);width:var(--hb-aside-width)}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}';const o=i;const a=class{constructor(e){t(this,e)}width;render(){const t={};if(this.width){t.width=this.width}return e("aside",{key:"f3a737773569b17eaeba7a061c087048d2f0b0d7",class:"hb-aside",style:t},e("slot",{key:"fde6d1fa95d2bb5c42202413b5c5716c85b26a7b"}))}};a.style=o;export{a as hb_aside};
2
+ //# sourceMappingURL=p-21682e92.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["asideCss","HbAsideStyle0","Aside","width","render","style","this","h","key","class"],"sources":["src/components/Container/aside.css?tag=hb-aside&encapsulation=shadow","src/components/Container/Aside.tsx"],"sourcesContent":[":host {\n display: block;\n --hb-aside-width: 200px;\n --hb-aside-padding: 20px;\n --hb-aside-bg-color: var(--hb-color-white, #ffffff);\n}\n\n.hb-aside {\n width: var(--hb-aside-width);\n padding: var(--hb-aside-padding);\n box-sizing: border-box;\n overflow: auto;\n background-color: var(--hb-aside-bg-color);\n}\n\n","import { Component, h, Prop } from '@stencil/core';\n\n/**\n * Container Aside 组件\n * 侧边栏容器\n */\n@Component({\n tag: 'hb-aside',\n styleUrl: 'aside.css',\n shadow: true,\n})\nexport class Aside {\n /**\n * 宽度\n */\n @Prop() width?: string;\n\n render() {\n const style: any = {};\n if (this.width) {\n style.width = this.width;\n }\n\n return (\n <aside class=\"hb-aside\" style={style}>\n <slot></slot>\n </aside>\n );\n }\n}\n\n"],"mappings":"2CAAA,MAAMA,EAAW,g0LACjB,MAAAC,EAAeD,E,MCUFE,EAAK,M,yBAIRC,MAER,MAAAC,GACE,MAAMC,EAAa,GACnB,GAAIC,KAAKH,MAAO,CACdE,EAAMF,MAAQG,KAAKH,K,CAGrB,OACEI,EAAA,SAAAC,IAAA,2CAAOC,MAAM,WAAWJ,MAAOA,GAC7BE,EAAA,QAAAC,IAAA,6C","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as e,g as t,h as i}from"./p-e42dfa95.js";const o='/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{border:0 solid;box-sizing:border-box;margin:0;padding:0}::file-selector-button{appearance:button;background-color:#0000;border:0 solid;border-radius:0;box-sizing:border-box;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;margin:0;margin-inline-end:4px;opacity:1;padding:0}:host,html{-webkit-text-size-adjust:100%;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);line-height:1.5;tab-size:4;-webkit-tap-highlight-color:transparent}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-size:1em;font-variation-settings:var(--default-mono-font-variation-settings,normal)}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}button,input,optgroup,select,textarea{background-color:#0000;border-radius:0;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex;padding-block:0}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field,::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}} /*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer components;:host{display:block}.hb-collapse{border-bottom:1px solid var(--hb-color-border-secondary);border-top:1px solid var(--hb-color-border-secondary)}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}';const n=o;const a=class{constructor(t){e(this,t)}get el(){return t(this)}accordion=false;componentDidLoad(){this.el.addEventListener("hbCollapseItemToggle",(e=>{if(!this.accordion)return;const{active:t}=e.detail;if(!t)return;const i=e.target;this.el.querySelectorAll("hb-collapse-item").forEach((e=>{if(e!==i){e.active=false}}))}))}render(){return i("div",{key:"24dd4feed226f43872d718544b72ca82415645fa",class:{"hb-collapse":true,"hb-collapse--accordion":this.accordion}},i("slot",{key:"f0f66d8ffb59b9bdebe72a093eea33551a1cd5c9"}))}};a.style=n;export{a as hb_collapse};
2
+ //# sourceMappingURL=p-231a7335.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["collapseCss","HbCollapseStyle0","Collapse","accordion","componentDidLoad","this","el","addEventListener","e","active","detail","current","target","querySelectorAll","forEach","item","render","h","key","class"],"sources":["src/components/Collapse/collapse.css?tag=hb-collapse&encapsulation=shadow","src/components/Collapse/Collapse.tsx"],"sourcesContent":[":host { display: block; }\n.hb-collapse { border-top: 1px solid var(--hb-color-border-secondary); border-bottom: 1px solid var(--hb-color-border-secondary); }\n","import { Component, h, Prop, Element } from '@stencil/core';\n\n@Component({ tag: 'hb-collapse', styleUrl: 'collapse.css', shadow: true })\nexport class Collapse {\n @Element() el: HTMLElement;\n\n /** 是否开启手风琴模式(同时仅展开一项) */\n @Prop({ mutable: true }) accordion: boolean = false;\n\n componentDidLoad() {\n this.el.addEventListener(\n 'hbCollapseItemToggle',\n ((e: CustomEvent) => {\n if (!this.accordion) return;\n const { active } = e.detail;\n // 手风琴模式:某项展开时,关闭其余项\n if (!active) return;\n const current = e.target as HTMLElement;\n this.el.querySelectorAll('hb-collapse-item').forEach((item) => {\n if (item !== current) {\n (item as any).active = false;\n }\n });\n }) as EventListener,\n );\n }\n\n render() {\n return (\n <div class={{ 'hb-collapse': true, 'hb-collapse--accordion': this.accordion }}>\n <slot />\n </div>\n );\n }\n}\n"],"mappings":"kDAAA,MAAMA,EAAc,0sLACpB,MAAAC,EAAeD,E,MCEFE,EAAQ,M,iDAIMC,UAAqB,MAE9C,gBAAAC,GACEC,KAAKC,GAAGC,iBACN,wBACEC,IACA,IAAKH,KAAKF,UAAW,OACrB,MAAMM,OAAEA,GAAWD,EAAEE,OAErB,IAAKD,EAAQ,OACb,MAAME,EAAUH,EAAEI,OAClBP,KAAKC,GAAGO,iBAAiB,oBAAoBC,SAASC,IACpD,GAAIA,IAASJ,EAAS,CACnBI,EAAaN,OAAS,K,IAG5B,G,CAIL,MAAAO,GACE,OACEC,EAAA,OAAAC,IAAA,2CAAKC,MAAO,CAAE,cAAe,KAAM,yBAA0Bd,KAAKF,YAChEc,EAAA,QAAAC,IAAA,6C","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as e,c as t,h as i}from"./p-e42dfa95.js";const n='/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{border:0 solid;box-sizing:border-box;margin:0;padding:0}::file-selector-button{appearance:button;background-color:#0000;border:0 solid;border-radius:0;box-sizing:border-box;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;margin:0;margin-inline-end:4px;opacity:1;padding:0}:host,html{-webkit-text-size-adjust:100%;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);line-height:1.5;tab-size:4;-webkit-tap-highlight-color:transparent}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-size:1em;font-variation-settings:var(--default-mono-font-variation-settings,normal)}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}button,input,optgroup,select,textarea{background-color:#0000;border-radius:0;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex;padding-block:0}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field,::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}} /*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer components;:host{--hb-input-number-font-size:14px;--hb-input-number-height:32px;--hb-input-number-border-color:var(--hb-border-color,#dcdfe6);--hb-input-number-border-color-hover:var(--hb-color-primary);--hb-input-number-bg-color:var(--hb-color-white,#fff);display:inline-block;position:relative}.hb-input-number{display:inline-block;position:relative;width:180px}.hb-input-number,.hb-input-number__inner{line-height:var(--hb-input-number-height)}.hb-input-number__inner{-webkit-appearance:none;background-color:var(--hb-input-number-bg-color);border:1px solid var(--hb-input-number-border-color);border-radius:4px;box-sizing:border-box;color:var(--hb-color-text-regular,#606266);display:block;font-size:inherit;height:var(--hb-input-number-height);outline:none;padding:0 50px 0 15px;text-align:left;transition:border-color .2s cubic-bezier(.645,.045,.355,1);width:100%}.hb-input-number--without-controls .hb-input-number__inner{padding:0 15px}.hb-input-number--controls-right .hb-input-number__inner{padding:0 15px 0 50px}.hb-input-number__inner:focus,.hb-input-number__inner:hover:not(:disabled){border-color:var(--hb-input-number-border-color-hover)}.hb-input-number__inner:disabled{background-color:var(--hb-fill-color-light,#f5f7fa);border-color:var(--hb-input-number-border-color);color:var(--hb-color-text-disabled,#c0c4cc);cursor:not-allowed}.hb-input-number__decrease,.hb-input-number__increase{align-items:center;background:var(--hb-fill-color-light,#f5f7fa);color:var(--hb-color-text-regular,#606266);cursor:pointer;display:flex;font-size:13px;height:calc(100% - 2px);justify-content:center;position:absolute;text-align:center;top:1px;transition:all .2s;-webkit-user-select:none;user-select:none;width:35px;z-index:1}.hb-input-number__decrease:hover:not(.hb-input-number__decrease--disabled),.hb-input-number__increase:hover:not(.hb-input-number__increase--disabled){color:var(--hb-color-primary)}.hb-input-number__decrease--disabled,.hb-input-number__increase--disabled{color:var(--hb-color-text-disabled,#c0c4cc);cursor:not-allowed}.hb-input-number__increase{border-radius:0 4px 4px 0;right:1px}.hb-input-number__decrease,.hb-input-number__increase{border-left:1px solid var(--hb-input-number-border-color)}.hb-input-number__decrease{border-radius:0;right:36px}.hb-input-number--controls-right .hb-input-number__increase{border-radius:0 4px 4px 0;right:1px}.hb-input-number--controls-right .hb-input-number__decrease{border-radius:0;right:36px}.hb-input-number__controls{background:var(--hb-fill-color-light,#f5f7fa);border-left:1px solid var(--hb-input-number-border-color);border-radius:0 4px 4px 0;height:calc(100% - 2px);position:absolute;right:1px;top:1px;width:35px}.hb-input-number--controls-right .hb-input-number__controls{border-left:none;border-radius:4px 0 0 4px;border-right:1px solid var(--hb-input-number-border-color);left:1px;right:auto}.hb-input-number--controls-right .hb-input-number__controls .hb-input-number__increase{border:none;border-bottom:1px solid var(--hb-input-number-border-color);border-radius:0;position:static}.hb-input-number--controls-right .hb-input-number__controls .hb-input-number__decrease{border:none;border-radius:0 0 0 4px;position:static}.hb-input-number--small{width:150px}.hb-input-number--small .hb-input-number__inner{font-size:12px;height:24px;line-height:24px;padding:0 40px 0 12px}.hb-input-number--large{width:200px}.hb-input-number--large .hb-input-number__inner{font-size:16px;height:40px;line-height:40px;padding:0 55px 0 18px}.hb-input-number--disabled{cursor:not-allowed}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}';const r=n;const o=class{constructor(i){e(this,i);this.hbChange=t(this,"hbChange",7);this.hbInput=t(this,"hbInput",7)}modelValue=0;size="default";disabled=false;readonly=false;min=-Infinity;max=Infinity;step=1;precision;stepStrictly=false;controls=true;controlsPosition="";name;inputId;placeholder;currentValue=0;hbChange;hbInput;componentDidLoad(){this.currentValue=this.modelValue}handleModelValueChange(){this.currentValue=this.modelValue}formatValue(e){if(this.precision!==undefined){return Number(e.toFixed(this.precision))}return e}clampValue(e){let t=Math.max(this.min,Math.min(this.max,e));if(this.stepStrictly){const e=this.step;t=Math.round(t/e)*e}return this.formatValue(t)}handleInput=e=>{const t=e.target;const i=parseFloat(t.value);if(isNaN(i)){this.currentValue=this.min}else{this.currentValue=this.clampValue(i)}this.modelValue=this.currentValue;this.hbInput.emit(this.currentValue)};handleChange=()=>{this.hbChange.emit(this.currentValue)};increase=()=>{if(this.disabled||this.readonly)return;const e=this.clampValue(this.currentValue+this.step);this.currentValue=e;this.modelValue=e;this.hbChange.emit(e)};decrease=()=>{if(this.disabled||this.readonly)return;const e=this.clampValue(this.currentValue-this.step);this.currentValue=e;this.modelValue=e;this.hbChange.emit(e)};render(){return i("div",{key:"490fe763a00f34486cbbe6502204433071a863eb",class:{"hb-input-number":true,[`hb-input-number--${this.size}`]:true,"hb-input-number--disabled":this.disabled,"hb-input-number--controls-right":this.controlsPosition==="right","hb-input-number--without-controls":!this.controls}},this.controls&&this.controlsPosition!=="right"&&i("span",{key:"a43a038a8914dbff0c8b9759c04c74fa791f2e6c",class:{"hb-input-number__decrease":true,"hb-input-number__decrease--disabled":this.currentValue<=this.min},onClick:this.decrease},"−"),i("input",{key:"83a7bb1d73a709e92f31044396fdb73daed77ea9",type:"number",id:this.inputId,name:this.name,class:"hb-input-number__inner",value:this.currentValue,disabled:this.disabled,readonly:this.readonly,placeholder:this.placeholder,min:this.min,max:this.max,step:this.step,onInput:this.handleInput,onChange:this.handleChange}),this.controls&&this.controlsPosition==="right"&&i("span",{key:"e202c7b06c991550eb9a5cae441ead7d82231b0f",class:"hb-input-number__controls"},i("span",{key:"876db137bb4539e93a1f7ccb08a2fb754722a7bf",class:{"hb-input-number__increase":true,"hb-input-number__increase--disabled":this.currentValue>=this.max},onClick:this.increase},"+"),i("span",{key:"98acd918f10a7f8d3c399aa60677eac231be503b",class:{"hb-input-number__decrease":true,"hb-input-number__decrease--disabled":this.currentValue<=this.min},onClick:this.decrease},"−")),this.controls&&this.controlsPosition!=="right"&&i("span",{key:"4befdfc2a0d7ac3af63027f0947f27d866fbe158",class:{"hb-input-number__increase":true,"hb-input-number__increase--disabled":this.currentValue>=this.max},onClick:this.increase},"+"))}static get watchers(){return{modelValue:["handleModelValueChange"]}}};o.style=r;export{o as hb_input_number};
2
+ //# sourceMappingURL=p-24ad7eec.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["inputNumberCss","HbInputNumberStyle0","InputNumber","modelValue","size","disabled","readonly","min","Infinity","max","step","precision","stepStrictly","controls","controlsPosition","name","inputId","placeholder","currentValue","hbChange","hbInput","componentDidLoad","this","handleModelValueChange","formatValue","value","undefined","Number","toFixed","clampValue","clamped","Math","round","handleInput","e","target","parseFloat","isNaN","emit","handleChange","increase","newValue","decrease","render","h","key","class","onClick","type","id","onInput","onChange"],"sources":["src/components/InputNumber/input-number.css?tag=hb-input-number&encapsulation=shadow","src/components/InputNumber/InputNumber.tsx"],"sourcesContent":[":host {\n display: inline-block;\n position: relative;\n --hb-input-number-font-size: 14px;\n --hb-input-number-height: 32px;\n --hb-input-number-border-color: var(--hb-border-color, #dcdfe6);\n --hb-input-number-border-color-hover: var(--hb-color-primary);\n --hb-input-number-bg-color: var(--hb-color-white, #ffffff);\n}\n\n.hb-input-number {\n position: relative;\n display: inline-block;\n width: 180px;\n line-height: var(--hb-input-number-height);\n}\n\n.hb-input-number__inner {\n -webkit-appearance: none;\n background-color: var(--hb-input-number-bg-color);\n border: 1px solid var(--hb-input-number-border-color);\n border-radius: 4px;\n box-sizing: border-box;\n color: var(--hb-color-text-regular, #606266);\n display: block;\n font-size: inherit;\n height: var(--hb-input-number-height);\n line-height: var(--hb-input-number-height);\n outline: none;\n padding: 0 50px 0 15px;\n text-align: left;\n transition: border-color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1);\n width: 100%;\n}\n\n.hb-input-number--without-controls .hb-input-number__inner {\n padding: 0 15px;\n}\n\n.hb-input-number--controls-right .hb-input-number__inner {\n padding: 0 15px 0 50px;\n}\n\n.hb-input-number__inner:hover:not(:disabled) {\n border-color: var(--hb-input-number-border-color-hover);\n}\n\n.hb-input-number__inner:focus {\n border-color: var(--hb-input-number-border-color-hover);\n}\n\n.hb-input-number__inner:disabled {\n background-color: var(--hb-fill-color-light, #f5f7fa);\n border-color: var(--hb-input-number-border-color);\n color: var(--hb-color-text-disabled, #c0c4cc);\n cursor: not-allowed;\n}\n\n.hb-input-number__increase,\n.hb-input-number__decrease {\n position: absolute;\n z-index: 1;\n top: 1px;\n width: 35px;\n height: calc(100% - 2px);\n text-align: center;\n background: var(--hb-fill-color-light, #f5f7fa);\n color: var(--hb-color-text-regular, #606266);\n cursor: pointer;\n font-size: 13px;\n user-select: none;\n display: flex;\n align-items: center;\n justify-content: center;\n transition: all 0.2s;\n}\n\n.hb-input-number__increase:hover:not(.hb-input-number__increase--disabled),\n.hb-input-number__decrease:hover:not(.hb-input-number__decrease--disabled) {\n color: var(--hb-color-primary);\n}\n\n.hb-input-number__increase--disabled,\n.hb-input-number__decrease--disabled {\n color: var(--hb-color-text-disabled, #c0c4cc);\n cursor: not-allowed;\n}\n\n.hb-input-number__increase {\n right: 1px;\n border-radius: 0 4px 4px 0;\n border-left: 1px solid var(--hb-input-number-border-color);\n}\n\n.hb-input-number__decrease {\n right: 36px;\n border-radius: 0;\n border-left: 1px solid var(--hb-input-number-border-color);\n}\n\n.hb-input-number--controls-right .hb-input-number__increase {\n right: 1px;\n border-radius: 0 4px 4px 0;\n}\n\n.hb-input-number--controls-right .hb-input-number__decrease {\n right: 36px;\n border-radius: 0;\n}\n\n.hb-input-number__controls {\n position: absolute;\n right: 1px;\n top: 1px;\n width: 35px;\n height: calc(100% - 2px);\n border-left: 1px solid var(--hb-input-number-border-color);\n border-radius: 0 4px 4px 0;\n background: var(--hb-fill-color-light, #f5f7fa);\n}\n\n.hb-input-number--controls-right .hb-input-number__controls {\n left: 1px;\n right: auto;\n border-left: none;\n border-right: 1px solid var(--hb-input-number-border-color);\n border-radius: 4px 0 0 4px;\n}\n\n.hb-input-number--controls-right .hb-input-number__controls .hb-input-number__increase {\n position: static;\n border: none;\n border-bottom: 1px solid var(--hb-input-number-border-color);\n border-radius: 0;\n}\n\n.hb-input-number--controls-right .hb-input-number__controls .hb-input-number__decrease {\n position: static;\n border: none;\n border-radius: 0 0 0 4px;\n}\n\n.hb-input-number--small {\n width: 150px;\n}\n\n.hb-input-number--small .hb-input-number__inner {\n height: 24px;\n line-height: 24px;\n font-size: 12px;\n padding: 0 40px 0 12px;\n}\n\n.hb-input-number--large {\n width: 200px;\n}\n\n.hb-input-number--large .hb-input-number__inner {\n height: 40px;\n line-height: 40px;\n font-size: 16px;\n padding: 0 55px 0 18px;\n}\n\n.hb-input-number--disabled {\n cursor: not-allowed;\n}\n\n","import { Component, h, Prop, Event, EventEmitter, State, Watch } from '@stencil/core';\n\n/**\n * InputNumber 数字输入框组件\n * 仅允许输入标准的数字值,可定义范围\n */\n@Component({\n tag: 'hb-input-number',\n styleUrl: 'input-number.css',\n shadow: true,\n})\nexport class InputNumber {\n /**\n * 绑定值\n */\n @Prop({ mutable: true }) modelValue: number = 0;\n\n /**\n * 计数器尺寸\n */\n @Prop() size: 'large' | 'default' | 'small' = 'default';\n\n /**\n * 是否禁用\n * @default false\n */\n @Prop() disabled: boolean = false;\n\n /**\n * 是否只读\n * @default false\n */\n @Prop() readonly: boolean = false;\n\n /**\n * 最小值\n * @default -Infinity\n */\n @Prop() min: number = -Infinity;\n\n /**\n * 最大值\n * @default Infinity\n */\n @Prop() max: number = Infinity;\n\n /**\n * 计数器步长\n * @default 1\n */\n @Prop() step: number = 1;\n\n /**\n * 精度\n */\n @Prop() precision?: number;\n\n /**\n * 是否只能输入 step 的倍数\n * @default false\n */\n @Prop() stepStrictly: boolean = false;\n\n /**\n * 是否使用控制按钮\n * @default true\n */\n @Prop() controls: boolean = true;\n\n /**\n * 控制按钮位置\n */\n @Prop() controlsPosition: '' | 'right' = '';\n\n /**\n * 原生 name 属性\n */\n @Prop() name?: string;\n\n /**\n * 原生 id 属性\n */\n @Prop() inputId?: string;\n\n /**\n * 原生 placeholder 属性\n */\n @Prop() placeholder?: string;\n\n @State() currentValue: number = 0;\n\n /**\n * 值改变事件\n */\n @Event() hbChange: EventEmitter<number>;\n\n /**\n * 输入事件\n */\n @Event() hbInput: EventEmitter<number>;\n\n componentDidLoad() {\n this.currentValue = this.modelValue;\n }\n\n /** 受控模式:外部修改 modelValue 时同步内部 currentValue,保证 UI 与值一致 */\n @Watch('modelValue')\n handleModelValueChange() {\n this.currentValue = this.modelValue;\n }\n\n private formatValue(value: number): number {\n if (this.precision !== undefined) {\n return Number(value.toFixed(this.precision));\n }\n return value;\n }\n\n private clampValue(value: number): number {\n let clamped = Math.max(this.min, Math.min(this.max, value));\n \n if (this.stepStrictly) {\n const step = this.step;\n clamped = Math.round(clamped / step) * step;\n }\n \n return this.formatValue(clamped);\n }\n\n private handleInput = (e: Event) => {\n const target = e.target as HTMLInputElement;\n const value = parseFloat(target.value);\n \n if (isNaN(value)) {\n this.currentValue = this.min;\n } else {\n this.currentValue = this.clampValue(value);\n }\n \n this.modelValue = this.currentValue;\n this.hbInput.emit(this.currentValue);\n };\n\n private handleChange = () => {\n this.hbChange.emit(this.currentValue);\n };\n\n private increase = () => {\n if (this.disabled || this.readonly) return;\n const newValue = this.clampValue(this.currentValue + this.step);\n this.currentValue = newValue;\n this.modelValue = newValue;\n this.hbChange.emit(newValue);\n };\n\n private decrease = () => {\n if (this.disabled || this.readonly) return;\n const newValue = this.clampValue(this.currentValue - this.step);\n this.currentValue = newValue;\n this.modelValue = newValue;\n this.hbChange.emit(newValue);\n };\n\n render() {\n return (\n <div\n class={{\n 'hb-input-number': true,\n [`hb-input-number--${this.size}`]: true,\n 'hb-input-number--disabled': this.disabled,\n 'hb-input-number--controls-right': this.controlsPosition === 'right',\n 'hb-input-number--without-controls': !this.controls,\n }}\n >\n {this.controls && this.controlsPosition !== 'right' && (\n <span\n class={{\n 'hb-input-number__decrease': true,\n 'hb-input-number__decrease--disabled': this.currentValue <= this.min,\n }}\n onClick={this.decrease}\n >\n −\n </span>\n )}\n <input\n type=\"number\"\n id={this.inputId}\n name={this.name}\n class=\"hb-input-number__inner\"\n value={this.currentValue}\n disabled={this.disabled}\n readonly={this.readonly}\n placeholder={this.placeholder}\n min={this.min}\n max={this.max}\n step={this.step}\n onInput={this.handleInput}\n onChange={this.handleChange}\n />\n {this.controls && this.controlsPosition === 'right' && (\n <span class=\"hb-input-number__controls\">\n <span\n class={{\n 'hb-input-number__increase': true,\n 'hb-input-number__increase--disabled': this.currentValue >= this.max,\n }}\n onClick={this.increase}\n >\n +\n </span>\n <span\n class={{\n 'hb-input-number__decrease': true,\n 'hb-input-number__decrease--disabled': this.currentValue <= this.min,\n }}\n onClick={this.decrease}\n >\n −\n </span>\n </span>\n )}\n {this.controls && this.controlsPosition !== 'right' && (\n <span\n class={{\n 'hb-input-number__increase': true,\n 'hb-input-number__increase--disabled': this.currentValue >= this.max,\n }}\n onClick={this.increase}\n >\n +\n </span>\n )}\n </div>\n );\n }\n}\n\n"],"mappings":"kDAAA,MAAMA,EAAiB,sgSACvB,MAAAC,EAAeD,E,MCUFE,EAAW,M,6FAIGC,WAAqB,EAKtCC,KAAsC,UAMtCC,SAAoB,MAMpBC,SAAoB,MAMpBC,KAAeC,SAMfC,IAAcD,SAMdE,KAAe,EAKfC,UAMAC,aAAwB,MAMxBC,SAAoB,KAKpBC,iBAAiC,GAKjCC,KAKAC,QAKAC,YAECC,aAAuB,EAKvBC,SAKAC,QAET,gBAAAC,GACEC,KAAKJ,aAAeI,KAAKnB,U,CAK3B,sBAAAoB,GACED,KAAKJ,aAAeI,KAAKnB,U,CAGnB,WAAAqB,CAAYC,GAClB,GAAIH,KAAKX,YAAce,UAAW,CAChC,OAAOC,OAAOF,EAAMG,QAAQN,KAAKX,W,CAEnC,OAAOc,C,CAGD,UAAAI,CAAWJ,GACjB,IAAIK,EAAUC,KAAKtB,IAAIa,KAAKf,IAAKwB,KAAKxB,IAAIe,KAAKb,IAAKgB,IAEpD,GAAIH,KAAKV,aAAc,CACrB,MAAMF,EAAOY,KAAKZ,KAClBoB,EAAUC,KAAKC,MAAMF,EAAUpB,GAAQA,C,CAGzC,OAAOY,KAAKE,YAAYM,E,CAGlBG,YAAeC,IACrB,MAAMC,EAASD,EAAEC,OACjB,MAAMV,EAAQW,WAAWD,EAAOV,OAEhC,GAAIY,MAAMZ,GAAQ,CAChBH,KAAKJ,aAAeI,KAAKf,G,KACpB,CACLe,KAAKJ,aAAeI,KAAKO,WAAWJ,E,CAGtCH,KAAKnB,WAAamB,KAAKJ,aACvBI,KAAKF,QAAQkB,KAAKhB,KAAKJ,aAAa,EAG9BqB,aAAe,KACrBjB,KAAKH,SAASmB,KAAKhB,KAAKJ,aAAa,EAG/BsB,SAAW,KACjB,GAAIlB,KAAKjB,UAAYiB,KAAKhB,SAAU,OACpC,MAAMmC,EAAWnB,KAAKO,WAAWP,KAAKJ,aAAeI,KAAKZ,MAC1DY,KAAKJ,aAAeuB,EACpBnB,KAAKnB,WAAasC,EAClBnB,KAAKH,SAASmB,KAAKG,EAAS,EAGtBC,SAAW,KACjB,GAAIpB,KAAKjB,UAAYiB,KAAKhB,SAAU,OACpC,MAAMmC,EAAWnB,KAAKO,WAAWP,KAAKJ,aAAeI,KAAKZ,MAC1DY,KAAKJ,aAAeuB,EACpBnB,KAAKnB,WAAasC,EAClBnB,KAAKH,SAASmB,KAAKG,EAAS,EAG9B,MAAAE,GACE,OACEC,EAAA,OAAAC,IAAA,2CACEC,MAAO,CACL,kBAAmB,KACnB,CAAC,oBAAoBxB,KAAKlB,QAAS,KACnC,4BAA6BkB,KAAKjB,SAClC,kCAAmCiB,KAAKR,mBAAqB,QAC7D,qCAAsCQ,KAAKT,WAG5CS,KAAKT,UAAYS,KAAKR,mBAAqB,SAC1C8B,EAAA,QAAAC,IAAA,2CACEC,MAAO,CACL,4BAA6B,KAC7B,sCAAuCxB,KAAKJ,cAAgBI,KAAKf,KAEnEwC,QAASzB,KAAKoB,UAAQ,KAK1BE,EAAA,SAAAC,IAAA,2CACEG,KAAK,SACLC,GAAI3B,KAAKN,QACTD,KAAMO,KAAKP,KACX+B,MAAM,yBACNrB,MAAOH,KAAKJ,aACZb,SAAUiB,KAAKjB,SACfC,SAAUgB,KAAKhB,SACfW,YAAaK,KAAKL,YAClBV,IAAKe,KAAKf,IACVE,IAAKa,KAAKb,IACVC,KAAMY,KAAKZ,KACXwC,QAAS5B,KAAKW,YACdkB,SAAU7B,KAAKiB,eAEhBjB,KAAKT,UAAYS,KAAKR,mBAAqB,SAC1C8B,EAAA,QAAAC,IAAA,2CAAMC,MAAM,6BACVF,EAAA,QAAAC,IAAA,2CACEC,MAAO,CACL,4BAA6B,KAC7B,sCAAuCxB,KAAKJ,cAAgBI,KAAKb,KAEnEsC,QAASzB,KAAKkB,UAAQ,KAIxBI,EAAA,QAAAC,IAAA,2CACEC,MAAO,CACL,4BAA6B,KAC7B,sCAAuCxB,KAAKJ,cAAgBI,KAAKf,KAEnEwC,QAASzB,KAAKoB,UAAQ,MAM3BpB,KAAKT,UAAYS,KAAKR,mBAAqB,SAC1C8B,EAAA,QAAAC,IAAA,2CACEC,MAAO,CACL,4BAA6B,KAC7B,sCAAuCxB,KAAKJ,cAAgBI,KAAKb,KAEnEsC,QAASzB,KAAKkB,UAAQ,K","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as e,g as i,h as t}from"./p-e42dfa95.js";const o='/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{border:0 solid;box-sizing:border-box;margin:0;padding:0}::file-selector-button{appearance:button;background-color:#0000;border:0 solid;border-radius:0;box-sizing:border-box;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;margin:0;margin-inline-end:4px;opacity:1;padding:0}:host,html{-webkit-text-size-adjust:100%;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);line-height:1.5;tab-size:4;-webkit-tap-highlight-color:transparent}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-size:1em;font-variation-settings:var(--default-mono-font-variation-settings,normal)}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}button,input,optgroup,select,textarea{background-color:#0000;border-radius:0;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex;padding-block:0}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field,::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}} /*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer components;:host{display:block}.hb-divider{align-items:center;border:0;color:var(--hb-color-text-secondary);display:flex;font-size:var(--hb-font-size-sm);margin:var(--hb-spacing-md)0}.hb-divider__line{border-top:1px solid var(--hb-color-border-secondary);flex:1}.hb-divider--dashed .hb-divider__line{border-top-style:dashed}.hb-divider--vertical{display:inline-flex;flex-direction:column;height:.9em;margin:0 var(--hb-spacing-xs)}.hb-divider--vertical .hb-divider__line{border-left:1px solid var(--hb-color-border-secondary);border-top:none;flex:none;height:100%}.hb-divider__text{padding:0 var(--hb-spacing-sm);white-space:nowrap}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}';const r=o;const n=class{constructor(i){e(this,i)}get el(){return i(this)}direction="horizontal";contentPosition="center";dashed=false;render(){const e=this.el.childNodes.length>0;return t("div",{key:"9c92e52f27cf63f9eb08f76204c0380df1f70762",class:{"hb-divider":true,[`hb-divider--${this.direction}`]:true,"hb-divider--dashed":this.dashed,"hb-divider--with-text":e,[`hb-divider--with-text-${this.contentPosition}`]:e}},t("div",{key:"be7ed538cb7c11ecd5228456c70064b7a1134c22",class:"hb-divider__line hb-divider__line--before"}),t("div",{key:"381b60a6d74c9d595d23ba931f4de73a1479d45c",class:"hb-divider__text"},t("slot",{key:"0bd08b0d41a9d2d4dad651e0c37a7e7fc10eab4c"})),t("div",{key:"dd0774049f2b68b47f21c7171532f830d766c276",class:"hb-divider__line hb-divider__line--after"}))}};n.style=r;export{n as hb_divider};
2
+ //# sourceMappingURL=p-2b286698.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["dividerCss","HbDividerStyle0","Divider","direction","contentPosition","dashed","render","hasContent","this","el","childNodes","length","h","key","class"],"sources":["src/components/Divider/divider.css?tag=hb-divider&encapsulation=shadow","src/components/Divider/Divider.tsx"],"sourcesContent":[":host {\n display: block;\n}\n\n.hb-divider {\n display: flex;\n align-items: center;\n margin: var(--hb-spacing-md) 0;\n border: 0;\n color: var(--hb-color-text-secondary);\n font-size: var(--hb-font-size-sm);\n}\n\n.hb-divider__line {\n flex: 1;\n border-top: 1px solid var(--hb-color-border-secondary);\n}\n\n.hb-divider--dashed .hb-divider__line {\n border-top-style: dashed;\n}\n\n.hb-divider--vertical {\n display: inline-flex;\n flex-direction: column;\n margin: 0 var(--hb-spacing-xs);\n height: 0.9em;\n}\n\n.hb-divider--vertical .hb-divider__line {\n border-top: none;\n border-left: 1px solid var(--hb-color-border-secondary);\n flex: none;\n height: 100%;\n}\n\n.hb-divider__text {\n padding: 0 var(--hb-spacing-sm);\n white-space: nowrap;\n}\n","import { Component, h, Prop, Element } from '@stencil/core';\n\n/**\n * Divider 分割线组件\n * 区隔内容的分割线\n */\n@Component({\n tag: 'hb-divider',\n styleUrl: 'divider.css',\n shadow: true,\n})\nexport class Divider {\n @Element() el: HTMLElement;\n\n /** 分割线方向 */\n @Prop() direction: 'horizontal' | 'vertical' = 'horizontal';\n\n /** 文字位置 */\n @Prop() contentPosition: 'left' | 'center' | 'right' = 'center';\n\n /** 是否虚线 */\n @Prop() dashed: boolean = false;\n\n render() {\n const hasContent = this.el.childNodes.length > 0;\n return (\n <div\n class={{\n 'hb-divider': true,\n [`hb-divider--${this.direction}`]: true,\n 'hb-divider--dashed': this.dashed,\n 'hb-divider--with-text': hasContent,\n [`hb-divider--with-text-${this.contentPosition}`]: hasContent,\n }}\n >\n <div class=\"hb-divider__line hb-divider__line--before\"></div>\n <div class=\"hb-divider__text\"><slot /></div>\n <div class=\"hb-divider__line hb-divider__line--after\"></div>\n </div>\n );\n }\n}\n"],"mappings":"kDAAA,MAAMA,EAAa,sqMACnB,MAAAC,EAAeD,E,MCUFE,EAAO,M,iDAIVC,UAAuC,aAGvCC,gBAA+C,SAG/CC,OAAkB,MAE1B,MAAAC,GACE,MAAMC,EAAaC,KAAKC,GAAGC,WAAWC,OAAS,EAC/C,OACEC,EAAA,OAAAC,IAAA,2CACEC,MAAO,CACL,aAAc,KACd,CAAC,eAAeN,KAAKL,aAAc,KACnC,qBAAsBK,KAAKH,OAC3B,wBAAyBE,EACzB,CAAC,yBAAyBC,KAAKJ,mBAAoBG,IAGrDK,EAAA,OAAAC,IAAA,2CAAKC,MAAM,8CACXF,EAAA,OAAAC,IAAA,2CAAKC,MAAM,oBAAmBF,EAAA,QAAAC,IAAA,8CAC9BD,EAAA,OAAAC,IAAA,2CAAKC,MAAM,6C","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as i,c as e,h as t}from"./p-e42dfa95.js";const o='/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{border:0 solid;box-sizing:border-box;margin:0;padding:0}::file-selector-button{appearance:button;background-color:#0000;border:0 solid;border-radius:0;box-sizing:border-box;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;margin:0;margin-inline-end:4px;opacity:1;padding:0}:host,html{-webkit-text-size-adjust:100%;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);line-height:1.5;tab-size:4;-webkit-tap-highlight-color:transparent}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-size:1em;font-variation-settings:var(--default-mono-font-variation-settings,normal)}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}button,input,optgroup,select,textarea{background-color:#0000;border-radius:0;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex;padding-block:0}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field,::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.underline{text-decoration-line:underline}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}} /*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer components;:host{--hb-link-font-size:14px;--hb-link-font-weight:400;--hb-link-color:var(--hb-color-primary);--hb-link-hover-color:var(--hb-color-primary-light-3);--hb-link-disabled-color:var(--hb-color-text-disabled);display:inline-block}.hb-link{align-items:center;color:var(--hb-link-color);cursor:pointer;display:inline-flex;font-size:var(--hb-link-font-size);font-weight:var(--hb-link-font-weight);justify-content:center;outline:none;padding:0;position:relative;text-decoration:none;transition:color .2s cubic-bezier(.645,.045,.355,1);vertical-align:middle}.hb-link:hover{color:var(--hb-link-hover-color)}.hb-link--underline:hover:after{border-bottom:1px solid var(--hb-link-hover-color);bottom:0;content:"";height:0;left:0;position:absolute;right:0}.hb-link--disabled{cursor:not-allowed}.hb-link--disabled,.hb-link--disabled:hover{color:var(--hb-link-disabled-color)}.hb-link--disabled:hover:after{border-bottom-color:var(--hb-link-disabled-color)}.hb-link--primary{--hb-link-color:var(--hb-color-primary);--hb-link-hover-color:var(--hb-color-primary-light-3)}.hb-link--success{--hb-link-color:var(--hb-color-success);--hb-link-hover-color:var(--hb-color-success-light-3)}.hb-link--warning{--hb-link-color:var(--hb-color-warning);--hb-link-hover-color:var(--hb-color-warning-light-3)}.hb-link--danger{--hb-link-color:var(--hb-color-danger);--hb-link-hover-color:var(--hb-color-danger-light-3)}.hb-link--info{--hb-link-color:var(--hb-color-info);--hb-link-hover-color:var(--hb-color-info-light-3)}.hb-link--default{--hb-link-color:var(--hb-color-text-regular);--hb-link-hover-color:var(--hb-color-primary)}.hb-link i{margin-right:4px}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}';const r=o;const n=class{constructor(t){i(this,t);this.hbClick=e(this,"hbClick",7)}type="default";underline=false;disabled=false;href;target;icon;hbClick;handleClick=i=>{if(this.disabled){i.preventDefault();return}this.hbClick.emit(i)};render(){const i=this.href?"a":"span";return t(i,{key:"f4aac8cc7a366ae0c9b4b24fa0d3ee80f79da58b",class:{"hb-link":true,[`hb-link--${this.type}`]:true,"hb-link--underline":this.underline,"hb-link--disabled":this.disabled},href:this.disabled?undefined:this.href,target:this.target,onClick:this.handleClick},this.icon&&t("i",{key:"4b2675a1daf216c9ee79ea12bcab5ed24fd858ca",class:this.icon}),t("slot",{key:"948264261fa279325d939820adb2c67ae7aaf465"}))}};n.style=r;export{n as hb_link};
2
+ //# sourceMappingURL=p-2e6584ea.entry.js.map