godown 2.7.7 → 3.0.0-canary.1

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 (736) hide show
  1. package/README.md +44 -80
  2. package/alert.d.ts +2 -3
  3. package/alert.d.ts.map +1 -1
  4. package/alert.js +5 -4
  5. package/alert.js.map +1 -1
  6. package/avatar.d.ts +2 -3
  7. package/avatar.d.ts.map +1 -1
  8. package/avatar.js +5 -4
  9. package/avatar.js.map +1 -1
  10. package/breath.d.ts +9 -0
  11. package/breath.d.ts.map +1 -0
  12. package/breath.js +6 -0
  13. package/breath.js.map +1 -0
  14. package/button.d.ts +2 -3
  15. package/button.d.ts.map +1 -1
  16. package/button.js +5 -4
  17. package/button.js.map +1 -1
  18. package/card.d.ts +2 -3
  19. package/card.d.ts.map +1 -1
  20. package/card.js +5 -4
  21. package/card.js.map +1 -1
  22. package/carousel.d.ts +2 -3
  23. package/carousel.d.ts.map +1 -1
  24. package/carousel.js +5 -4
  25. package/carousel.js.map +1 -1
  26. package/components/alert.d.ts +50 -0
  27. package/components/alert.d.ts.map +1 -0
  28. package/components/alert.js +167 -0
  29. package/components/alert.js.map +1 -0
  30. package/components/avatar.d.ts +26 -0
  31. package/components/avatar.d.ts.map +1 -0
  32. package/components/avatar.js +62 -0
  33. package/components/avatar.js.map +1 -0
  34. package/components/breath.d.ts +34 -0
  35. package/components/breath.d.ts.map +1 -0
  36. package/components/breath.js +80 -0
  37. package/components/breath.js.map +1 -0
  38. package/{web-components/button → components}/button.d.ts +6 -5
  39. package/components/button.d.ts.map +1 -0
  40. package/components/button.js +167 -0
  41. package/components/button.js.map +1 -0
  42. package/components/card.d.ts +20 -0
  43. package/components/card.d.ts.map +1 -0
  44. package/components/card.js +55 -0
  45. package/components/card.js.map +1 -0
  46. package/components/carousel.d.ts +40 -0
  47. package/components/carousel.d.ts.map +1 -0
  48. package/components/carousel.js +113 -0
  49. package/components/carousel.js.map +1 -0
  50. package/{web-components/details → components}/details.d.ts +5 -3
  51. package/components/details.d.ts.map +1 -0
  52. package/components/details.js +50 -0
  53. package/components/details.js.map +1 -0
  54. package/components/dialog.d.ts +33 -0
  55. package/components/dialog.d.ts.map +1 -0
  56. package/components/dialog.js +92 -0
  57. package/components/dialog.js.map +1 -0
  58. package/components/divider.d.ts +17 -0
  59. package/components/divider.d.ts.map +1 -0
  60. package/components/divider.js +37 -0
  61. package/components/divider.js.map +1 -0
  62. package/{web-components/wrapper → components}/dragbox.d.ts +15 -5
  63. package/components/dragbox.d.ts.map +1 -0
  64. package/components/dragbox.js +110 -0
  65. package/components/dragbox.js.map +1 -0
  66. package/components/flex.d.ts +31 -0
  67. package/components/flex.d.ts.map +1 -0
  68. package/components/flex.js +55 -0
  69. package/components/flex.js.map +1 -0
  70. package/{web-components/form → components}/form.d.ts +4 -2
  71. package/components/form.d.ts.map +1 -0
  72. package/components/form.js +78 -0
  73. package/components/form.js.map +1 -0
  74. package/components/grid.d.ts +31 -0
  75. package/components/grid.d.ts.map +1 -0
  76. package/components/grid.js +56 -0
  77. package/components/grid.js.map +1 -0
  78. package/components/input.d.ts +20 -0
  79. package/components/input.d.ts.map +1 -0
  80. package/components/input.js +54 -0
  81. package/components/input.js.map +1 -0
  82. package/components/layout.d.ts +29 -0
  83. package/components/layout.d.ts.map +1 -0
  84. package/components/layout.js +48 -0
  85. package/components/layout.js.map +1 -0
  86. package/components/link.d.ts +20 -0
  87. package/components/link.d.ts.map +1 -0
  88. package/components/link.js +43 -0
  89. package/components/link.js.map +1 -0
  90. package/{web-components/progress → components}/progress.d.ts +5 -3
  91. package/components/progress.d.ts.map +1 -0
  92. package/components/progress.js +68 -0
  93. package/components/progress.js.map +1 -0
  94. package/components/range.d.ts +60 -0
  95. package/components/range.d.ts.map +1 -0
  96. package/components/range.js +193 -0
  97. package/components/range.js.map +1 -0
  98. package/{web-components/wrapper → components}/rotate.d.ts +4 -8
  99. package/components/rotate.d.ts.map +1 -0
  100. package/components/rotate.js +57 -0
  101. package/components/rotate.js.map +1 -0
  102. package/components/router.d.ts +121 -0
  103. package/components/router.d.ts.map +1 -0
  104. package/components/router.js +251 -0
  105. package/components/router.js.map +1 -0
  106. package/components/select.d.ts +50 -0
  107. package/components/select.d.ts.map +1 -0
  108. package/components/select.js +211 -0
  109. package/components/select.js.map +1 -0
  110. package/{web-components/skeleton → components}/skeleton.d.ts +6 -6
  111. package/components/skeleton.d.ts.map +1 -0
  112. package/components/skeleton.js +56 -0
  113. package/components/skeleton.js.map +1 -0
  114. package/components/split.d.ts +32 -0
  115. package/components/split.d.ts.map +1 -0
  116. package/components/split.js +121 -0
  117. package/components/split.js.map +1 -0
  118. package/{web-components/input/switch-input.d.ts → components/switch.d.ts} +9 -10
  119. package/components/switch.d.ts.map +1 -0
  120. package/components/switch.js +93 -0
  121. package/components/switch.js.map +1 -0
  122. package/{web-components/text → components}/text.d.ts +5 -3
  123. package/components/text.d.ts.map +1 -0
  124. package/components/text.js +44 -0
  125. package/components/text.js.map +1 -0
  126. package/{web-components/text → components}/time.d.ts +5 -3
  127. package/components/time.d.ts.map +1 -0
  128. package/components/time.js +139 -0
  129. package/components/time.js.map +1 -0
  130. package/components/tooltip.d.ts +38 -0
  131. package/components/tooltip.d.ts.map +1 -0
  132. package/components/tooltip.js +67 -0
  133. package/components/tooltip.js.map +1 -0
  134. package/{web-components/text → components}/typewriter.d.ts +5 -3
  135. package/components/typewriter.d.ts.map +1 -0
  136. package/components/typewriter.js +130 -0
  137. package/components/typewriter.js.map +1 -0
  138. package/core/global-style.d.ts +21 -0
  139. package/core/global-style.d.ts.map +1 -0
  140. package/core/global-style.js +46 -0
  141. package/core/global-style.js.map +1 -0
  142. package/core/super-anchor.d.ts +15 -0
  143. package/core/super-anchor.d.ts.map +1 -0
  144. package/core/super-anchor.js +39 -0
  145. package/core/super-anchor.js.map +1 -0
  146. package/core/super-input.d.ts +39 -0
  147. package/core/super-input.d.ts.map +1 -0
  148. package/core/super-input.js +115 -0
  149. package/core/super-input.js.map +1 -0
  150. package/{proto → core}/super-openable.d.ts +4 -8
  151. package/core/super-openable.d.ts.map +1 -0
  152. package/core/super-openable.js +38 -0
  153. package/core/super-openable.js.map +1 -0
  154. package/custom-elements.json +1 -0
  155. package/details.d.ts +2 -3
  156. package/details.d.ts.map +1 -1
  157. package/details.js +5 -4
  158. package/details.js.map +1 -1
  159. package/dev/alert.d.ts +8 -0
  160. package/dev/alert.d.ts.map +1 -0
  161. package/dev/alert.js +4 -0
  162. package/dev/alert.js.map +1 -0
  163. package/dev/avatar.d.ts +8 -0
  164. package/dev/avatar.d.ts.map +1 -0
  165. package/dev/avatar.js +4 -0
  166. package/dev/avatar.js.map +1 -0
  167. package/dev/breath.d.ts +9 -0
  168. package/dev/breath.d.ts.map +1 -0
  169. package/dev/breath.js +5 -0
  170. package/dev/breath.js.map +1 -0
  171. package/dev/button.d.ts +8 -0
  172. package/dev/button.d.ts.map +1 -0
  173. package/dev/button.js +4 -0
  174. package/dev/button.js.map +1 -0
  175. package/dev/card.d.ts +8 -0
  176. package/dev/card.d.ts.map +1 -0
  177. package/dev/card.js +4 -0
  178. package/dev/card.js.map +1 -0
  179. package/dev/carousel.d.ts +8 -0
  180. package/dev/carousel.d.ts.map +1 -0
  181. package/dev/carousel.js +4 -0
  182. package/dev/carousel.js.map +1 -0
  183. package/dev/components/alert.d.ts +50 -0
  184. package/dev/components/alert.d.ts.map +1 -0
  185. package/dev/components/alert.js +234 -0
  186. package/dev/components/alert.js.map +1 -0
  187. package/dev/components/avatar.d.ts +26 -0
  188. package/dev/components/avatar.d.ts.map +1 -0
  189. package/dev/components/avatar.js +91 -0
  190. package/dev/components/avatar.js.map +1 -0
  191. package/dev/components/breath.d.ts +34 -0
  192. package/dev/components/breath.d.ts.map +1 -0
  193. package/dev/components/breath.js +133 -0
  194. package/dev/components/breath.js.map +1 -0
  195. package/dev/components/button.d.ts +45 -0
  196. package/dev/components/button.d.ts.map +1 -0
  197. package/{web-components/button → dev/components}/button.js +76 -76
  198. package/dev/components/button.js.map +1 -0
  199. package/dev/components/card.d.ts +20 -0
  200. package/dev/components/card.d.ts.map +1 -0
  201. package/dev/components/card.js +89 -0
  202. package/dev/components/card.js.map +1 -0
  203. package/dev/components/carousel.d.ts +40 -0
  204. package/dev/components/carousel.d.ts.map +1 -0
  205. package/dev/components/carousel.js +155 -0
  206. package/dev/components/carousel.js.map +1 -0
  207. package/dev/components/details.d.ts +20 -0
  208. package/dev/components/details.d.ts.map +1 -0
  209. package/dev/components/details.js +115 -0
  210. package/dev/components/details.js.map +1 -0
  211. package/dev/components/dialog.d.ts +33 -0
  212. package/dev/components/dialog.d.ts.map +1 -0
  213. package/dev/components/dialog.js +154 -0
  214. package/dev/components/dialog.js.map +1 -0
  215. package/dev/components/divider.d.ts +17 -0
  216. package/dev/components/divider.d.ts.map +1 -0
  217. package/dev/components/divider.js +46 -0
  218. package/dev/components/divider.js.map +1 -0
  219. package/dev/components/dragbox.d.ts +40 -0
  220. package/dev/components/dragbox.d.ts.map +1 -0
  221. package/{web-components/wrapper → dev/components}/dragbox.js +27 -15
  222. package/dev/components/dragbox.js.map +1 -0
  223. package/dev/components/flex.d.ts +31 -0
  224. package/dev/components/flex.d.ts.map +1 -0
  225. package/dev/components/flex.js +52 -0
  226. package/dev/components/flex.js.map +1 -0
  227. package/dev/components/form.d.ts +24 -0
  228. package/dev/components/form.d.ts.map +1 -0
  229. package/{web-components/form → dev/components}/form.js +11 -11
  230. package/dev/components/form.js.map +1 -0
  231. package/dev/components/grid.d.ts +31 -0
  232. package/dev/components/grid.d.ts.map +1 -0
  233. package/dev/components/grid.js +53 -0
  234. package/dev/components/grid.js.map +1 -0
  235. package/dev/components/input.d.ts +20 -0
  236. package/dev/components/input.d.ts.map +1 -0
  237. package/dev/components/input.js +89 -0
  238. package/dev/components/input.js.map +1 -0
  239. package/dev/components/layout.d.ts +29 -0
  240. package/dev/components/layout.d.ts.map +1 -0
  241. package/dev/components/layout.js +69 -0
  242. package/dev/components/layout.js.map +1 -0
  243. package/dev/components/link.d.ts +20 -0
  244. package/dev/components/link.d.ts.map +1 -0
  245. package/dev/components/link.js +40 -0
  246. package/dev/components/link.js.map +1 -0
  247. package/dev/components/progress.d.ts +30 -0
  248. package/dev/components/progress.d.ts.map +1 -0
  249. package/{web-components/progress → dev/components}/progress.js +12 -11
  250. package/dev/components/progress.js.map +1 -0
  251. package/dev/components/range.d.ts +60 -0
  252. package/dev/components/range.d.ts.map +1 -0
  253. package/{web-components/input/range-input.js → dev/components/range.js} +82 -92
  254. package/dev/components/range.js.map +1 -0
  255. package/dev/components/rotate.d.ts +26 -0
  256. package/dev/components/rotate.d.ts.map +1 -0
  257. package/{web-components/wrapper → dev/components}/rotate.js +14 -20
  258. package/dev/components/rotate.js.map +1 -0
  259. package/dev/components/router.d.ts +121 -0
  260. package/dev/components/router.d.ts.map +1 -0
  261. package/dev/components/router.js +248 -0
  262. package/dev/components/router.js.map +1 -0
  263. package/dev/components/select.d.ts +50 -0
  264. package/dev/components/select.d.ts.map +1 -0
  265. package/dev/components/select.js +243 -0
  266. package/dev/components/select.js.map +1 -0
  267. package/dev/components/skeleton.d.ts +26 -0
  268. package/dev/components/skeleton.d.ts.map +1 -0
  269. package/dev/components/skeleton.js +119 -0
  270. package/dev/components/skeleton.js.map +1 -0
  271. package/dev/components/split.d.ts +32 -0
  272. package/dev/components/split.d.ts.map +1 -0
  273. package/dev/components/split.js +173 -0
  274. package/dev/components/split.js.map +1 -0
  275. package/dev/components/switch.d.ts +39 -0
  276. package/dev/components/switch.d.ts.map +1 -0
  277. package/{web-components/input/switch-input.js → dev/components/switch.js} +53 -59
  278. package/dev/components/switch.js.map +1 -0
  279. package/dev/components/text.d.ts +19 -0
  280. package/dev/components/text.d.ts.map +1 -0
  281. package/{web-components/text → dev/components}/text.js +22 -23
  282. package/dev/components/text.js.map +1 -0
  283. package/dev/components/time.d.ts +53 -0
  284. package/dev/components/time.d.ts.map +1 -0
  285. package/{web-components/text → dev/components}/time.js +12 -18
  286. package/dev/components/time.js.map +1 -0
  287. package/dev/components/tooltip.d.ts +38 -0
  288. package/dev/components/tooltip.d.ts.map +1 -0
  289. package/dev/components/tooltip.js +114 -0
  290. package/dev/components/tooltip.js.map +1 -0
  291. package/dev/components/typewriter.d.ts +55 -0
  292. package/dev/components/typewriter.d.ts.map +1 -0
  293. package/{web-components/text → dev/components}/typewriter.js +21 -19
  294. package/dev/components/typewriter.js.map +1 -0
  295. package/dev/core/global-style.d.ts +21 -0
  296. package/dev/core/global-style.d.ts.map +1 -0
  297. package/dev/core/global-style.js +77 -0
  298. package/dev/core/global-style.js.map +1 -0
  299. package/dev/core/super-anchor.d.ts +15 -0
  300. package/dev/core/super-anchor.d.ts.map +1 -0
  301. package/dev/core/super-anchor.js +58 -0
  302. package/dev/core/super-anchor.js.map +1 -0
  303. package/dev/core/super-input.d.ts +39 -0
  304. package/dev/core/super-input.d.ts.map +1 -0
  305. package/dev/core/super-input.js +181 -0
  306. package/dev/core/super-input.js.map +1 -0
  307. package/dev/core/super-openable.d.ts +19 -0
  308. package/dev/core/super-openable.d.ts.map +1 -0
  309. package/{proto → dev/core}/super-openable.js +6 -13
  310. package/dev/core/super-openable.js.map +1 -0
  311. package/dev/details.d.ts +8 -0
  312. package/dev/details.d.ts.map +1 -0
  313. package/dev/details.js +4 -0
  314. package/dev/details.js.map +1 -0
  315. package/dev/dialog.d.ts +8 -0
  316. package/dev/dialog.d.ts.map +1 -0
  317. package/dev/dialog.js +4 -0
  318. package/dev/dialog.js.map +1 -0
  319. package/dev/divider.d.ts +8 -0
  320. package/dev/divider.d.ts.map +1 -0
  321. package/dev/divider.js +4 -0
  322. package/dev/divider.js.map +1 -0
  323. package/dev/dragbox.d.ts +8 -0
  324. package/dev/dragbox.d.ts.map +1 -0
  325. package/dev/dragbox.js +4 -0
  326. package/dev/dragbox.js.map +1 -0
  327. package/dev/flex.d.ts +8 -0
  328. package/dev/flex.d.ts.map +1 -0
  329. package/dev/flex.js +4 -0
  330. package/dev/flex.js.map +1 -0
  331. package/dev/form.d.ts +8 -0
  332. package/dev/form.d.ts.map +1 -0
  333. package/dev/form.js +4 -0
  334. package/dev/form.js.map +1 -0
  335. package/dev/grid.d.ts +8 -0
  336. package/dev/grid.d.ts.map +1 -0
  337. package/dev/grid.js +4 -0
  338. package/dev/grid.js.map +1 -0
  339. package/dev/index.d.ts +29 -0
  340. package/dev/index.d.ts.map +1 -0
  341. package/dev/index.js +29 -0
  342. package/dev/index.js.map +1 -0
  343. package/dev/input.d.ts +9 -0
  344. package/dev/input.d.ts.map +1 -0
  345. package/dev/input.js +5 -0
  346. package/dev/input.js.map +1 -0
  347. package/dev/layout.d.ts +9 -0
  348. package/dev/layout.d.ts.map +1 -0
  349. package/dev/layout.js +5 -0
  350. package/dev/layout.js.map +1 -0
  351. package/dev/link.d.ts +9 -0
  352. package/dev/link.d.ts.map +1 -0
  353. package/dev/link.js +5 -0
  354. package/dev/link.js.map +1 -0
  355. package/dev/progress.d.ts +9 -0
  356. package/dev/progress.d.ts.map +1 -0
  357. package/dev/progress.js +5 -0
  358. package/dev/progress.js.map +1 -0
  359. package/dev/range.d.ts +9 -0
  360. package/dev/range.d.ts.map +1 -0
  361. package/dev/range.js +5 -0
  362. package/dev/range.js.map +1 -0
  363. package/dev/rotate.d.ts +9 -0
  364. package/dev/rotate.d.ts.map +1 -0
  365. package/dev/rotate.js +5 -0
  366. package/dev/rotate.js.map +1 -0
  367. package/dev/router.d.ts +9 -0
  368. package/dev/router.d.ts.map +1 -0
  369. package/dev/router.js +5 -0
  370. package/dev/router.js.map +1 -0
  371. package/dev/select.d.ts +9 -0
  372. package/dev/select.d.ts.map +1 -0
  373. package/dev/select.js +5 -0
  374. package/dev/select.js.map +1 -0
  375. package/dev/skeleton.d.ts +9 -0
  376. package/dev/skeleton.d.ts.map +1 -0
  377. package/dev/skeleton.js +5 -0
  378. package/dev/skeleton.js.map +1 -0
  379. package/dev/split.d.ts +9 -0
  380. package/dev/split.d.ts.map +1 -0
  381. package/dev/split.js +5 -0
  382. package/dev/split.js.map +1 -0
  383. package/dev/switch.d.ts +9 -0
  384. package/dev/switch.d.ts.map +1 -0
  385. package/dev/switch.js +5 -0
  386. package/dev/switch.js.map +1 -0
  387. package/dev/text.d.ts +9 -0
  388. package/dev/text.d.ts.map +1 -0
  389. package/dev/text.js +5 -0
  390. package/dev/text.js.map +1 -0
  391. package/dev/time.d.ts +9 -0
  392. package/dev/time.d.ts.map +1 -0
  393. package/dev/time.js +5 -0
  394. package/dev/time.js.map +1 -0
  395. package/dev/tooltip.d.ts +9 -0
  396. package/dev/tooltip.d.ts.map +1 -0
  397. package/dev/tooltip.js +5 -0
  398. package/dev/tooltip.js.map +1 -0
  399. package/dev/typewriter.d.ts +8 -0
  400. package/dev/typewriter.d.ts.map +1 -0
  401. package/dev/typewriter.js +4 -0
  402. package/dev/typewriter.js.map +1 -0
  403. package/dialog.d.ts +2 -3
  404. package/dialog.d.ts.map +1 -1
  405. package/dialog.js +5 -4
  406. package/dialog.js.map +1 -1
  407. package/divider.d.ts +2 -3
  408. package/divider.d.ts.map +1 -1
  409. package/divider.js +5 -4
  410. package/divider.js.map +1 -1
  411. package/dragbox.d.ts +2 -3
  412. package/dragbox.d.ts.map +1 -1
  413. package/dragbox.js +5 -4
  414. package/dragbox.js.map +1 -1
  415. package/flex.d.ts +8 -0
  416. package/flex.d.ts.map +1 -0
  417. package/flex.js +6 -0
  418. package/flex.js.map +1 -0
  419. package/form.d.ts +2 -3
  420. package/form.d.ts.map +1 -1
  421. package/form.js +5 -4
  422. package/form.js.map +1 -1
  423. package/grid.d.ts +8 -0
  424. package/grid.d.ts.map +1 -0
  425. package/grid.js +6 -0
  426. package/grid.js.map +1 -0
  427. package/index.d.ts +28 -32
  428. package/index.d.ts.map +1 -1
  429. package/index.js +57 -33
  430. package/index.js.map +1 -1
  431. package/input.d.ts +3 -3
  432. package/input.d.ts.map +1 -1
  433. package/input.js +5 -4
  434. package/input.js.map +1 -1
  435. package/layout.d.ts +3 -3
  436. package/layout.d.ts.map +1 -1
  437. package/layout.js +5 -4
  438. package/layout.js.map +1 -1
  439. package/link.d.ts +3 -3
  440. package/link.d.ts.map +1 -1
  441. package/link.js +5 -4
  442. package/link.js.map +1 -1
  443. package/package.json +42 -81
  444. package/progress.d.ts +3 -3
  445. package/progress.d.ts.map +1 -1
  446. package/progress.js +5 -4
  447. package/progress.js.map +1 -1
  448. package/range.d.ts +9 -0
  449. package/range.d.ts.map +1 -0
  450. package/range.js +6 -0
  451. package/range.js.map +1 -0
  452. package/rotate.d.ts +3 -3
  453. package/rotate.d.ts.map +1 -1
  454. package/rotate.js +5 -4
  455. package/rotate.js.map +1 -1
  456. package/router.d.ts +3 -3
  457. package/router.d.ts.map +1 -1
  458. package/router.js +5 -4
  459. package/router.js.map +1 -1
  460. package/select.d.ts +9 -0
  461. package/select.d.ts.map +1 -0
  462. package/select.js +6 -0
  463. package/select.js.map +1 -0
  464. package/skeleton.d.ts +3 -3
  465. package/skeleton.d.ts.map +1 -1
  466. package/skeleton.js +5 -4
  467. package/skeleton.js.map +1 -1
  468. package/split.d.ts +9 -0
  469. package/split.d.ts.map +1 -0
  470. package/split.js +6 -0
  471. package/split.js.map +1 -0
  472. package/switch.d.ts +9 -0
  473. package/switch.d.ts.map +1 -0
  474. package/switch.js +6 -0
  475. package/switch.js.map +1 -0
  476. package/text.d.ts +3 -3
  477. package/text.d.ts.map +1 -1
  478. package/text.js +5 -4
  479. package/text.js.map +1 -1
  480. package/time.d.ts +3 -3
  481. package/time.d.ts.map +1 -1
  482. package/time.js +5 -4
  483. package/time.js.map +1 -1
  484. package/tooltip.d.ts +3 -3
  485. package/tooltip.d.ts.map +1 -1
  486. package/tooltip.js +5 -4
  487. package/tooltip.js.map +1 -1
  488. package/typewriter.d.ts +2 -3
  489. package/typewriter.d.ts.map +1 -1
  490. package/typewriter.js +5 -4
  491. package/typewriter.js.map +1 -1
  492. package/vscode.css-custom-data.json +1 -0
  493. package/vscode.html-custom-data.json +1 -0
  494. package/web-types.json +1 -0
  495. package/_deps.d.ts +0 -4
  496. package/_deps.d.ts.map +0 -1
  497. package/_deps.js +0 -4
  498. package/_deps.js.map +0 -1
  499. package/avatar-group.d.ts +0 -9
  500. package/avatar-group.d.ts.map +0 -1
  501. package/avatar-group.js +0 -5
  502. package/avatar-group.js.map +0 -1
  503. package/components.json +0 -194
  504. package/conf.d.ts +0 -12
  505. package/conf.d.ts.map +0 -1
  506. package/conf.js +0 -24
  507. package/conf.js.map +0 -1
  508. package/decorators/godown.d.ts +0 -4
  509. package/decorators/godown.d.ts.map +0 -1
  510. package/decorators/godown.js +0 -9
  511. package/decorators/godown.js.map +0 -1
  512. package/decorators/part.d.ts +0 -7
  513. package/decorators/part.d.ts.map +0 -1
  514. package/decorators/part.js +0 -8
  515. package/decorators/part.js.map +0 -1
  516. package/decorators/styles.d.ts +0 -3
  517. package/decorators/styles.d.ts.map +0 -1
  518. package/decorators/styles.js +0 -8
  519. package/decorators/styles.js.map +0 -1
  520. package/flex-flow.d.ts +0 -9
  521. package/flex-flow.d.ts.map +0 -1
  522. package/flex-flow.js +0 -5
  523. package/flex-flow.js.map +0 -1
  524. package/grid-flow.d.ts +0 -9
  525. package/grid-flow.d.ts.map +0 -1
  526. package/grid-flow.js +0 -5
  527. package/grid-flow.js.map +0 -1
  528. package/label-input.d.ts +0 -9
  529. package/label-input.d.ts.map +0 -1
  530. package/label-input.js +0 -5
  531. package/label-input.js.map +0 -1
  532. package/lib/css.d.ts +0 -13
  533. package/lib/css.d.ts.map +0 -1
  534. package/lib/css.js +0 -29
  535. package/lib/css.js.map +0 -1
  536. package/lib/directives.d.ts +0 -25
  537. package/lib/directives.d.ts.map +0 -1
  538. package/lib/directives.js +0 -40
  539. package/lib/directives.js.map +0 -1
  540. package/lib/event-coll.d.ts +0 -13
  541. package/lib/event-coll.d.ts.map +0 -1
  542. package/lib/event-coll.js +0 -45
  543. package/lib/event-coll.js.map +0 -1
  544. package/lib/icons.d.ts +0 -25
  545. package/lib/icons.d.ts.map +0 -1
  546. package/lib/icons.js +0 -73
  547. package/lib/icons.js.map +0 -1
  548. package/lib/jsx.d.ts +0 -4
  549. package/lib/jsx.d.ts.map +0 -1
  550. package/lib/jsx.js +0 -52
  551. package/lib/jsx.js.map +0 -1
  552. package/lib/route-tree.d.ts +0 -28
  553. package/lib/route-tree.d.ts.map +0 -1
  554. package/lib/route-tree.js +0 -141
  555. package/lib/route-tree.js.map +0 -1
  556. package/lib/utils.d.ts +0 -10
  557. package/lib/utils.d.ts.map +0 -1
  558. package/lib/utils.js +0 -71
  559. package/lib/utils.js.map +0 -1
  560. package/overbreath.d.ts +0 -9
  561. package/overbreath.d.ts.map +0 -1
  562. package/overbreath.js +0 -5
  563. package/overbreath.js.map +0 -1
  564. package/proto/godown-config.d.ts +0 -41
  565. package/proto/godown-config.d.ts.map +0 -1
  566. package/proto/godown-config.js +0 -27
  567. package/proto/godown-config.js.map +0 -1
  568. package/proto/godown-element.d.ts +0 -125
  569. package/proto/godown-element.d.ts.map +0 -1
  570. package/proto/godown-element.js +0 -204
  571. package/proto/godown-element.js.map +0 -1
  572. package/proto/super-a.d.ts +0 -30
  573. package/proto/super-a.d.ts.map +0 -1
  574. package/proto/super-a.js +0 -141
  575. package/proto/super-a.js.map +0 -1
  576. package/proto/super-input.d.ts +0 -44
  577. package/proto/super-input.d.ts.map +0 -1
  578. package/proto/super-input.js +0 -119
  579. package/proto/super-input.js.map +0 -1
  580. package/proto/super-openable.d.ts.map +0 -1
  581. package/proto/super-openable.js.map +0 -1
  582. package/range-input.d.ts +0 -9
  583. package/range-input.d.ts.map +0 -1
  584. package/range-input.js +0 -5
  585. package/range-input.js.map +0 -1
  586. package/react/create.d.ts +0 -5
  587. package/react/create.d.ts.map +0 -1
  588. package/react/create.js +0 -16
  589. package/react/create.js.map +0 -1
  590. package/react/index.d.ts +0 -65
  591. package/react/index.d.ts.map +0 -1
  592. package/react/index.js +0 -132
  593. package/react/index.js.map +0 -1
  594. package/router-link.d.ts +0 -9
  595. package/router-link.d.ts.map +0 -1
  596. package/router-link.js +0 -5
  597. package/router-link.js.map +0 -1
  598. package/search-input.d.ts +0 -9
  599. package/search-input.d.ts.map +0 -1
  600. package/search-input.js +0 -5
  601. package/search-input.js.map +0 -1
  602. package/select-input.d.ts +0 -9
  603. package/select-input.d.ts.map +0 -1
  604. package/select-input.js +0 -5
  605. package/select-input.js.map +0 -1
  606. package/split-input.d.ts +0 -9
  607. package/split-input.d.ts.map +0 -1
  608. package/split-input.js +0 -5
  609. package/split-input.js.map +0 -1
  610. package/styles/colors/presets.d.ts +0 -13
  611. package/styles/colors/presets.d.ts.map +0 -1
  612. package/styles/colors/presets.js +0 -6
  613. package/styles/colors/presets.js.map +0 -1
  614. package/styles/colors/presetsRGB.d.ts +0 -16
  615. package/styles/colors/presetsRGB.d.ts.map +0 -1
  616. package/styles/colors/presetsRGB.js +0 -134
  617. package/styles/colors/presetsRGB.js.map +0 -1
  618. package/styles/global.d.ts +0 -18
  619. package/styles/global.d.ts.map +0 -1
  620. package/styles/global.js +0 -78
  621. package/styles/global.js.map +0 -1
  622. package/styles/inputStyle.d.ts +0 -3
  623. package/styles/inputStyle.d.ts.map +0 -1
  624. package/styles/inputStyle.js +0 -59
  625. package/styles/inputStyle.js.map +0 -1
  626. package/switch-input.d.ts +0 -9
  627. package/switch-input.d.ts.map +0 -1
  628. package/switch-input.js +0 -5
  629. package/switch-input.js.map +0 -1
  630. package/web-components/alert/alert.d.ts +0 -36
  631. package/web-components/alert/alert.d.ts.map +0 -1
  632. package/web-components/alert/alert.js +0 -161
  633. package/web-components/alert/alert.js.map +0 -1
  634. package/web-components/avatar/avatar-group.d.ts +0 -21
  635. package/web-components/avatar/avatar-group.d.ts.map +0 -1
  636. package/web-components/avatar/avatar-group.js +0 -86
  637. package/web-components/avatar/avatar-group.js.map +0 -1
  638. package/web-components/avatar/avatar.d.ts +0 -28
  639. package/web-components/avatar/avatar.d.ts.map +0 -1
  640. package/web-components/avatar/avatar.js +0 -120
  641. package/web-components/avatar/avatar.js.map +0 -1
  642. package/web-components/button/button.d.ts.map +0 -1
  643. package/web-components/button/button.js.map +0 -1
  644. package/web-components/card/card.d.ts +0 -9
  645. package/web-components/card/card.d.ts.map +0 -1
  646. package/web-components/card/card.js +0 -75
  647. package/web-components/card/card.js.map +0 -1
  648. package/web-components/carousel/carousel.d.ts +0 -29
  649. package/web-components/carousel/carousel.d.ts.map +0 -1
  650. package/web-components/carousel/carousel.js +0 -185
  651. package/web-components/carousel/carousel.js.map +0 -1
  652. package/web-components/details/details.d.ts.map +0 -1
  653. package/web-components/details/details.js +0 -124
  654. package/web-components/details/details.js.map +0 -1
  655. package/web-components/dialog/dialog.d.ts +0 -31
  656. package/web-components/dialog/dialog.d.ts.map +0 -1
  657. package/web-components/dialog/dialog.js +0 -143
  658. package/web-components/dialog/dialog.js.map +0 -1
  659. package/web-components/divider/divider.d.ts +0 -13
  660. package/web-components/divider/divider.d.ts.map +0 -1
  661. package/web-components/divider/divider.js +0 -95
  662. package/web-components/divider/divider.js.map +0 -1
  663. package/web-components/form/form.d.ts.map +0 -1
  664. package/web-components/form/form.js.map +0 -1
  665. package/web-components/input/input.d.ts +0 -37
  666. package/web-components/input/input.d.ts.map +0 -1
  667. package/web-components/input/input.js +0 -152
  668. package/web-components/input/input.js.map +0 -1
  669. package/web-components/input/label-input.d.ts +0 -15
  670. package/web-components/input/label-input.d.ts.map +0 -1
  671. package/web-components/input/label-input.js +0 -96
  672. package/web-components/input/label-input.js.map +0 -1
  673. package/web-components/input/range-input.d.ts +0 -53
  674. package/web-components/input/range-input.d.ts.map +0 -1
  675. package/web-components/input/range-input.js.map +0 -1
  676. package/web-components/input/search-input.d.ts +0 -42
  677. package/web-components/input/search-input.d.ts.map +0 -1
  678. package/web-components/input/search-input.js +0 -214
  679. package/web-components/input/search-input.js.map +0 -1
  680. package/web-components/input/select-input.d.ts +0 -36
  681. package/web-components/input/select-input.d.ts.map +0 -1
  682. package/web-components/input/select-input.js +0 -210
  683. package/web-components/input/select-input.js.map +0 -1
  684. package/web-components/input/split-input.d.ts +0 -29
  685. package/web-components/input/split-input.d.ts.map +0 -1
  686. package/web-components/input/split-input.js +0 -184
  687. package/web-components/input/split-input.js.map +0 -1
  688. package/web-components/input/switch-input.d.ts.map +0 -1
  689. package/web-components/input/switch-input.js.map +0 -1
  690. package/web-components/layout/flex-flow.d.ts +0 -17
  691. package/web-components/layout/flex-flow.d.ts.map +0 -1
  692. package/web-components/layout/flex-flow.js +0 -73
  693. package/web-components/layout/flex-flow.js.map +0 -1
  694. package/web-components/layout/grid-flow.d.ts +0 -14
  695. package/web-components/layout/grid-flow.d.ts.map +0 -1
  696. package/web-components/layout/grid-flow.js +0 -56
  697. package/web-components/layout/grid-flow.js.map +0 -1
  698. package/web-components/layout/layout.d.ts +0 -18
  699. package/web-components/layout/layout.d.ts.map +0 -1
  700. package/web-components/layout/layout.js +0 -76
  701. package/web-components/layout/layout.js.map +0 -1
  702. package/web-components/link/link.d.ts +0 -10
  703. package/web-components/link/link.d.ts.map +0 -1
  704. package/web-components/link/link.js +0 -17
  705. package/web-components/link/link.js.map +0 -1
  706. package/web-components/link/router-link.d.ts +0 -19
  707. package/web-components/link/router-link.d.ts.map +0 -1
  708. package/web-components/link/router-link.js +0 -60
  709. package/web-components/link/router-link.js.map +0 -1
  710. package/web-components/progress/progress.d.ts.map +0 -1
  711. package/web-components/progress/progress.js.map +0 -1
  712. package/web-components/router/router.d.ts +0 -86
  713. package/web-components/router/router.d.ts.map +0 -1
  714. package/web-components/router/router.js +0 -246
  715. package/web-components/router/router.js.map +0 -1
  716. package/web-components/skeleton/skeleton.d.ts.map +0 -1
  717. package/web-components/skeleton/skeleton.js +0 -130
  718. package/web-components/skeleton/skeleton.js.map +0 -1
  719. package/web-components/text/overbreath.d.ts +0 -22
  720. package/web-components/text/overbreath.d.ts.map +0 -1
  721. package/web-components/text/overbreath.js +0 -132
  722. package/web-components/text/overbreath.js.map +0 -1
  723. package/web-components/text/text.d.ts.map +0 -1
  724. package/web-components/text/text.js.map +0 -1
  725. package/web-components/text/time.d.ts.map +0 -1
  726. package/web-components/text/time.js.map +0 -1
  727. package/web-components/text/typewriter.d.ts.map +0 -1
  728. package/web-components/text/typewriter.js.map +0 -1
  729. package/web-components/tooltip/tooltip.d.ts +0 -30
  730. package/web-components/tooltip/tooltip.d.ts.map +0 -1
  731. package/web-components/tooltip/tooltip.js +0 -123
  732. package/web-components/tooltip/tooltip.js.map +0 -1
  733. package/web-components/wrapper/dragbox.d.ts.map +0 -1
  734. package/web-components/wrapper/dragbox.js.map +0 -1
  735. package/web-components/wrapper/rotate.d.ts.map +0 -1
  736. package/web-components/wrapper/rotate.js.map +0 -1
