duoyun-ui 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (392) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +12 -0
  3. package/docs/.gitignore +4 -0
  4. package/docs/104.bundle.js +19 -0
  5. package/docs/283.bundle.js +47 -0
  6. package/docs/354.bundle.js +1133 -0
  7. package/docs/354.bundle.js.LICENSE.txt +13 -0
  8. package/docs/587.bundle.js +26 -0
  9. package/docs/810.bundle.js +1 -0
  10. package/docs/gem-book.json +84 -0
  11. package/docs/index.html +1 -0
  12. package/docs/main.bundle.js +1 -0
  13. package/docs/robots.txt +2 -0
  14. package/docs/service-worker.js +1 -0
  15. package/docs/workbox-62d1f9d5.js +1 -0
  16. package/elements/action-text.d.ts +12 -0
  17. package/elements/action-text.d.ts.map +1 -0
  18. package/elements/action-text.js +63 -0
  19. package/elements/action-text.js.map +1 -0
  20. package/elements/area-chart.d.ts +35 -0
  21. package/elements/area-chart.d.ts.map +1 -0
  22. package/elements/area-chart.js +408 -0
  23. package/elements/area-chart.js.map +1 -0
  24. package/elements/avatar.d.ts +42 -0
  25. package/elements/avatar.d.ts.map +1 -0
  26. package/elements/avatar.js +190 -0
  27. package/elements/avatar.js.map +1 -0
  28. package/elements/banner.d.ts +21 -0
  29. package/elements/banner.d.ts.map +1 -0
  30. package/elements/banner.js +136 -0
  31. package/elements/banner.js.map +1 -0
  32. package/elements/bar-chart.d.ts +23 -0
  33. package/elements/bar-chart.d.ts.map +1 -0
  34. package/elements/bar-chart.js +170 -0
  35. package/elements/bar-chart.js.map +1 -0
  36. package/elements/base/chart.d.ts +74 -0
  37. package/elements/base/chart.d.ts.map +1 -0
  38. package/elements/base/chart.js +299 -0
  39. package/elements/base/chart.js.map +1 -0
  40. package/elements/base/loadable.d.ts +16 -0
  41. package/elements/base/loadable.d.ts.map +1 -0
  42. package/elements/base/loadable.js +77 -0
  43. package/elements/base/loadable.js.map +1 -0
  44. package/elements/base/resize.d.ts +15 -0
  45. package/elements/base/resize.d.ts.map +1 -0
  46. package/elements/base/resize.js +31 -0
  47. package/elements/base/resize.js.map +1 -0
  48. package/elements/base/scroll.d.ts +11 -0
  49. package/elements/base/scroll.d.ts.map +1 -0
  50. package/elements/base/scroll.js +90 -0
  51. package/elements/base/scroll.js.map +1 -0
  52. package/elements/base/visible.d.ts +12 -0
  53. package/elements/base/visible.d.ts.map +1 -0
  54. package/elements/base/visible.js +37 -0
  55. package/elements/base/visible.js.map +1 -0
  56. package/elements/breadcrumbs.d.ts +20 -0
  57. package/elements/breadcrumbs.d.ts.map +1 -0
  58. package/elements/breadcrumbs.js +88 -0
  59. package/elements/breadcrumbs.js.map +1 -0
  60. package/elements/button.d.ts +30 -0
  61. package/elements/button.d.ts.map +1 -0
  62. package/elements/button.js +225 -0
  63. package/elements/button.js.map +1 -0
  64. package/elements/card.d.ts +26 -0
  65. package/elements/card.d.ts.map +1 -0
  66. package/elements/card.js +163 -0
  67. package/elements/card.js.map +1 -0
  68. package/elements/cascader-pick.d.ts +22 -0
  69. package/elements/cascader-pick.d.ts.map +1 -0
  70. package/elements/cascader-pick.js +172 -0
  71. package/elements/cascader-pick.js.map +1 -0
  72. package/elements/cascader.d.ts +29 -0
  73. package/elements/cascader.d.ts.map +1 -0
  74. package/elements/cascader.js +247 -0
  75. package/elements/cascader.js.map +1 -0
  76. package/elements/chart-tooltip.d.ts +29 -0
  77. package/elements/chart-tooltip.d.ts.map +1 -0
  78. package/elements/chart-tooltip.js +150 -0
  79. package/elements/chart-tooltip.js.map +1 -0
  80. package/elements/chart-zoom.d.ts +20 -0
  81. package/elements/chart-zoom.d.ts.map +1 -0
  82. package/elements/chart-zoom.js +207 -0
  83. package/elements/chart-zoom.js.map +1 -0
  84. package/elements/checkbox.d.ts +20 -0
  85. package/elements/checkbox.d.ts.map +1 -0
  86. package/elements/checkbox.js +108 -0
  87. package/elements/checkbox.js.map +1 -0
  88. package/elements/coach-mark.d.ts +39 -0
  89. package/elements/coach-mark.d.ts.map +1 -0
  90. package/elements/coach-mark.js +212 -0
  91. package/elements/coach-mark.js.map +1 -0
  92. package/elements/code-block.d.ts +14 -0
  93. package/elements/code-block.d.ts.map +1 -0
  94. package/elements/code-block.js +427 -0
  95. package/elements/code-block.js.map +1 -0
  96. package/elements/collapse.d.ts +22 -0
  97. package/elements/collapse.d.ts.map +1 -0
  98. package/elements/collapse.js +111 -0
  99. package/elements/collapse.js.map +1 -0
  100. package/elements/color-panel.d.ts +30 -0
  101. package/elements/color-panel.d.ts.map +1 -0
  102. package/elements/color-panel.js +383 -0
  103. package/elements/color-panel.js.map +1 -0
  104. package/elements/color-pick.d.ts +14 -0
  105. package/elements/color-pick.d.ts.map +1 -0
  106. package/elements/color-pick.js +81 -0
  107. package/elements/color-pick.js.map +1 -0
  108. package/elements/compartment.d.ts +9 -0
  109. package/elements/compartment.d.ts.map +1 -0
  110. package/elements/compartment.js +32 -0
  111. package/elements/compartment.js.map +1 -0
  112. package/elements/copy.d.ts +20 -0
  113. package/elements/copy.d.ts.map +1 -0
  114. package/elements/copy.js +160 -0
  115. package/elements/copy.js.map +1 -0
  116. package/elements/date-panel.d.ts +29 -0
  117. package/elements/date-panel.d.ts.map +1 -0
  118. package/elements/date-panel.js +220 -0
  119. package/elements/date-panel.js.map +1 -0
  120. package/elements/date-pick.d.ts +23 -0
  121. package/elements/date-pick.d.ts.map +1 -0
  122. package/elements/date-pick.js +107 -0
  123. package/elements/date-pick.js.map +1 -0
  124. package/elements/date-range-panel.d.ts +28 -0
  125. package/elements/date-range-panel.d.ts.map +1 -0
  126. package/elements/date-range-panel.js +154 -0
  127. package/elements/date-range-panel.js.map +1 -0
  128. package/elements/date-range-pick.d.ts +26 -0
  129. package/elements/date-range-pick.d.ts.map +1 -0
  130. package/elements/date-range-pick.js +159 -0
  131. package/elements/date-range-pick.js.map +1 -0
  132. package/elements/divider.d.ts +15 -0
  133. package/elements/divider.d.ts.map +1 -0
  134. package/elements/divider.js +95 -0
  135. package/elements/divider.js.map +1 -0
  136. package/elements/donut-chart.d.ts +19 -0
  137. package/elements/donut-chart.d.ts.map +1 -0
  138. package/elements/donut-chart.js +140 -0
  139. package/elements/donut-chart.js.map +1 -0
  140. package/elements/drawer.d.ts +9 -0
  141. package/elements/drawer.d.ts.map +1 -0
  142. package/elements/drawer.js +45 -0
  143. package/elements/drawer.js.map +1 -0
  144. package/elements/drop-area.d.ts +18 -0
  145. package/elements/drop-area.d.ts.map +1 -0
  146. package/elements/drop-area.js +155 -0
  147. package/elements/drop-area.js.map +1 -0
  148. package/elements/empty.d.ts +8 -0
  149. package/elements/empty.d.ts.map +1 -0
  150. package/elements/empty.js +33 -0
  151. package/elements/empty.js.map +1 -0
  152. package/elements/file-pick.d.ts +28 -0
  153. package/elements/file-pick.d.ts.map +1 -0
  154. package/elements/file-pick.js +226 -0
  155. package/elements/file-pick.js.map +1 -0
  156. package/elements/form.d.ts +76 -0
  157. package/elements/form.d.ts.map +1 -0
  158. package/elements/form.js +372 -0
  159. package/elements/form.js.map +1 -0
  160. package/elements/heading.d.ts +13 -0
  161. package/elements/heading.d.ts.map +1 -0
  162. package/elements/heading.js +88 -0
  163. package/elements/heading.js.map +1 -0
  164. package/elements/help-text.d.ts +11 -0
  165. package/elements/help-text.d.ts.map +1 -0
  166. package/elements/help-text.js +53 -0
  167. package/elements/help-text.js.map +1 -0
  168. package/elements/icons.d.ts +10 -0
  169. package/elements/icons.d.ts.map +1 -0
  170. package/elements/icons.js +71 -0
  171. package/elements/icons.js.map +1 -0
  172. package/elements/image-preview.d.ts +26 -0
  173. package/elements/image-preview.d.ts.map +1 -0
  174. package/elements/image-preview.js +172 -0
  175. package/elements/image-preview.js.map +1 -0
  176. package/elements/input-capture.d.ts +17 -0
  177. package/elements/input-capture.d.ts.map +1 -0
  178. package/elements/input-capture.js +111 -0
  179. package/elements/input-capture.js.map +1 -0
  180. package/elements/input.d.ts +51 -0
  181. package/elements/input.d.ts.map +1 -0
  182. package/elements/input.js +372 -0
  183. package/elements/input.js.map +1 -0
  184. package/elements/keyboard-access.d.ts +26 -0
  185. package/elements/keyboard-access.d.ts.map +1 -0
  186. package/elements/keyboard-access.js +217 -0
  187. package/elements/keyboard-access.js.map +1 -0
  188. package/elements/legend.d.ts +21 -0
  189. package/elements/legend.d.ts.map +1 -0
  190. package/elements/legend.js +118 -0
  191. package/elements/legend.js.map +1 -0
  192. package/elements/line-chart.d.ts +9 -0
  193. package/elements/line-chart.d.ts.map +1 -0
  194. package/elements/line-chart.js +116 -0
  195. package/elements/line-chart.js.map +1 -0
  196. package/elements/link.d.ts +14 -0
  197. package/elements/link.d.ts.map +1 -0
  198. package/elements/link.js +46 -0
  199. package/elements/link.js.map +1 -0
  200. package/elements/list.d.ts +30 -0
  201. package/elements/list.d.ts.map +1 -0
  202. package/elements/list.js +114 -0
  203. package/elements/list.js.map +1 -0
  204. package/elements/loading.d.ts +9 -0
  205. package/elements/loading.d.ts.map +1 -0
  206. package/elements/loading.js +44 -0
  207. package/elements/loading.js.map +1 -0
  208. package/elements/map.d.ts +68 -0
  209. package/elements/map.d.ts.map +1 -0
  210. package/elements/map.js +323 -0
  211. package/elements/map.js.map +1 -0
  212. package/elements/menu.d.ts +58 -0
  213. package/elements/menu.d.ts.map +1 -0
  214. package/elements/menu.js +256 -0
  215. package/elements/menu.js.map +1 -0
  216. package/elements/meter.d.ts +20 -0
  217. package/elements/meter.d.ts.map +1 -0
  218. package/elements/meter.js +130 -0
  219. package/elements/meter.js.map +1 -0
  220. package/elements/modal.d.ts +46 -0
  221. package/elements/modal.d.ts.map +1 -0
  222. package/elements/modal.js +296 -0
  223. package/elements/modal.js.map +1 -0
  224. package/elements/more.d.ts +28 -0
  225. package/elements/more.d.ts.map +1 -0
  226. package/elements/more.js +118 -0
  227. package/elements/more.js.map +1 -0
  228. package/elements/options.d.ts +34 -0
  229. package/elements/options.d.ts.map +1 -0
  230. package/elements/options.js +174 -0
  231. package/elements/options.js.map +1 -0
  232. package/elements/page-loadbar.d.ts +20 -0
  233. package/elements/page-loadbar.d.ts.map +1 -0
  234. package/elements/page-loadbar.js +85 -0
  235. package/elements/page-loadbar.js.map +1 -0
  236. package/elements/pagination.d.ts +23 -0
  237. package/elements/pagination.d.ts.map +1 -0
  238. package/elements/pagination.js +221 -0
  239. package/elements/pagination.js.map +1 -0
  240. package/elements/paragraph.d.ts +8 -0
  241. package/elements/paragraph.d.ts.map +1 -0
  242. package/elements/paragraph.js +60 -0
  243. package/elements/paragraph.js.map +1 -0
  244. package/elements/pick.d.ts +34 -0
  245. package/elements/pick.d.ts.map +1 -0
  246. package/elements/pick.js +168 -0
  247. package/elements/pick.js.map +1 -0
  248. package/elements/placeholder.d.ts +23 -0
  249. package/elements/placeholder.d.ts.map +1 -0
  250. package/elements/placeholder.js +93 -0
  251. package/elements/placeholder.js.map +1 -0
  252. package/elements/popover.d.ts +54 -0
  253. package/elements/popover.d.ts.map +1 -0
  254. package/elements/popover.js +316 -0
  255. package/elements/popover.js.map +1 -0
  256. package/elements/progress.d.ts +12 -0
  257. package/elements/progress.d.ts.map +1 -0
  258. package/elements/progress.js +45 -0
  259. package/elements/progress.js.map +1 -0
  260. package/elements/radio.d.ts +34 -0
  261. package/elements/radio.d.ts.map +1 -0
  262. package/elements/radio.js +152 -0
  263. package/elements/radio.js.map +1 -0
  264. package/elements/rating.d.ts +15 -0
  265. package/elements/rating.d.ts.map +1 -0
  266. package/elements/rating.js +122 -0
  267. package/elements/rating.js.map +1 -0
  268. package/elements/scatter-chart.d.ts +13 -0
  269. package/elements/scatter-chart.d.ts.map +1 -0
  270. package/elements/scatter-chart.js +151 -0
  271. package/elements/scatter-chart.js.map +1 -0
  272. package/elements/select.d.ts +63 -0
  273. package/elements/select.d.ts.map +1 -0
  274. package/elements/select.js +416 -0
  275. package/elements/select.js.map +1 -0
  276. package/elements/shortcut-record.d.ts +19 -0
  277. package/elements/shortcut-record.d.ts.map +1 -0
  278. package/elements/shortcut-record.js +127 -0
  279. package/elements/shortcut-record.js.map +1 -0
  280. package/elements/side-navigation.d.ts +31 -0
  281. package/elements/side-navigation.d.ts.map +1 -0
  282. package/elements/side-navigation.js +137 -0
  283. package/elements/side-navigation.js.map +1 -0
  284. package/elements/slider.d.ts +27 -0
  285. package/elements/slider.d.ts.map +1 -0
  286. package/elements/slider.js +219 -0
  287. package/elements/slider.js.map +1 -0
  288. package/elements/space.d.ts +10 -0
  289. package/elements/space.d.ts.map +1 -0
  290. package/elements/space.js +35 -0
  291. package/elements/space.js.map +1 -0
  292. package/elements/statistic.d.ts +24 -0
  293. package/elements/statistic.d.ts.map +1 -0
  294. package/elements/statistic.js +116 -0
  295. package/elements/statistic.js.map +1 -0
  296. package/elements/status-light.d.ts +14 -0
  297. package/elements/status-light.d.ts.map +1 -0
  298. package/elements/status-light.js +75 -0
  299. package/elements/status-light.js.map +1 -0
  300. package/elements/switch.d.ts +18 -0
  301. package/elements/switch.d.ts.map +1 -0
  302. package/elements/switch.js +117 -0
  303. package/elements/switch.js.map +1 -0
  304. package/elements/table.d.ts +36 -0
  305. package/elements/table.d.ts.map +1 -0
  306. package/elements/table.js +268 -0
  307. package/elements/table.js.map +1 -0
  308. package/elements/tabs.d.ts +29 -0
  309. package/elements/tabs.d.ts.map +1 -0
  310. package/elements/tabs.js +130 -0
  311. package/elements/tabs.js.map +1 -0
  312. package/elements/tag.d.ts +20 -0
  313. package/elements/tag.d.ts.map +1 -0
  314. package/elements/tag.js +120 -0
  315. package/elements/tag.js.map +1 -0
  316. package/elements/timeline.d.ts +19 -0
  317. package/elements/timeline.d.ts.map +1 -0
  318. package/elements/timeline.js +92 -0
  319. package/elements/timeline.js.map +1 -0
  320. package/elements/toast.d.ts +26 -0
  321. package/elements/toast.d.ts.map +1 -0
  322. package/elements/toast.js +149 -0
  323. package/elements/toast.js.map +1 -0
  324. package/elements/tooltip.d.ts +12 -0
  325. package/elements/tooltip.d.ts.map +1 -0
  326. package/elements/tooltip.js +27 -0
  327. package/elements/tooltip.js.map +1 -0
  328. package/elements/tree.d.ts +48 -0
  329. package/elements/tree.d.ts.map +1 -0
  330. package/elements/tree.js +231 -0
  331. package/elements/tree.js.map +1 -0
  332. package/elements/wait.d.ts +19 -0
  333. package/elements/wait.d.ts.map +1 -0
  334. package/elements/wait.js +97 -0
  335. package/elements/wait.js.map +1 -0
  336. package/lib/animations.d.ts +4 -0
  337. package/lib/animations.d.ts.map +1 -0
  338. package/lib/animations.js +8 -0
  339. package/lib/animations.js.map +1 -0
  340. package/lib/cache.d.ts +12 -0
  341. package/lib/cache.d.ts.map +1 -0
  342. package/lib/cache.js +56 -0
  343. package/lib/cache.js.map +1 -0
  344. package/lib/color.d.ts +37 -0
  345. package/lib/color.d.ts.map +1 -0
  346. package/lib/color.js +101 -0
  347. package/lib/color.js.map +1 -0
  348. package/lib/hotkeys.d.ts +31 -0
  349. package/lib/hotkeys.d.ts.map +1 -0
  350. package/lib/hotkeys.js +207 -0
  351. package/lib/hotkeys.js.map +1 -0
  352. package/lib/icons.d.ts +90 -0
  353. package/lib/icons.d.ts.map +1 -0
  354. package/lib/icons.js +81 -0
  355. package/lib/icons.js.map +1 -0
  356. package/lib/image.d.ts +29 -0
  357. package/lib/image.d.ts.map +1 -0
  358. package/lib/image.js +140 -0
  359. package/lib/image.js.map +1 -0
  360. package/lib/locale.d.ts +37 -0
  361. package/lib/locale.d.ts.map +1 -0
  362. package/lib/locale.js +14 -0
  363. package/lib/locale.js.map +1 -0
  364. package/lib/number.d.ts +80 -0
  365. package/lib/number.d.ts.map +1 -0
  366. package/lib/number.js +144 -0
  367. package/lib/number.js.map +1 -0
  368. package/lib/theme.d.ts +67 -0
  369. package/lib/theme.d.ts.map +1 -0
  370. package/lib/theme.js +56 -0
  371. package/lib/theme.js.map +1 -0
  372. package/lib/time.d.ts +58 -0
  373. package/lib/time.d.ts.map +1 -0
  374. package/lib/time.js +225 -0
  375. package/lib/time.js.map +1 -0
  376. package/lib/types.d.ts +8 -0
  377. package/lib/types.d.ts.map +1 -0
  378. package/lib/types.js +17 -0
  379. package/lib/types.js.map +1 -0
  380. package/lib/utils.d.ts +37 -0
  381. package/lib/utils.d.ts.map +1 -0
  382. package/lib/utils.js +249 -0
  383. package/lib/utils.js.map +1 -0
  384. package/locales/en.d.ts +34 -0
  385. package/locales/en.d.ts.map +1 -0
  386. package/locales/en.js +33 -0
  387. package/locales/en.js.map +1 -0
  388. package/locales/zh.d.ts +4 -0
  389. package/locales/zh.d.ts.map +1 -0
  390. package/locales/zh.js +34 -0
  391. package/locales/zh.js.map +1 -0
  392. package/package.json +39 -0