@@ -0,0 +1,248 @@
1
+ var Router_1;
2
+ import { __decorate } from "tslib";
3
+ import { godown } from "@godown/element/decorators/godown.js";
4
+ import { styles } from "@godown/element/decorators/styles.js";
5
+ import { htmlSlot } from "@godown/element/directives/html-slot.js";
6
+ import { RouteTree } from "@godown/element/tools/route-tree.js";
7
+ import { css } from "lit";
8
+ import { property, state } from "lit/decorators.js";
9
+ import { GlobalStyle } from "../core/global-style.js";
10
+ const protoName = "router";
11
+ /**
12
+ * {@linkcode Router} has basic routing control.
13
+ *
14
+ * To switch routes, use `router-link component`.
15
+ *
16
+ * It has two methods to collect routes.
17
+ *
18
+ * 1. From field `routes`, an array, each elements require "path" and "component".
19
+ * 2. From child elements, which have the slot attribute for matching routes.
20
+ *
21
+ * If only the method 1 is used, set `type` to `"field"`.
22
+ *
23
+ * If only the method 2 is used, set `type` to `"slotted"`.
24
+ *
25
+ * `type` defaults to `"united"`, which will try method 1, then method 2.
26
+ *
27
+ * If no routes are matched, the default value (no named slot) will be rendered.
28
+ *
29
+ * @category navigation
30
+ */
31
+ let Router = Router_1 = class Router extends GlobalStyle {
32
+ constructor() {
33
+ super(...arguments);
34
+ this.__fieldRouteTree = new RouteTree();
35
+ this.__slottedRouteTree = new RouteTree();
36
+ this.__cacheRecord = new Map();
37
+ /**
38
+ * Render result.
39
+ */
40
+ this.component = null;
41
+ /**
42
+ * Dynamic parameters record.
43
+ */
44
+ this.params = {};
45
+ /**
46
+ * Current pathname (equals to location.pathname).
47
+ */
48
+ this.pathname = "";
49
+ /**
50
+ * Path prefix.
51
+ */
52
+ this.baseURL = "";
53
+ /**
54
+ * Rendered content when there is no match.
55
+ */
56
+ this.default = htmlSlot();
57
+ /**
58
+ * The type of routing sources.
59
+ *
60
+ * If field, it won't collect the slot attribute of the child elements.
61
+ *
62
+ * This property should not be changed after the rendering is complete.
63
+ */
64
+ this.type = "united";
65
+ /**
66
+ * Cache accessed records.
67
+ *
68
+ * Emptied at each re-collection.
69
+ */
70
+ this.cache = false;
71
+ /**
72
+ * @param params value of useRouter()
73
+ * @param first whether this path is loaded for the first time.
74
+ */
75
+ this.routeChangeCallback = null;
76
+ }
77
+ set routes(value) {
78
+ this.__routes = value;
79
+ this.collectFieldRoutes(value);
80
+ }
81
+ get routes() {
82
+ return this.__routes;
83
+ }
84
+ clear() {
85
+ this.__cacheRecord.clear();
86
+ }
87
+ render() {
88
+ this.params = {};
89
+ if (this.cache) {
90
+ const cached = this.__cacheRecord.get(this.pathname);
91
+ if (cached) {
92
+ Object.assign(this, cached);
93
+ return this.component;
94
+ }
95
+ }
96
+ switch (this.type) {
97
+ case "field":
98
+ this.component = this.fieldComponent();
99
+ break;
100
+ case "slotted":
101
+ this.component = this.slottedComponent();
102
+ break;
103
+ default:
104
+ this.component = this.fieldComponent() ?? this.slottedComponent();
105
+ }
106
+ return this.component ?? this.default ?? null;
107
+ }
108
+ connectedCallback() {
109
+ super.connectedCallback();
110
+ Router_1.routerInstances.add(this);
111
+ this.pathname = window.location.pathname;
112
+ if (this.type !== "field") {
113
+ const mutationObserver = new MutationObserver(this.collectSlottedRoutes);
114
+ mutationObserver.observe(this, {
115
+ attributeFilter: ["slot"],
116
+ attributes: true,
117
+ subtree: true,
118
+ });
119
+ this.collectSlottedRoutes();
120
+ }
121
+ }
122
+ disconnectedCallback() {
123
+ super.disconnectedCallback();
124
+ Router_1.routerInstances.delete(this);
125
+ }
126
+ useRouter() {
127
+ return {
128
+ pathname: this.pathname,
129
+ params: this.params,
130
+ path: this.path,
131
+ component: this.component,
132
+ };
133
+ }
134
+ updated(changedProperties) {
135
+ const shouldDispatch = changedProperties.has("pathname") || changedProperties.has("path");
136
+ if (shouldDispatch) {
137
+ const ur = this.useRouter();
138
+ const noRecord = !this.__cacheRecord.has(this.pathname);
139
+ if (noRecord) {
140
+ this.__cacheRecord.set(this.pathname, ur);
141
+ }
142
+ this.routeChangeCallback?.(ur, noRecord);
143
+ this.dispatchEvent(new CustomEvent("change", { detail: ur }));
144
+ }
145
+ }
146
+ /**
147
+ * Find components from {@linkcode __fieldRouteTree} matching query.
148
+ * @param query Query string.
149
+ * @returns Components or null.
150
+ */
151
+ fieldComponent(query) {
152
+ query ||= this.useWhich(this.pathname);
153
+ this.path = query;
154
+ if (!query) {
155
+ return null;
156
+ }
157
+ this.params = this.parseParams(this.path, this.pathname);
158
+ const route = this.routes.find((r) => r.path === query);
159
+ if (!route) {
160
+ return null;
161
+ }
162
+ return route.component;
163
+ }
164
+ /**
165
+ * Find components from {@linkcode __slottedRouteTree} matching query.
166
+ * @param query Query string.
167
+ * @returns Named slot element template result or null.
168
+ */
169
+ slottedComponent(usedRouteTemplate) {
170
+ const slottedPaths = this._slottedNames;
171
+ usedRouteTemplate ||= this.__slottedRouteTree.useWhich(this.pathname);
172
+ this.path = usedRouteTemplate;
173
+ if (!usedRouteTemplate) {
174
+ return null;
175
+ }
176
+ this.path = slottedPaths.find((s) => s === usedRouteTemplate);
177
+ if (!this.path) {
178
+ return null;
179
+ }
180
+ this.params = this.parseParams(usedRouteTemplate, this.pathname);
181
+ return htmlSlot(this.path);
182
+ }
183
+ /**
184
+ * Reset the route tree, clear cache, collect routes from child elements.
185
+ */
186
+ collectSlottedRoutes() {
187
+ this.__slottedRouteTree = new RouteTree();
188
+ this.clear();
189
+ this._slottedNames.forEach(slotName => {
190
+ this.__slottedRouteTree.insert(slotName);
191
+ });
192
+ }
193
+ /**
194
+ * Reset the route tree, clear cache, collect routes from value.
195
+ */
196
+ collectFieldRoutes(value) {
197
+ this.__fieldRouteTree = new RouteTree();
198
+ this.clear();
199
+ value.forEach(({ path }) => {
200
+ this.__fieldRouteTree.insert(path);
201
+ });
202
+ }
203
+ useWhich(path) {
204
+ return this.__fieldRouteTree.useWhich(this.baseURL + path);
205
+ }
206
+ parseParams(routeTemplate, path) {
207
+ return this.__fieldRouteTree.parseParams(path, routeTemplate);
208
+ }
209
+ static updateAll() {
210
+ this.routerInstances.forEach((i) => {
211
+ i.pathname = window.location.pathname;
212
+ });
213
+ }
214
+ };
215
+ Router.routerInstances = new Set();
216
+ __decorate([
217
+ state()
218
+ ], Router.prototype, "component", void 0);
219
+ __decorate([
220
+ state()
221
+ ], Router.prototype, "params", void 0);
222
+ __decorate([
223
+ state()
224
+ ], Router.prototype, "path", void 0);
225
+ __decorate([
226
+ property()
227
+ ], Router.prototype, "pathname", void 0);
228
+ __decorate([
229
+ property()
230
+ ], Router.prototype, "baseURL", void 0);
231
+ __decorate([
232
+ state()
233
+ ], Router.prototype, "default", void 0);
234
+ __decorate([
235
+ property()
236
+ ], Router.prototype, "type", void 0);
237
+ __decorate([
238
+ property({ type: Boolean })
239
+ ], Router.prototype, "cache", void 0);
240
+ __decorate([
241
+ state()
242
+ ], Router.prototype, "routes", null);
243
+ Router = Router_1 = __decorate([
244
+ godown(protoName),
245
+ styles(css `:host{display:contents;}`)
246
+ ], Router);
247
+ export default Router;
248
+ //# sourceMappingURL=router.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"router.js","sourceRoot":"","sources":["../../src/components/router.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,50 @@
1
+ import { HandlerEvent } from "@godown/element";
2
+ import Input from "./input.js";
3
+ /**
4
+ * {@linkcode Select} is similar to <select>.
5
+ *
6
+ * Elements with the value attribute/property can be used as options.
7
+ *
8
+ * The checked attribute will be added to the selected element.
9
+ *
10
+ * Multi-selected state looks the same as single-selected.
11
+ *
12
+ * Input will filter the element.
13
+ *
14
+ * @slot - Options.
15
+ * @category input
16
+ */
17
+ declare class Select extends Input {
18
+ _cache: WeakMap<HTMLElement, boolean>;
19
+ value: string | string[];
20
+ /**
21
+ * Open content.
22
+ */
23
+ open: boolean;
24
+ /**
25
+ * Selected texts.
26
+ */
27
+ text: string;
28
+ _content: HTMLElement;
29
+ visible: boolean;
30
+ direction: "top" | "bottom" | undefined;
31
+ multiple: boolean;
32
+ protected autoDirection: "top" | "bottom";
33
+ protected lastChecked: HTMLElement;
34
+ protected defaultText: string;
35
+ protected defaultChecked: HTMLElement[];
36
+ private _store;
37
+ protected render(): import("lit").TemplateResult<1>;
38
+ protected _handleFocus(): void;
39
+ protected _connectedInit(): void;
40
+ reset(): void;
41
+ select(value: string, text?: string): 0 | 1;
42
+ filter(query?: string): void;
43
+ filterCallback(element: HTMLElement, match: boolean, query: string): void;
44
+ protected _handleInput(e: HandlerEvent<HTMLInputElement>): void;
45
+ focus(options?: FocusOptions): void;
46
+ blur(): void;
47
+ optionValue(option: HTMLElement): string;
48
+ }
49
+ export default Select;
50
+ //# sourceMappingURL=select.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"select.d.ts","sourceRoot":"","sources":["../../src/components/select.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAU/C,OAAO,KAAK,MAAM,YAAY,CAAC;AAyB/B;;;;;;;;;;;;;GAaG;AACH,cAsBM,MAAO,SAAQ,KAAK;IACxB,MAAM,gCAAuC;IAE7C,KAAK,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IAEzB;;OAEG;IAEH,IAAI,UAAS;IAEb;;OAEG;IAEH,IAAI,EAAE,MAAM,CAAC;IAGb,QAAQ,EAAE,WAAW,CAAC;IAGtB,OAAO,EAAE,OAAO,CAAC;IAGjB,SAAS,EAAE,KAAK,GAAG,QAAQ,GAAG,SAAS,CAAC;IAGxC,QAAQ,EAAE,OAAO,CAAC;IAElB,SAAS,CAAC,aAAa,EAAE,KAAK,GAAG,QAAQ,CAAC;IAC1C,SAAS,CAAC,WAAW,EAAE,WAAW,CAAC;IACnC,SAAS,CAAC,WAAW,EAAE,MAAM,CAAC;IAC9B,SAAS,CAAC,cAAc,EAAE,WAAW,EAAE,CAAC;IACxC,OAAO,CAAC,MAAM,CAA0C;IAExD,SAAS,CAAC,MAAM;IA4BhB,SAAS,CAAC,YAAY;IAmCtB,SAAS,CAAC,cAAc;IAmBxB,KAAK,IAAI,IAAI;IAOb,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM;IA4BnC,MAAM,CAAC,KAAK,CAAC,EAAE,MAAM;IAcrB,cAAc,CAAC,OAAO,EAAE,WAAW,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM;IAIlE,SAAS,CAAC,YAAY,CAAC,CAAC,EAAE,YAAY,CAAC,gBAAgB,CAAC;IAUxD,KAAK,CAAC,OAAO,CAAC,EAAE,YAAY;IAK5B,IAAI;IAKJ,WAAW,CAAC,MAAM,EAAE,WAAW,GAAG,MAAM;CAGzC;AAED,eAAe,MAAM,CAAC"}
@@ -0,0 +1,243 @@
1
+ import { __decorate } from "tslib";
2
+ import { godown } from "@godown/element/decorators/godown.js";
3
+ import { part } from "@godown/element/decorators/part.js";
4
+ import { styles } from "@godown/element/decorators/styles.js";
5
+ import { htmlSlot } from "@godown/element/directives/index.js";
6
+ import svgCaretDown from "@godown/f7-icon/icons/chevron-down.js";
7
+ import { css, html, nothing } from "lit";
8
+ import { property } from "lit/decorators.js";
9
+ import { ifDefined } from "lit/directives/if-defined.js";
10
+ import Input from "./input.js";
11
+ function contain(a, b) {
12
+ return a && b && a.toLowerCase().includes(b.toLowerCase());
13
+ }
14
+ function betweenAt(i, s, c) {
15
+ const start = s.slice(0, i).lastIndexOf(c) + 1 || 0;
16
+ const end = s.indexOf(c, i) || s.length;
17
+ return s.slice(start, end);
18
+ }
19
+ function updateChecked(element, operation) {
20
+ if (element) {
21
+ const name = "checked";
22
+ if (operation) {
23
+ element.setAttribute(name, "");
24
+ }
25
+ else {
26
+ element.removeAttribute(name);
27
+ }
28
+ }
29
+ }
30
+ const protoName = "select";
31
+ /**
32
+ * {@linkcode Select} is similar to <select>.
33
+ *
34
+ * Elements with the value attribute/property can be used as options.
35
+ *
36
+ * The checked attribute will be added to the selected element.
37
+ *
38
+ * Multi-selected state looks the same as single-selected.
39
+ *
40
+ * Input will filter the element.
41
+ *
42
+ * @slot - Options.
43
+ * @category input
44
+ */
45
+ let Select = class Select extends Input {
46
+ constructor() {
47
+ super(...arguments);
48
+ this._cache = new WeakMap();
49
+ /**
50
+ * Open content.
51
+ */
52
+ this.open = false;
53
+ this._store = [];
54
+ }
55
+ render() {
56
+ return html `<div part="root" class="input-field">
57
+ ${[
58
+ this._renderPrefix(),
59
+ html `<input
60
+ part="input"
61
+ dir="${ifDefined(this.dir)}"
62
+ id="${this.makeId}"
63
+ .value="${this.text}"
64
+ type="${this.type}"
65
+ placeholder="${this.placeholder || nothing}"
66
+ ?autofocus="${this.autofocus}"
67
+ autocapitalize="${this.autocapitalize || nothing}"
68
+ autocomplete="${this.autocomplete || nothing}"
69
+ ?disabled="${this.disabled}"
70
+ @focus="${this._handleFocus}"
71
+ @input="${this._handleInput}"
72
+ >`,
73
+ html `<label for="${this.makeId}" part="suffix">
74
+ <i part="space"></i><i part="icon">${svgCaretDown()}</i><i part="space"></i>
75
+ </label>`,
76
+ html `<div part="content" direction="${this.direction || this.autoDirection}" style="visibility:${this.visible ? "visible" : "hidden"}">${htmlSlot()}</div>`,
77
+ ]}
78
+ </div>`;
79
+ }
80
+ _handleFocus() {
81
+ if (!this.direction) {
82
+ const { top, bottom } = this.getBoundingClientRect();
83
+ if (window.innerHeight - bottom < this._content.clientHeight && top > this._content.clientHeight) {
84
+ this.autoDirection = "top";
85
+ }
86
+ else {
87
+ this.autoDirection = "bottom";
88
+ }
89
+ }
90
+ if (!this.visible) {
91
+ const event = this.events.add(document, "click", (e) => {
92
+ const { target } = e;
93
+ if (!this.contains(target)) {
94
+ this.events.remove(document, "click", event);
95
+ this.visible = false;
96
+ }
97
+ else if (target !== this) {
98
+ const value = this.optionValue(target);
99
+ if (value) {
100
+ const operation = this.select(value, target.textContent);
101
+ if (!this.multiple) {
102
+ updateChecked(this.lastChecked, 0);
103
+ }
104
+ updateChecked(target, operation);
105
+ this.lastChecked = target;
106
+ }
107
+ this.visible = this.multiple;
108
+ if (!this.visible) {
109
+ this.events.remove(document, "click", event);
110
+ }
111
+ }
112
+ });
113
+ }
114
+ this.visible = true;
115
+ }
116
+ _connectedInit() {
117
+ if (!this.value) {
118
+ const checked = [...this.querySelectorAll("[checked]")];
119
+ const list = this.multiple
120
+ ? checked
121
+ : checked.length
122
+ ? [this.lastChecked = checked[0]]
123
+ : [];
124
+ list.forEach((element) => {
125
+ const operation = this.select(this.optionValue(element), element.textContent);
126
+ updateChecked(element, operation);
127
+ });
128
+ this.default = this.value;
129
+ this.defaultText = this.text;
130
+ this.defaultChecked = checked;
131
+ }
132
+ }
133
+ reset() {
134
+ this.value = this.default;
135
+ this.text = this.defaultText;
136
+ this.querySelectorAll("[checked]").forEach(element => updateChecked(element, 0));
137
+ this.defaultChecked.forEach(element => updateChecked(element, 1));
138
+ }
139
+ select(value, text) {
140
+ text ||= value;
141
+ let operation = 0;
142
+ if (this.multiple) {
143
+ const i = this._store.findIndex(s => s.value === value);
144
+ if (i > -1) {
145
+ this._store.splice(i, 1);
146
+ }
147
+ else {
148
+ this._store.push({ value, text });
149
+ operation = 1;
150
+ }
151
+ this.value = this._store.map(s => s.value);
152
+ this.text = this._store.map(s => s.text).join(", ");
153
+ }
154
+ else {
155
+ if (this.value === value) {
156
+ this.value = "";
157
+ this.text = "";
158
+ }
159
+ else {
160
+ this.value = value;
161
+ this.text = text;
162
+ operation = 1;
163
+ }
164
+ }
165
+ this.dispatchEvent(new CustomEvent("change", { detail: this.namevalue() }));
166
+ this.filter();
167
+ return operation;
168
+ }
169
+ filter(query) {
170
+ query = query?.trim();
171
+ [...this.children].forEach((element) => {
172
+ this.filterCallback(element, !query
173
+ || contain(this.optionValue(element), query)
174
+ || contain(element.textContent, query), query);
175
+ });
176
+ }
177
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
178
+ filterCallback(element, match, query) {
179
+ element.style.display = match ? "" : "none";
180
+ }
181
+ _handleInput(e) {
182
+ e.stopPropagation();
183
+ if (this.compositing) {
184
+ return;
185
+ }
186
+ const s = this._input.value;
187
+ this.filter(this.multiple ? betweenAt(this._input.selectionStart, s, ",") : s);
188
+ this.dispatchEvent(new CustomEvent("input", { detail: this.namevalue() }));
189
+ }
190
+ focus(options) {
191
+ this._input.focus(options);
192
+ this.visible = true;
193
+ }
194
+ blur() {
195
+ this._input.blur();
196
+ this.visible = false;
197
+ }
198
+ optionValue(option) {
199
+ return option.value || option.getAttribute("value") || "";
200
+ }
201
+ };
202
+ __decorate([
203
+ property({ type: Boolean, reflect: true })
204
+ ], Select.prototype, "open", void 0);
205
+ __decorate([
206
+ property()
207
+ ], Select.prototype, "text", void 0);
208
+ __decorate([
209
+ part("content")
210
+ ], Select.prototype, "_content", void 0);
211
+ __decorate([
212
+ property({ type: Boolean })
213
+ ], Select.prototype, "visible", void 0);
214
+ __decorate([
215
+ property()
216
+ ], Select.prototype, "direction", void 0);
217
+ __decorate([
218
+ property({ type: Boolean })
219
+ ], Select.prototype, "multiple", void 0);
220
+ Select = __decorate([
221
+ godown(protoName),
222
+ styles(css `
223
+ [part="input"] {
224
+ text-overflow: ellipsis;
225
+ }
226
+
227
+ [part="content"] {
228
+ position: absolute;
229
+ width: 100%;
230
+ visibility: hidden;
231
+ }
232
+
233
+ [direction="bottom"] {
234
+ top: 100%;
235
+ }
236
+
237
+ [direction="top"] {
238
+ bottom: 100%;
239
+ }
240
+ `)
241
+ ], Select);
242
+ export default Select;
243
+ //# sourceMappingURL=select.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"select.js","sourceRoot":"","sources":["../../src/components/select.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,MAAM,EAAE,MAAM,sCAAsC,CAAC;AAC9D,OAAO,EAAE,IAAI,EAAE,MAAM,oCAAoC,CAAC;AAC1D,OAAO,EAAE,MAAM,EAAE,MAAM,sCAAsC,CAAC;AAC9D,OAAO,EAAE,QAAQ,EAAE,MAAM,qCAAqC,CAAC;AAC/D,OAAO,YAAY,MAAM,uCAAuC,CAAC;AACjE,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,KAAK,CAAC;AACzC,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAC;AAEzD,OAAO,KAAK,MAAM,YAAY,CAAC;AAE/B,SAAS,OAAO,CAAC,CAAS,EAAE,CAAS;IACnC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;AAC7D,CAAC;AAED,SAAS,SAAS,CAAC,CAAS,EAAE,CAAS,EAAE,CAAS;IAChD,MAAM,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACpD,MAAM,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC;IACxC,OAAO,CAAC,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;AAC7B,CAAC;AAED,SAAS,aAAa,CAAC,OAA2B,EAAE,SAAgB;IAClE,IAAI,OAAO,EAAE,CAAC;QACZ,MAAM,IAAI,GAAG,SAAS,CAAC;QACvB,IAAI,SAAS,EAAE,CAAC;YACd,OAAO,CAAC,YAAY,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QACjC,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QAChC,CAAC;IACH,CAAC;AACH,CAAC;AAED,MAAM,SAAS,GAAG,QAAQ,CAAC;AAE3B;;;;;;;;;;;;;GAaG;AAuBH,IAAM,MAAM,GAAZ,MAAM,MAAO,SAAQ,KAAK;IAA1B;;QACE,WAAM,GAAG,IAAI,OAAO,EAAwB,CAAC;QAI7C;;WAEG;QAEH,SAAI,GAAG,KAAK,CAAC;QAwBL,WAAM,GAAuC,EAAE,CAAC;IAgK1D,CAAC;IA9JW,MAAM;QACd,OAAO,IAAI,CAAA;MACT;YACA,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAA;;eAEK,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC;cACpB,IAAI,CAAC,MAAM;kBACP,IAAI,CAAC,IAAI;gBACX,IAAI,CAAC,IAAI;uBACF,IAAI,CAAC,WAAW,IAAI,OAAO;sBAC5B,IAAI,CAAC,SAAS;0BACV,IAAI,CAAC,cAAc,IAAI,OAAO;wBAChC,IAAI,CAAC,YAAY,IAAI,OAAO;qBAC/B,IAAI,CAAC,QAAQ;kBAChB,IAAI,CAAC,YAAY;kBACjB,IAAI,CAAC,YAAY;QAC3B;YACF,IAAI,CAAA,eAAe,IAAI,CAAC,MAAM;6CACS,YAAY,EAAE;eAC5C;YACT,IAAI,CAAA,kCAAkC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,aAAa,uBACxE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAC7B,KAAK,QAAQ,EAAE,QAAQ;SACxB;WACM,CAAC;IACV,CAAC;IAES,YAAY;QACpB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACpB,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAC;YACrD,IAAI,MAAM,CAAC,WAAW,GAAG,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,YAAY,IAAI,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE,CAAC;gBACjG,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAC7B,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC;YAChC,CAAC;QACH,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAe,EAAE,EAAE;gBACnE,MAAM,EAAE,MAAM,EAAE,GAAG,CAAC,CAAC;gBACrB,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAc,CAAC,EAAE,CAAC;oBACnC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;oBAC7C,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;gBACvB,CAAC;qBAAM,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;oBAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;oBACvC,IAAI,KAAK,EAAE,CAAC;wBACV,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC;wBACzD,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;4BACnB,aAAa,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;wBACrC,CAAC;wBACD,aAAa,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;wBACjC,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;oBAC5B,CAAC;oBACD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC;oBAC7B,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;wBAClB,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;oBAC/C,CAAC;gBACH,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC;QACD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;IACtB,CAAC;IAES,cAAc;QACtB,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YAChB,MAAM,OAAO,GAAG,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAc,WAAW,CAAC,CAAC,CAAC;YACrE,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ;gBACxB,CAAC,CAAC,OAAO;gBACT,CAAC,CAAC,OAAO,CAAC,MAAM;oBAChB,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;oBACjC,CAAC,CAAC,EAAE,CAAC;YACP,IAAI,CAAC,OAAO,CAAC,CAAC,OAAoB,EAAE,EAAE;gBACpC,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC;gBAC9E,aAAa,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;YACpC,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC;YAC1B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC;YAC7B,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC;QAChC,CAAC;IACH,CAAC;IAED,KAAK;QACH,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC;QAC1B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC;QAC7B,IAAI,CAAC,gBAAgB,CAAc,WAAW,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC;QAC9F,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC;IACpE,CAAC;IAED,MAAM,CAAC,KAAa,EAAE,IAAa;QACjC,IAAI,KAAK,KAAK,CAAC;QACf,IAAI,SAAS,GAAU,CAAC,CAAC;QACzB,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,MAAM,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC;YACxD,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACX,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YAC3B,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;gBAClC,SAAS,GAAG,CAAC,CAAC;YAChB,CAAC;YACD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;YAC3C,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACtD,CAAC;aAAM,CAAC;YACN,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,EAAE,CAAC;gBACzB,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;gBAChB,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;YACjB,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;gBACnB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;gBACjB,SAAS,GAAG,CAAC,CAAC;YAChB,CAAC;QACH,CAAC;QACD,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QAC5E,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,MAAM,CAAC,KAAc;QACnB,KAAK,GAAG,KAAK,EAAE,IAAI,EAAE,CAAC;QACtB,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,OAAoB,EAAE,EAAE;YAClD,IAAI,CAAC,cAAc,CACjB,OAAO,EACP,CAAC,KAAK;mBACD,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,KAAK,CAAC;mBACzC,OAAO,CAAC,OAAO,CAAC,WAAW,EAAE,KAAK,CAAC,EACxC,KAAK,CACN,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,6DAA6D;IAC7D,cAAc,CAAC,OAAoB,EAAE,KAAc,EAAE,KAAa;QAChE,OAAO,CAAC,KAAK,CAAC,OAAO,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;IAC9C,CAAC;IAES,YAAY,CAAC,CAAiC;QACtD,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,OAAO;QACT,CAAC;QACD,MAAM,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;QAC5B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/E,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,OAAO,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;IAC7E,CAAC;IAED,KAAK,CAAC,OAAsB;QAC1B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;IACtB,CAAC;IAED,IAAI;QACF,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QACnB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,WAAW,CAAC,MAAmB;QAC7B,OAAQ,MAAc,CAAC,KAAK,IAAI,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;IACrE,CAAC;CACF,CAAA;AAxLC;IADC,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;oCAC9B;AAMb;IADC,QAAQ,EAAE;oCACE;AAGb;IADC,IAAI,CAAC,SAAS,CAAC;wCACM;AAGtB;IADC,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;uCACX;AAGjB;IADC,QAAQ,EAAE;yCAC6B;AAGxC;IADC,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;wCACV;AA3Bd,MAAM;IAtBX,MAAM,CAAC,SAAS,CAAC;IACjB,MAAM,CACL,GAAG,CAAA;;;;;;;;;;;;;;;;;;GAkBF,CACF;GACK,MAAM,CAiMX;AAED,eAAe,MAAM,CAAC"}
@@ -0,0 +1,26 @@
1
+ import { GlobalStyle } from "../core/global-style.js";
2
+ /**
3
+ * {@linkcode Skeleton} renders a skeleton screen.
4
+ *
5
+ * @slot loading - The content if loading is true.
6
+ * @slot - The content if loading is false.
7
+ * @category feedback
8
+ */
9
+ declare class Skeleton extends GlobalStyle {
10
+ /**
11
+ * If "image", render a image placeholder.
12
+ */
13
+ type: "text" | "image";
14
+ /**
15
+ * Animation type.
16
+ * opacity animation only effect on slotted element and image icon.
17
+ */
18
+ animation: "position" | "opacity";
19
+ /**
20
+ * If false, render slot only.
21
+ */
22
+ loading: boolean;
23
+ protected render(): import("lit").TemplateResult<1>;
24
+ }
25
+ export default Skeleton;
26
+ //# sourceMappingURL=skeleton.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"skeleton.d.ts","sourceRoot":"","sources":["../../src/components/skeleton.ts"],"names":[],"mappings":"AAQA,OAAO,EAAiB,WAAW,EAAe,MAAM,yBAAyB,CAAC;AAKlF;;;;;;GAMG;AACH,cAoEM,QAAS,SAAQ,WAAW;IAChC;;OAEG;IAEH,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC;IACvB;;;OAGG;IAEH,SAAS,EAAE,UAAU,GAAG,SAAS,CAAc;IAC/C;;OAEG;IAEH,OAAO,UAAQ;IAEf,SAAS,CAAC,MAAM;CAQjB;AAED,eAAe,QAAQ,CAAC"}