@@ -0,0 +1,130 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ import { GemElement, html, adoptedStyle, createCSSSheet, css, customElement, property, boolattribute, emitter, partMap, } from '@mantou/gem';
8
+ import { theme } from '../lib/theme';
9
+ import { DuoyunScrollBaseElement } from './base/scroll';
10
+ import '@mantou/gem/elements/use';
11
+ import './compartment';
12
+ import './divider';
13
+ const style = createCSSSheet(css `
14
+ :host {
15
+ display: flex;
16
+ flex-direction: column;
17
+ }
18
+ [part~='tabs'] {
19
+ display: flex;
20
+ font-size: 0.875em;
21
+ gap: 2em;
22
+ flex-shrink: 0;
23
+ }
24
+ .divider {
25
+ flex-shrink: 0;
26
+ }
27
+ :host([center]) [part~='tabs'] {
28
+ justify-content: center;
29
+ }
30
+ [part~='tab'] {
31
+ position: relative;
32
+ cursor: pointer;
33
+ display: flex;
34
+ align-items: center;
35
+ line-height: 1.5;
36
+ padding: 0.8em 0;
37
+ gap: 0.3em;
38
+ }
39
+ [part~='icon'] {
40
+ width: 1.2em;
41
+ }
42
+ [part~='tab']:hover,
43
+ [part~='current'] {
44
+ color: ${theme.primaryColor};
45
+ }
46
+ [part~='mark'] {
47
+ position: absolute;
48
+ bottom: 0;
49
+ left: 0;
50
+ width: 100%;
51
+ transform: translateY(100%);
52
+ }
53
+ `);
54
+ /**
55
+ * @customElement dy-tabs
56
+ */
57
+ let DuoyunTabsElement = class DuoyunTabsElement extends GemElement {
58
+ constructor() {
59
+ super();
60
+ this.render = () => {
61
+ if (!this.data)
62
+ return html ``;
63
+ let currentContent = '';
64
+ return html `
65
+ <div part="tabs">
66
+ ${this.data.map(({ value, tab, icon, getContent }, index) => {
67
+ const isCurrent = (value !== null && value !== void 0 ? value : index) === this.value;
68
+ if (isCurrent)
69
+ currentContent = (getContent === null || getContent === void 0 ? void 0 : getContent()) || '';
70
+ return html `
71
+ <div
72
+ role="tab"
73
+ part=${partMap({ tab: true, current: isCurrent })}
74
+ @click=${() => this.change(value !== null && value !== void 0 ? value : index)}
75
+ >
76
+ ${icon ? html `<gem-use part="icon" .element=${icon}></gem-use>` : ''}${tab}
77
+ ${isCurrent ? html `<dy-divider part="mark" size="medium" .color=${theme.primaryColor}></dy-divider>` : ''}
78
+ </div>
79
+ `;
80
+ })}
81
+ </div>
82
+ <dy-divider class="divider" size="medium"></dy-divider>
83
+ <dy-compartment .content=${currentContent}></dy-compartment>
84
+ `;
85
+ };
86
+ this.internals.role = 'tablist';
87
+ }
88
+ };
89
+ __decorate([
90
+ boolattribute
91
+ ], DuoyunTabsElement.prototype, "center", void 0);
92
+ __decorate([
93
+ property
94
+ ], DuoyunTabsElement.prototype, "data", void 0);
95
+ __decorate([
96
+ property
97
+ ], DuoyunTabsElement.prototype, "value", void 0);
98
+ __decorate([
99
+ emitter
100
+ ], DuoyunTabsElement.prototype, "change", void 0);
101
+ DuoyunTabsElement = __decorate([
102
+ customElement('dy-tabs'),
103
+ adoptedStyle(style)
104
+ ], DuoyunTabsElement);
105
+ export { DuoyunTabsElement };
106
+ const panelStyle = createCSSSheet(css `
107
+ :host {
108
+ display: block;
109
+ flex-shrink: 1;
110
+ flex-grow: 1;
111
+ line-height: 1.5;
112
+ margin-block-start: 1em;
113
+ overflow: auto;
114
+ }
115
+ `);
116
+ /**
117
+ * @customElement dy-tab-panel
118
+ */
119
+ let DyTabPanelElement = class DyTabPanelElement extends DuoyunScrollBaseElement {
120
+ constructor() {
121
+ super();
122
+ this.internals.role = 'tabpanel';
123
+ }
124
+ };
125
+ DyTabPanelElement = __decorate([
126
+ customElement('dy-tab-panel'),
127
+ adoptedStyle(panelStyle)
128
+ ], DyTabPanelElement);
129
+ export { DyTabPanelElement };
130
+ //# sourceMappingURL=tabs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tabs.js","sourceRoot":"","sources":["../src/elements/tabs.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EACL,UAAU,EACV,IAAI,EACJ,YAAY,EACZ,cAAc,EACd,GAAG,EACH,aAAa,EACb,QAAQ,EAER,aAAa,EACb,OAAO,EAEP,OAAO,GACR,MAAM,aAAa,CAAC;AAErB,OAAO,EAAE,KAAK,EAAE,MAAM,cAAc,CAAC;AAErC,OAAO,EAAE,uBAAuB,EAAE,MAAM,eAAe,CAAC;AAExD,OAAO,0BAA0B,CAAC;AAClC,OAAO,eAAe,CAAC;AACvB,OAAO,WAAW,CAAC;AAEnB,MAAM,KAAK,GAAG,cAAc,CAAC,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;aA+BnB,KAAK,CAAC,YAAY;;;;;;;;;CAS9B,CAAC,CAAC;AAQH;;GAEG;AAGH,IAAa,iBAAiB,GAA9B,MAAa,iBAAkB,SAAQ,UAAU;IAM/C;QACE,KAAK,EAAE,CAAC;QAIV,WAAM,GAAG,GAAG,EAAE;YACZ,IAAI,CAAC,IAAI,CAAC,IAAI;gBAAE,OAAO,IAAI,CAAA,EAAE,CAAC;YAC9B,IAAI,cAAc,GAA4B,EAAE,CAAC;YACjD,OAAO,IAAI,CAAA;;UAEL,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,EAAE,KAAK,EAAE,EAAE;gBAC1D,MAAM,SAAS,GAAG,CAAC,KAAK,aAAL,KAAK,cAAL,KAAK,GAAI,KAAK,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC;gBAClD,IAAI,SAAS;oBAAE,cAAc,GAAG,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,EAAI,KAAI,EAAE,CAAC;gBACrD,OAAO,IAAI,CAAA;;;qBAGA,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC;uBACxC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,aAAL,KAAK,cAAL,KAAK,GAAI,KAAK,CAAC;;gBAExC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAA,iCAAiC,IAAI,aAAa,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG;gBACxE,SAAS,CAAC,CAAC,CAAC,IAAI,CAAA,gDAAgD,KAAK,CAAC,YAAY,gBAAgB,CAAC,CAAC,CAAC,EAAE;;WAE5G,CAAC;YACJ,CAAC,CAAC;;;iCAGuB,cAAc;KAC1C,CAAC;QACJ,CAAC,CAAC;QA1BA,IAAI,CAAC,SAAS,CAAC,IAAI,GAAG,SAAS,CAAC;IAClC,CAAC;CA0BF,CAAA;AAlCgB;IAAd,aAAa;iDAAiB;AACrB;IAAT,QAAQ;+CAAkB;AACjB;IAAT,QAAQ;gDAAa;AACb;IAAR,OAAO;iDAAsB;AAJnB,iBAAiB;IAF7B,aAAa,CAAC,SAAS,CAAC;IACxB,YAAY,CAAC,KAAK,CAAC;GACP,iBAAiB,CAmC7B;SAnCY,iBAAiB;AAqC9B,MAAM,UAAU,GAAG,cAAc,CAAC,GAAG,CAAA;;;;;;;;;CASpC,CAAC,CAAC;AAEH;;GAEG;AAGH,IAAa,iBAAiB,GAA9B,MAAa,iBAAkB,SAAQ,uBAAuB;IAC5D;QACE,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,SAAS,CAAC,IAAI,GAAG,UAAU,CAAC;IACnC,CAAC;CACF,CAAA;AALY,iBAAiB;IAF7B,aAAa,CAAC,cAAc,CAAC;IAC7B,YAAY,CAAC,UAAU,CAAC;GACZ,iBAAiB,CAK7B;SALY,iBAAiB"}
@@ -0,0 +1,20 @@
1
+ import { GemElement, Emitter } from '@mantou/gem';
2
+ import { StringList } from '../lib/types';
3
+ import '@mantou/gem/elements/use';
4
+ export declare type PresetColor = 'positive' | 'informative' | 'negative' | 'notice' | 'default';
5
+ /**
6
+ * @customElement dy-tag
7
+ * @attr small
8
+ * @fires close
9
+ */
10
+ export declare class DuoyunTagElement extends GemElement {
11
+ #private;
12
+ closeable: boolean;
13
+ color: StringList<PresetColor>;
14
+ mode: 'solid' | 'reverse';
15
+ small: boolean;
16
+ close: Emitter<null>;
17
+ constructor();
18
+ render: () => import("@mantou/gem").TemplateResult;
19
+ }
20
+ //# sourceMappingURL=tag.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tag.d.ts","sourceRoot":"","sources":["../src/elements/tag.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,UAAU,EAQV,OAAO,EAGR,MAAM,aAAa,CAAC;AAIrB,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAG1C,OAAO,0BAA0B,CAAC;AA4BlC,oBAAY,WAAW,GAAG,UAAU,GAAG,aAAa,GAAG,UAAU,GAAG,QAAQ,GAAG,SAAS,CAAC;AAEzF;;;;GAIG;AACH,qBAGa,gBAAiB,SAAQ,UAAU;;IAC/B,SAAS,EAAE,OAAO,CAAC;IACvB,KAAK,EAAE,UAAU,CAAC,WAAW,CAAC,CAAC;IAC/B,IAAI,EAAE,OAAO,GAAG,SAAS,CAAC;IACtB,KAAK,EAAE,OAAO,CAAC;IAErB,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;;IA4B9B,MAAM,6CA0BJ;CACH"}
@@ -0,0 +1,120 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
8
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
9
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
10
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
11
+ };
12
+ var _DuoyunTagElement_instances, _DuoyunTagElement_color_get, _DuoyunTagElement_mode_get, _DuoyunTagElement_onClose;
13
+ import { GemElement, html, adoptedStyle, createCSSSheet, css, customElement, connectStore, emitter, boolattribute, attribute, } from '@mantou/gem';
14
+ import { icons } from '../lib/icons';
15
+ import { theme, getSemanticColor } from '../lib/theme';
16
+ import { commonHandle } from '../lib/hotkeys';
17
+ import '@mantou/gem/elements/use';
18
+ const style = createCSSSheet(css `
19
+ :host {
20
+ display: inline-flex;
21
+ align-items: center;
22
+ justify-content: center;
23
+ gap: 0.3em;
24
+ font-size: 0.875em;
25
+ line-height: 1.2;
26
+ padding: 0.5em 0.6em;
27
+ border-radius: ${theme.normalRound};
28
+ border-width: 1px;
29
+ border-style: solid;
30
+ }
31
+ :host([small]) {
32
+ font-size: 0.75em;
33
+ }
34
+ .close {
35
+ width: 1.2em;
36
+ opacity: 0.7;
37
+ flex-shrink: 0;
38
+ }
39
+ .close:hover {
40
+ opacity: 1;
41
+ }
42
+ `);
43
+ /**
44
+ * @customElement dy-tag
45
+ * @attr small
46
+ * @fires close
47
+ */
48
+ let DuoyunTagElement = class DuoyunTagElement extends GemElement {
49
+ constructor() {
50
+ super();
51
+ _DuoyunTagElement_instances.add(this);
52
+ _DuoyunTagElement_onClose.set(this, (e) => {
53
+ e.stopPropagation();
54
+ this.close(null);
55
+ });
56
+ this.render = () => {
57
+ const isSolid = __classPrivateFieldGet(this, _DuoyunTagElement_instances, "a", _DuoyunTagElement_mode_get) === 'solid';
58
+ const isDefault = this.color === 'default' || this.color === '';
59
+ return html `
60
+ <style>
61
+ :host {
62
+ color: ${isDefault ? theme.textColor : isSolid ? theme.backgroundColor : __classPrivateFieldGet(this, _DuoyunTagElement_instances, "a", _DuoyunTagElement_color_get)};
63
+ background-color: ${isSolid ? __classPrivateFieldGet(this, _DuoyunTagElement_instances, "a", _DuoyunTagElement_color_get) : 'transparent'};
64
+ border-color: ${__classPrivateFieldGet(this, _DuoyunTagElement_instances, "a", _DuoyunTagElement_color_get)};
65
+ }
66
+ </style>
67
+ <slot></slot>
68
+ ${this.closeable
69
+ ? html `
70
+ <gem-use
71
+ tabindex="0"
72
+ role="button"
73
+ class="close"
74
+ @keydown=${commonHandle}
75
+ @click=${__classPrivateFieldGet(this, _DuoyunTagElement_onClose, "f")}
76
+ .element=${icons.close}
77
+ ></gem-use>
78
+ `
79
+ : ''}
80
+ `;
81
+ };
82
+ this.internals.role = 'mark';
83
+ }
84
+ };
85
+ _DuoyunTagElement_onClose = new WeakMap(), _DuoyunTagElement_instances = new WeakSet(), _DuoyunTagElement_color_get = function _DuoyunTagElement_color_get() {
86
+ const semanticColor = getSemanticColor(this.color);
87
+ if (semanticColor)
88
+ return semanticColor;
89
+ switch (this.color) {
90
+ case '':
91
+ case 'default':
92
+ return theme.hoverBackgroundColor;
93
+ default:
94
+ return this.color;
95
+ }
96
+ }, _DuoyunTagElement_mode_get = function _DuoyunTagElement_mode_get() {
97
+ return this.mode || 'solid';
98
+ };
99
+ __decorate([
100
+ boolattribute
101
+ ], DuoyunTagElement.prototype, "closeable", void 0);
102
+ __decorate([
103
+ attribute
104
+ ], DuoyunTagElement.prototype, "color", void 0);
105
+ __decorate([
106
+ attribute
107
+ ], DuoyunTagElement.prototype, "mode", void 0);
108
+ __decorate([
109
+ boolattribute
110
+ ], DuoyunTagElement.prototype, "small", void 0);
111
+ __decorate([
112
+ emitter
113
+ ], DuoyunTagElement.prototype, "close", void 0);
114
+ DuoyunTagElement = __decorate([
115
+ customElement('dy-tag'),
116
+ adoptedStyle(style),
117
+ connectStore(icons)
118
+ ], DuoyunTagElement);
119
+ export { DuoyunTagElement };
120
+ //# sourceMappingURL=tag.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tag.js","sourceRoot":"","sources":["../src/elements/tag.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,OAAO,EACL,UAAU,EACV,IAAI,EACJ,YAAY,EACZ,cAAc,EACd,GAAG,EACH,aAAa,EACb,YAAY,EACZ,OAAO,EAEP,aAAa,EACb,SAAS,GACV,MAAM,aAAa,CAAC;AAErB,OAAO,EAAE,KAAK,EAAE,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,KAAK,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAEvD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAE9C,OAAO,0BAA0B,CAAC;AAElC,MAAM,KAAK,GAAG,cAAc,CAAC,GAAG,CAAA;;;;;;;;;qBASX,KAAK,CAAC,WAAW;;;;;;;;;;;;;;;CAerC,CAAC,CAAC;AAIH;;;;GAIG;AAIH,IAAa,gBAAgB,GAA7B,MAAa,gBAAiB,SAAQ,UAAU;IAwB9C;QACE,KAAK,EAAE,CAAC;;QAIV,oCAAW,CAAC,CAAa,EAAE,EAAE;YAC3B,CAAC,CAAC,eAAe,EAAE,CAAC;YACpB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QACnB,CAAC,EAAC;QAEF,WAAM,GAAG,GAAG,EAAE;YACZ,MAAM,OAAO,GAAG,uBAAA,IAAI,+DAAM,KAAK,OAAO,CAAC;YACvC,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,KAAK,SAAS,IAAI,IAAI,CAAC,KAAK,KAAK,EAAE,CAAC;YAEhE,OAAO,IAAI,CAAA;;;mBAGI,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC,uBAAA,IAAI,gEAAO;8BAChE,OAAO,CAAC,CAAC,CAAC,uBAAA,IAAI,gEAAO,CAAC,CAAC,CAAC,aAAa;0BACzC,uBAAA,IAAI,gEAAO;;;;QAI7B,IAAI,CAAC,SAAS;gBACd,CAAC,CAAC,IAAI,CAAA;;;;;yBAKW,YAAY;uBACd,uBAAA,IAAI,iCAAS;yBACX,KAAK,CAAC,KAAK;;WAEzB;gBACH,CAAC,CAAC,EAAE;KACP,CAAC;QACJ,CAAC,CAAC;QAlCA,IAAI,CAAC,SAAS,CAAC,IAAI,GAAG,MAAM,CAAC;IAC/B,CAAC;CAkCF,CAAA;;IApDG,MAAM,aAAa,GAAG,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACnD,IAAI,aAAa;QAAE,OAAO,aAAa,CAAC;IACxC,QAAQ,IAAI,CAAC,KAAK,EAAE;QAClB,KAAK,EAAE,CAAC;QACR,KAAK,SAAS;YACZ,OAAO,KAAK,CAAC,oBAAoB,CAAC;QACpC;YACE,OAAO,IAAI,CAAC,KAAK,CAAC;KACrB;AACH,CAAC;IAGC,OAAO,IAAI,CAAC,IAAI,IAAI,OAAO,CAAC;AAC9B,CAAC;AArBc;IAAd,aAAa;mDAAoB;AACvB;IAAV,SAAS;+CAAgC;AAC/B;IAAV,SAAS;8CAA2B;AACtB;IAAd,aAAa;+CAAgB;AAErB;IAAR,OAAO;+CAAsB;AANnB,gBAAgB;IAH5B,aAAa,CAAC,QAAQ,CAAC;IACvB,YAAY,CAAC,KAAK,CAAC;IACnB,YAAY,CAAC,KAAK,CAAC;GACP,gBAAgB,CA6D5B;SA7DY,gBAAgB"}
@@ -0,0 +1,19 @@
1
+ import { TemplateResult } from '@mantou/gem';
2
+ import { DuoyunScrollBaseElement } from './base/scroll';
3
+ import '@mantou/gem/elements/use';
4
+ declare type Item = {
5
+ title: string;
6
+ description: string | TemplateResult;
7
+ icon?: string | DocumentFragment | Element;
8
+ color?: string;
9
+ };
10
+ /**
11
+ * @customElement dy-timeline
12
+ */
13
+ export declare class DuoyunTimelineElement extends DuoyunScrollBaseElement {
14
+ events?: Item[];
15
+ constructor();
16
+ render: () => TemplateResult;
17
+ }
18
+ export {};
19
+ //# sourceMappingURL=timeline.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"timeline.d.ts","sourceRoot":"","sources":["../src/elements/timeline.ts"],"names":[],"mappings":"AACA,OAAO,EAOL,cAAc,EAGf,MAAM,aAAa,CAAC;AAIrB,OAAO,EAAE,uBAAuB,EAAE,MAAM,eAAe,CAAC;AAExD,OAAO,0BAA0B,CAAC;AA+ClC,aAAK,IAAI,GAAG;IACV,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,GAAG,cAAc,CAAC;IACrC,IAAI,CAAC,EAAE,MAAM,GAAG,gBAAgB,GAAG,OAAO,CAAC;IAC3C,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF;;GAEG;AACH,qBAEa,qBAAsB,SAAQ,uBAAuB;IACtD,MAAM,CAAC,EAAE,IAAI,EAAE,CAAC;;IAO1B,MAAM,uBAoBJ;CACH"}
@@ -0,0 +1,92 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ // https://ant.design/components/timeline/
8
+ import { html, adoptedStyle, createCSSSheet, css, customElement, property, classMap, styleMap, } from '@mantou/gem';
9
+ import { theme } from '../lib/theme';
10
+ import { DuoyunScrollBaseElement } from './base/scroll';
11
+ import '@mantou/gem/elements/use';
12
+ const style = createCSSSheet(css `
13
+ :host {
14
+ --size: 1.5em;
15
+ line-height: var(--size);
16
+ display: block;
17
+ overflow: auto;
18
+ }
19
+ .item {
20
+ position: relative;
21
+ padding-inline-start: var(--size);
22
+ }
23
+ .line,
24
+ .dot {
25
+ position: absolute;
26
+ content: '';
27
+ left: calc(var(--size) / 4);
28
+ }
29
+ .line {
30
+ top: var(--size);
31
+ bottom: 0;
32
+ transform: translateX(-50%);
33
+ width: 2px;
34
+ background-color: ${theme.borderColor};
35
+ }
36
+ .last {
37
+ display: none;
38
+ }
39
+ .dot {
40
+ top: calc(var(--size) / 2);
41
+ box-sizing: border-box;
42
+ width: calc(var(--size) / 2);
43
+ aspect-ratio: 1;
44
+ transform: translate(-50%, -50%);
45
+ }
46
+ .circle {
47
+ border-radius: 50%;
48
+ color: ${theme.informativeColor};
49
+ border: 2px solid currentColor;
50
+ }
51
+ .desc {
52
+ color: ${theme.describeColor};
53
+ padding-block-end: 0.5em;
54
+ }
55
+ `);
56
+ /**
57
+ * @customElement dy-timeline
58
+ */
59
+ let DuoyunTimelineElement = class DuoyunTimelineElement extends DuoyunScrollBaseElement {
60
+ constructor() {
61
+ super();
62
+ this.render = () => {
63
+ const events = this.events;
64
+ if (!events)
65
+ return html ``;
66
+ return html `
67
+ ${events.map(({ title, description, icon, color }, index) => html `
68
+ <div role="listitem" class="item">
69
+ <div class=${classMap({ line: true, last: index === events.length - 1 })}></div>
70
+ <gem-use
71
+ class=${classMap({ dot: true, circle: !icon })}
72
+ style=${styleMap({ color })}
73
+ .element=${icon}
74
+ ></gem-use>
75
+ <div class="title">${title}</div>
76
+ <div class="desc">${description}</div>
77
+ </div>
78
+ `)}
79
+ `;
80
+ };
81
+ this.internals.role = 'list';
82
+ }
83
+ };
84
+ __decorate([
85
+ property
86
+ ], DuoyunTimelineElement.prototype, "events", void 0);
87
+ DuoyunTimelineElement = __decorate([
88
+ customElement('dy-timeline'),
89
+ adoptedStyle(style)
90
+ ], DuoyunTimelineElement);
91
+ export { DuoyunTimelineElement };
92
+ //# sourceMappingURL=timeline.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"timeline.js","sourceRoot":"","sources":["../src/elements/timeline.ts"],"names":[],"mappings":";;;;;;AAAA,0CAA0C;AAC1C,OAAO,EACL,IAAI,EACJ,YAAY,EACZ,cAAc,EACd,GAAG,EACH,aAAa,EACb,QAAQ,EAER,QAAQ,EACR,QAAQ,GACT,MAAM,aAAa,CAAC;AAErB,OAAO,EAAE,KAAK,EAAE,MAAM,cAAc,CAAC;AAErC,OAAO,EAAE,uBAAuB,EAAE,MAAM,eAAe,CAAC;AAExD,OAAO,0BAA0B,CAAC;AAElC,MAAM,KAAK,GAAG,cAAc,CAAC,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;wBAsBR,KAAK,CAAC,WAAW;;;;;;;;;;;;;;aAc5B,KAAK,CAAC,gBAAgB;;;;aAItB,KAAK,CAAC,aAAa;;;CAG/B,CAAC,CAAC;AASH;;GAEG;AAGH,IAAa,qBAAqB,GAAlC,MAAa,qBAAsB,SAAQ,uBAAuB;IAGhE;QACE,KAAK,EAAE,CAAC;QAIV,WAAM,GAAG,GAAG,EAAE;YACZ,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YAC3B,IAAI,CAAC,MAAM;gBAAE,OAAO,IAAI,CAAA,EAAE,CAAC;YAE3B,OAAO,IAAI,CAAA;QACP,MAAM,CAAC,GAAG,CACV,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,CAAA;;yBAEnC,QAAQ,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,KAAK,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;;sBAE9D,QAAQ,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,IAAI,EAAE,CAAC;sBACtC,QAAQ,CAAC,EAAE,KAAK,EAAE,CAAC;yBAChB,IAAI;;iCAEI,KAAK;gCACN,WAAW;;SAElC,CACF;KACF,CAAC;QACJ,CAAC,CAAC;QAvBA,IAAI,CAAC,SAAS,CAAC,IAAI,GAAG,MAAM,CAAC;IAC/B,CAAC;CAuBF,CAAA;AA5BW;IAAT,QAAQ;qDAAiB;AADf,qBAAqB;IAFjC,aAAa,CAAC,aAAa,CAAC;IAC5B,YAAY,CAAC,KAAK,CAAC;GACP,qBAAqB,CA6BjC;SA7BY,qBAAqB"}
@@ -0,0 +1,26 @@
1
+ import { GemElement, TemplateResult } from '@mantou/gem';
2
+ import '@mantou/gem/elements/use';
3
+ declare type Type = 'success' | 'warning' | 'error' | 'default';
4
+ interface Item {
5
+ type: Type;
6
+ content: string | TemplateResult;
7
+ }
8
+ interface Option {
9
+ duration?: number;
10
+ debug?: boolean;
11
+ }
12
+ /**
13
+ * @customElement dy-toast
14
+ */
15
+ export declare class DuoyunToastElement extends GemElement {
16
+ #private;
17
+ data?: Item[];
18
+ static instance?: DuoyunToastElement;
19
+ static open(type: Type, content: string | TemplateResult, { debug, duration }?: Option): void;
20
+ constructor();
21
+ mounted: () => () => undefined;
22
+ render: () => TemplateResult;
23
+ }
24
+ export declare const Toast: typeof DuoyunToastElement;
25
+ export {};
26
+ //# sourceMappingURL=toast.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"toast.d.ts","sourceRoot":"","sources":["../src/elements/toast.ts"],"names":[],"mappings":"AAAA,OAAO,EAML,UAAU,EAGV,cAAc,EAEf,MAAM,aAAa,CAAC;AAKrB,OAAO,0BAA0B,CAAC;AAiDlC,aAAK,IAAI,GAAG,SAAS,GAAG,SAAS,GAAG,OAAO,GAAG,SAAS,CAAC;AAExD,UAAU,IAAI;IACZ,IAAI,EAAE,IAAI,CAAC;IACX,OAAO,EAAE,MAAM,GAAG,cAAc,CAAC;CAClC;AAID,UAAU,MAAM;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB;AAED;;GAEG;AACH,qBAEa,kBAAmB,SAAQ,UAAU;;IACtC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC;IAExB,MAAM,CAAC,QAAQ,CAAC,EAAE,kBAAkB,CAAC;IAErC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,GAAG,cAAc,EAAE,EAAE,KAAK,EAAE,QAAe,EAAE,GAAE,MAAW;;IAsDjG,OAAO,wBAGL;IAEF,MAAM,uBAWJ;CACH;AAED,eAAO,MAAM,KAAK,2BAAqB,CAAC"}
@@ -0,0 +1,149 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
8
+ if (kind === "m") throw new TypeError("Private method is not writable");
9
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
10
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
11
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
12
+ };
13
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
14
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
15
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
16
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
17
+ };
18
+ var _DuoyunToastElement_over, _DuoyunToastElement_getIcon;
19
+ import { adoptedStyle, classMap, createCSSSheet, css, customElement, GemElement, html, property, isArrayChange, } from '@mantou/gem';
20
+ import { icons } from '../lib/icons';
21
+ import { theme } from '../lib/theme';
22
+ import '@mantou/gem/elements/use';
23
+ const style = createCSSSheet(css `
24
+ :host {
25
+ z-index: 999999;
26
+ position: fixed;
27
+ display: flex;
28
+ align-items: center;
29
+ flex-direction: column;
30
+ gap: 1em;
31
+ top: calc(1em + env(titlebar-area-height, 0px));
32
+ left: 50%;
33
+ transform: translateX(-50%);
34
+ max-width: 90%;
35
+ font-size: 0.875em;
36
+ }
37
+ .item {
38
+ display: flex;
39
+ align-items: center;
40
+ gap: 0.5em;
41
+ color: white;
42
+ background: ${theme.informativeColor};
43
+ border-radius: ${theme.normalRound};
44
+ padding: 0.6em 0.8em;
45
+ line-height: 1;
46
+ max-width: 100%;
47
+ }
48
+ .success {
49
+ background: ${theme.positiveColor};
50
+ }
51
+ .warning {
52
+ background: ${theme.noticeColor};
53
+ }
54
+ .error {
55
+ background: ${theme.negativeColor};
56
+ }
57
+ gem-use {
58
+ width: 1.2em;
59
+ }
60
+ .body {
61
+ overflow: hidden;
62
+ text-overflow: ellipsis;
63
+ white-space: nowrap;
64
+ }
65
+ .body::first-letter {
66
+ text-transform: capitalize;
67
+ }
68
+ `);
69
+ const itemMap = new Map();
70
+ /**
71
+ * @customElement dy-toast
72
+ */
73
+ let DuoyunToastElement = class DuoyunToastElement extends GemElement {
74
+ constructor() {
75
+ super();
76
+ _DuoyunToastElement_over.set(this, Promise.resolve());
77
+ _DuoyunToastElement_getIcon.set(this, (type) => {
78
+ switch (type) {
79
+ case 'success':
80
+ return icons.success;
81
+ case 'warning':
82
+ return icons.warning;
83
+ case 'error':
84
+ return icons.error;
85
+ default:
86
+ return icons.info;
87
+ }
88
+ });
89
+ this.mounted = () => {
90
+ Toast.instance = this;
91
+ return () => (Toast.instance = undefined);
92
+ };
93
+ this.render = () => {
94
+ var _a;
95
+ return html `
96
+ ${(_a = this.data) === null || _a === void 0 ? void 0 : _a.map(({ type, content }) => html `
97
+ <div class=${classMap({ item: true, [type]: true })}>
98
+ <gem-use .element=${__classPrivateFieldGet(this, _DuoyunToastElement_getIcon, "f").call(this, type)}></gem-use>
99
+ <span class="body">${content}</span>
100
+ </div>
101
+ `)}
102
+ `;
103
+ };
104
+ this.internals.role = 'alert';
105
+ this.internals.ariaLive = 'polite';
106
+ if (Toast.instance)
107
+ throw new Error('Single instance component');
108
+ document.body.append(this);
109
+ this.addEventListener('mouseover', () => {
110
+ __classPrivateFieldSet(this, _DuoyunToastElement_over, new Promise((res) => {
111
+ this.addEventListener('mouseout', () => res(), { once: true });
112
+ }), "f");
113
+ });
114
+ }
115
+ static open(type, content, { debug, duration = 3000 } = {}) {
116
+ var _a;
117
+ const toast = Toast.instance || new Toast();
118
+ const item = ((_a = toast.data) === null || _a === void 0 ? void 0 : _a.find((e) => {
119
+ if (e.type !== type)
120
+ return false;
121
+ // support simple `TemplateResult`
122
+ return typeof e.content === 'string' || typeof content === 'string'
123
+ ? e.content === content
124
+ : !isArrayChange(content.values, e.content.values);
125
+ })) || { type, content };
126
+ clearTimeout(itemMap.get(item));
127
+ toast.data = [...(toast.data || []).filter((e) => e !== item), item];
128
+ itemMap.set(item, window.setTimeout(async () => {
129
+ await __classPrivateFieldGet(toast, _DuoyunToastElement_over, "f");
130
+ if (!toast.data)
131
+ return;
132
+ itemMap.delete(item);
133
+ toast.data = toast.data.filter((e) => e !== item);
134
+ if (toast.data.length === 0)
135
+ toast.remove();
136
+ }, debug ? 1000000 : duration));
137
+ }
138
+ };
139
+ _DuoyunToastElement_over = new WeakMap(), _DuoyunToastElement_getIcon = new WeakMap();
140
+ __decorate([
141
+ property
142
+ ], DuoyunToastElement.prototype, "data", void 0);
143
+ DuoyunToastElement = __decorate([
144
+ customElement('dy-toast'),
145
+ adoptedStyle(style)
146
+ ], DuoyunToastElement);
147
+ export { DuoyunToastElement };
148
+ export const Toast = DuoyunToastElement;
149
+ //# sourceMappingURL=toast.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"toast.js","sourceRoot":"","sources":["../src/elements/toast.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,12 @@
1
+ import { DuoyunPopoverElement } from './popover';
2
+ /**
3
+ * @customElement dy-tooltip
4
+ */
5
+ export declare class DuoyunTooltipElement extends DuoyunPopoverElement {
6
+ ghostStyle: {
7
+ '--bg': string;
8
+ '--color': string;
9
+ 'max-width': string;
10
+ };
11
+ }
12
+ //# sourceMappingURL=tooltip.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tooltip.d.ts","sourceRoot":"","sources":["../src/elements/tooltip.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,oBAAoB,EAAE,MAAM,WAAW,CAAC;AAEjD;;GAEG;AACH,qBACa,oBAAqB,SAAQ,oBAAoB;IAC5D,UAAU;;;;MAIR;CACH"}
@@ -0,0 +1,27 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ import { customElement } from '@mantou/gem';
8
+ import { theme } from '../lib/theme';
9
+ import { DuoyunPopoverElement } from './popover';
10
+ /**
11
+ * @customElement dy-tooltip
12
+ */
13
+ let DuoyunTooltipElement = class DuoyunTooltipElement extends DuoyunPopoverElement {
14
+ constructor() {
15
+ super(...arguments);
16
+ this.ghostStyle = {
17
+ '--bg': theme.highlightColor,
18
+ '--color': theme.backgroundColor,
19
+ 'max-width': '15em',
20
+ };
21
+ }
22
+ };
23
+ DuoyunTooltipElement = __decorate([
24
+ customElement('dy-tooltip')
25
+ ], DuoyunTooltipElement);
26
+ export { DuoyunTooltipElement };
27
+ //# sourceMappingURL=tooltip.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tooltip.js","sourceRoot":"","sources":["../src/elements/tooltip.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAE5C,OAAO,EAAE,KAAK,EAAE,MAAM,cAAc,CAAC;AAErC,OAAO,EAAE,oBAAoB,EAAE,MAAM,WAAW,CAAC;AAEjD;;GAEG;AAEH,IAAa,oBAAoB,GAAjC,MAAa,oBAAqB,SAAQ,oBAAoB;IAA9D;;QACE,eAAU,GAAG;YACX,MAAM,EAAE,KAAK,CAAC,cAAc;YAC5B,SAAS,EAAE,KAAK,CAAC,eAAe;YAChC,WAAW,EAAE,MAAM;SACpB,CAAC;IACJ,CAAC;CAAA,CAAA;AANY,oBAAoB;IADhC,aAAa,CAAC,YAAY,CAAC;GACf,oBAAoB,CAMhC;SANY,oBAAoB"}