godown 3.0.0-canary.0 → 3.0.0-canary.10

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 (431) hide show
  1. package/README.md +37 -8
  2. package/components/alert.d.ts +5 -3
  3. package/components/alert.d.ts.map +1 -1
  4. package/components/alert.js +24 -14
  5. package/components/alert.js.map +1 -1
  6. package/components/avatar.d.ts +5 -1
  7. package/components/avatar.d.ts.map +1 -1
  8. package/components/avatar.js +7 -3
  9. package/components/avatar.js.map +1 -1
  10. package/components/breath.d.ts +2 -1
  11. package/components/breath.d.ts.map +1 -1
  12. package/components/breath.js +5 -4
  13. package/components/breath.js.map +1 -1
  14. package/components/button.d.ts +16 -9
  15. package/components/button.d.ts.map +1 -1
  16. package/components/button.js +22 -20
  17. package/components/button.js.map +1 -1
  18. package/components/card.d.ts +1 -2
  19. package/components/card.d.ts.map +1 -1
  20. package/components/card.js +5 -11
  21. package/components/card.js.map +1 -1
  22. package/components/carousel.d.ts +6 -5
  23. package/components/carousel.d.ts.map +1 -1
  24. package/components/carousel.js +3 -2
  25. package/components/carousel.js.map +1 -1
  26. package/components/details.d.ts +5 -2
  27. package/components/details.d.ts.map +1 -1
  28. package/components/details.js +5 -2
  29. package/components/details.js.map +1 -1
  30. package/components/dialog.d.ts +8 -4
  31. package/components/dialog.d.ts.map +1 -1
  32. package/components/dialog.js +17 -12
  33. package/components/dialog.js.map +1 -1
  34. package/components/divider.d.ts +1 -1
  35. package/components/divider.js +1 -1
  36. package/components/divider.js.map +1 -1
  37. package/components/dragbox.d.ts +7 -7
  38. package/components/dragbox.d.ts.map +1 -1
  39. package/components/dragbox.js +1 -1
  40. package/components/dragbox.js.map +1 -1
  41. package/components/flex.d.ts +2 -1
  42. package/components/flex.d.ts.map +1 -1
  43. package/components/flex.js +8 -0
  44. package/components/flex.js.map +1 -1
  45. package/components/form.d.ts +0 -2
  46. package/components/form.d.ts.map +1 -1
  47. package/components/form.js +0 -2
  48. package/components/form.js.map +1 -1
  49. package/components/grid.d.ts +8 -3
  50. package/components/grid.d.ts.map +1 -1
  51. package/components/grid.js +1 -0
  52. package/components/grid.js.map +1 -1
  53. package/components/input.d.ts +2 -3
  54. package/components/input.d.ts.map +1 -1
  55. package/components/input.js +3 -6
  56. package/components/input.js.map +1 -1
  57. package/components/layout.d.ts +3 -6
  58. package/components/layout.d.ts.map +1 -1
  59. package/components/layout.js +21 -10
  60. package/components/layout.js.map +1 -1
  61. package/components/link.d.ts +3 -1
  62. package/components/link.d.ts.map +1 -1
  63. package/components/link.js +3 -1
  64. package/components/link.js.map +1 -1
  65. package/components/progress.d.ts +2 -11
  66. package/components/progress.d.ts.map +1 -1
  67. package/components/progress.js +6 -15
  68. package/components/progress.js.map +1 -1
  69. package/components/range.d.ts +43 -17
  70. package/components/range.d.ts.map +1 -1
  71. package/components/range.js +132 -58
  72. package/components/range.js.map +1 -1
  73. package/components/rotate.d.ts +1 -1
  74. package/components/rotate.d.ts.map +1 -1
  75. package/components/rotate.js +1 -1
  76. package/components/rotate.js.map +1 -1
  77. package/components/router.d.ts +6 -8
  78. package/components/router.d.ts.map +1 -1
  79. package/components/router.js +10 -10
  80. package/components/router.js.map +1 -1
  81. package/components/select.d.ts +4 -8
  82. package/components/select.d.ts.map +1 -1
  83. package/components/select.js +42 -41
  84. package/components/select.js.map +1 -1
  85. package/components/skeleton.d.ts.map +1 -1
  86. package/components/skeleton.js +3 -4
  87. package/components/skeleton.js.map +1 -1
  88. package/components/split.d.ts +18 -1
  89. package/components/split.d.ts.map +1 -1
  90. package/components/split.js +52 -19
  91. package/components/split.js.map +1 -1
  92. package/components/switch.d.ts +4 -4
  93. package/components/switch.d.ts.map +1 -1
  94. package/components/switch.js +6 -6
  95. package/components/switch.js.map +1 -1
  96. package/components/text.js +3 -3
  97. package/components/text.js.map +1 -1
  98. package/components/time.d.ts +4 -20
  99. package/components/time.d.ts.map +1 -1
  100. package/components/time.js +5 -66
  101. package/components/time.js.map +1 -1
  102. package/components/tooltip.d.ts +11 -1
  103. package/components/tooltip.d.ts.map +1 -1
  104. package/components/tooltip.js +23 -5
  105. package/components/tooltip.js.map +1 -1
  106. package/components/typewriter.d.ts +2 -2
  107. package/components/typewriter.d.ts.map +1 -1
  108. package/components/typewriter.js +2 -2
  109. package/components/typewriter.js.map +1 -1
  110. package/core/global-style.d.ts.map +1 -1
  111. package/core/global-style.js +8 -1
  112. package/core/global-style.js.map +1 -1
  113. package/core/super-anchor.js +1 -1
  114. package/core/super-anchor.js.map +1 -1
  115. package/core/super-input.d.ts +2 -3
  116. package/core/super-input.d.ts.map +1 -1
  117. package/core/super-input.js +3 -6
  118. package/core/super-input.js.map +1 -1
  119. package/core/super-openable.js.map +1 -1
  120. package/custom-elements.json +1 -1
  121. package/dev/alert.d.ts +8 -0
  122. package/dev/alert.d.ts.map +1 -0
  123. package/dev/alert.js +4 -0
  124. package/dev/alert.js.map +1 -0
  125. package/dev/avatar.d.ts +8 -0
  126. package/dev/avatar.d.ts.map +1 -0
  127. package/dev/avatar.js +4 -0
  128. package/dev/avatar.js.map +1 -0
  129. package/dev/breath.d.ts +9 -0
  130. package/dev/breath.d.ts.map +1 -0
  131. package/dev/breath.js +5 -0
  132. package/dev/breath.js.map +1 -0
  133. package/dev/button.d.ts +8 -0
  134. package/dev/button.d.ts.map +1 -0
  135. package/dev/button.js +4 -0
  136. package/dev/button.js.map +1 -0
  137. package/dev/card.d.ts +8 -0
  138. package/dev/card.d.ts.map +1 -0
  139. package/dev/card.js +4 -0
  140. package/dev/card.js.map +1 -0
  141. package/dev/carousel.d.ts +8 -0
  142. package/dev/carousel.d.ts.map +1 -0
  143. package/dev/carousel.js +4 -0
  144. package/dev/carousel.js.map +1 -0
  145. package/dev/components/alert.d.ts +52 -0
  146. package/dev/components/alert.d.ts.map +1 -0
  147. package/dev/components/alert.js +245 -0
  148. package/dev/components/alert.js.map +1 -0
  149. package/dev/components/avatar.d.ts +30 -0
  150. package/dev/components/avatar.d.ts.map +1 -0
  151. package/dev/components/avatar.js +92 -0
  152. package/dev/components/avatar.js.map +1 -0
  153. package/dev/components/breath.d.ts +35 -0
  154. package/dev/components/breath.d.ts.map +1 -0
  155. package/dev/components/breath.js +135 -0
  156. package/dev/components/breath.js.map +1 -0
  157. package/dev/components/button.d.ts +52 -0
  158. package/dev/components/button.d.ts.map +1 -0
  159. package/dev/components/button.js +260 -0
  160. package/dev/components/button.js.map +1 -0
  161. package/dev/components/card.d.ts +19 -0
  162. package/dev/components/card.d.ts.map +1 -0
  163. package/dev/components/card.js +81 -0
  164. package/dev/components/card.js.map +1 -0
  165. package/dev/components/carousel.d.ts +41 -0
  166. package/dev/components/carousel.d.ts.map +1 -0
  167. package/dev/components/carousel.js +157 -0
  168. package/dev/components/carousel.js.map +1 -0
  169. package/dev/components/details.d.ts +23 -0
  170. package/dev/components/details.d.ts.map +1 -0
  171. package/dev/components/details.js +118 -0
  172. package/dev/components/details.js.map +1 -0
  173. package/dev/components/dialog.d.ts +37 -0
  174. package/dev/components/dialog.d.ts.map +1 -0
  175. package/dev/components/dialog.js +159 -0
  176. package/dev/components/dialog.js.map +1 -0
  177. package/dev/components/divider.d.ts +17 -0
  178. package/dev/components/divider.d.ts.map +1 -0
  179. package/dev/components/divider.js +46 -0
  180. package/dev/components/divider.js.map +1 -0
  181. package/dev/components/dragbox.d.ts +40 -0
  182. package/dev/components/dragbox.d.ts.map +1 -0
  183. package/dev/components/dragbox.js +117 -0
  184. package/dev/components/dragbox.js.map +1 -0
  185. package/dev/components/flex.d.ts +32 -0
  186. package/dev/components/flex.d.ts.map +1 -0
  187. package/dev/components/flex.js +60 -0
  188. package/dev/components/flex.js.map +1 -0
  189. package/dev/components/form.d.ts +22 -0
  190. package/dev/components/form.d.ts.map +1 -0
  191. package/dev/components/form.js +77 -0
  192. package/dev/components/form.js.map +1 -0
  193. package/dev/components/grid.d.ts +36 -0
  194. package/dev/components/grid.d.ts.map +1 -0
  195. package/dev/components/grid.js +54 -0
  196. package/dev/components/grid.js.map +1 -0
  197. package/dev/components/input.d.ts +19 -0
  198. package/dev/components/input.d.ts.map +1 -0
  199. package/dev/components/input.js +70 -0
  200. package/dev/components/input.js.map +1 -0
  201. package/dev/components/layout.d.ts +26 -0
  202. package/dev/components/layout.d.ts.map +1 -0
  203. package/dev/components/layout.js +82 -0
  204. package/dev/components/layout.js.map +1 -0
  205. package/dev/components/link.d.ts +22 -0
  206. package/dev/components/link.d.ts.map +1 -0
  207. package/dev/components/link.js +42 -0
  208. package/dev/components/link.js.map +1 -0
  209. package/dev/components/progress.d.ts +21 -0
  210. package/dev/components/progress.d.ts.map +1 -0
  211. package/dev/components/progress.js +99 -0
  212. package/dev/components/progress.js.map +1 -0
  213. package/dev/components/range.d.ts +86 -0
  214. package/dev/components/range.d.ts.map +1 -0
  215. package/dev/components/range.js +364 -0
  216. package/dev/components/range.js.map +1 -0
  217. package/dev/components/rotate.d.ts +26 -0
  218. package/dev/components/rotate.d.ts.map +1 -0
  219. package/dev/components/rotate.js +86 -0
  220. package/dev/components/rotate.js.map +1 -0
  221. package/dev/components/router.d.ts +119 -0
  222. package/dev/components/router.d.ts.map +1 -0
  223. package/dev/components/router.js +248 -0
  224. package/dev/components/router.js.map +1 -0
  225. package/dev/components/select.d.ts +46 -0
  226. package/dev/components/select.d.ts.map +1 -0
  227. package/dev/components/select.js +245 -0
  228. package/dev/components/select.js.map +1 -0
  229. package/dev/components/skeleton.d.ts +26 -0
  230. package/dev/components/skeleton.d.ts.map +1 -0
  231. package/dev/components/skeleton.js +118 -0
  232. package/dev/components/skeleton.js.map +1 -0
  233. package/dev/components/split.d.ts +49 -0
  234. package/dev/components/split.d.ts.map +1 -0
  235. package/dev/components/split.js +206 -0
  236. package/dev/components/split.js.map +1 -0
  237. package/dev/components/switch.d.ts +39 -0
  238. package/dev/components/switch.d.ts.map +1 -0
  239. package/dev/components/switch.js +182 -0
  240. package/dev/components/switch.js.map +1 -0
  241. package/dev/components/text.d.ts +19 -0
  242. package/dev/components/text.d.ts.map +1 -0
  243. package/dev/components/text.js +93 -0
  244. package/dev/components/text.js.map +1 -0
  245. package/dev/components/time.d.ts +37 -0
  246. package/dev/components/time.d.ts.map +1 -0
  247. package/dev/components/time.js +75 -0
  248. package/dev/components/time.js.map +1 -0
  249. package/dev/components/tooltip.d.ts +48 -0
  250. package/dev/components/tooltip.d.ts.map +1 -0
  251. package/dev/components/tooltip.js +137 -0
  252. package/dev/components/tooltip.js.map +1 -0
  253. package/dev/components/typewriter.d.ts +55 -0
  254. package/dev/components/typewriter.d.ts.map +1 -0
  255. package/dev/components/typewriter.js +155 -0
  256. package/dev/components/typewriter.js.map +1 -0
  257. package/dev/core/global-style.d.ts +21 -0
  258. package/dev/core/global-style.d.ts.map +1 -0
  259. package/dev/core/global-style.js +76 -0
  260. package/dev/core/global-style.js.map +1 -0
  261. package/dev/core/super-anchor.d.ts +15 -0
  262. package/dev/core/super-anchor.d.ts.map +1 -0
  263. package/dev/core/super-anchor.js +58 -0
  264. package/dev/core/super-anchor.js.map +1 -0
  265. package/dev/core/super-input.d.ts +38 -0
  266. package/dev/core/super-input.d.ts.map +1 -0
  267. package/dev/core/super-input.js +182 -0
  268. package/dev/core/super-input.js.map +1 -0
  269. package/dev/core/super-openable.d.ts +19 -0
  270. package/dev/core/super-openable.d.ts.map +1 -0
  271. package/dev/core/super-openable.js +36 -0
  272. package/dev/core/super-openable.js.map +1 -0
  273. package/dev/details.d.ts +8 -0
  274. package/dev/details.d.ts.map +1 -0
  275. package/dev/details.js +4 -0
  276. package/dev/details.js.map +1 -0
  277. package/dev/dialog.d.ts +8 -0
  278. package/dev/dialog.d.ts.map +1 -0
  279. package/dev/dialog.js +4 -0
  280. package/dev/dialog.js.map +1 -0
  281. package/dev/divider.d.ts +8 -0
  282. package/dev/divider.d.ts.map +1 -0
  283. package/dev/divider.js +4 -0
  284. package/dev/divider.js.map +1 -0
  285. package/dev/dragbox.d.ts +8 -0
  286. package/dev/dragbox.d.ts.map +1 -0
  287. package/dev/dragbox.js +4 -0
  288. package/dev/dragbox.js.map +1 -0
  289. package/dev/flex.d.ts +8 -0
  290. package/dev/flex.d.ts.map +1 -0
  291. package/dev/flex.js +4 -0
  292. package/dev/flex.js.map +1 -0
  293. package/dev/form.d.ts +8 -0
  294. package/dev/form.d.ts.map +1 -0
  295. package/dev/form.js +4 -0
  296. package/dev/form.js.map +1 -0
  297. package/dev/grid.d.ts +8 -0
  298. package/dev/grid.d.ts.map +1 -0
  299. package/dev/grid.js +4 -0
  300. package/dev/grid.js.map +1 -0
  301. package/dev/index.d.ts +29 -0
  302. package/dev/index.d.ts.map +1 -0
  303. package/dev/index.js +29 -0
  304. package/dev/index.js.map +1 -0
  305. package/dev/input.d.ts +9 -0
  306. package/dev/input.d.ts.map +1 -0
  307. package/dev/input.js +5 -0
  308. package/dev/input.js.map +1 -0
  309. package/dev/layout.d.ts +9 -0
  310. package/dev/layout.d.ts.map +1 -0
  311. package/dev/layout.js +5 -0
  312. package/dev/layout.js.map +1 -0
  313. package/dev/link.d.ts +9 -0
  314. package/dev/link.d.ts.map +1 -0
  315. package/dev/link.js +5 -0
  316. package/dev/link.js.map +1 -0
  317. package/dev/progress.d.ts +9 -0
  318. package/dev/progress.d.ts.map +1 -0
  319. package/dev/progress.js +5 -0
  320. package/dev/progress.js.map +1 -0
  321. package/dev/range.d.ts +9 -0
  322. package/dev/range.d.ts.map +1 -0
  323. package/dev/range.js +5 -0
  324. package/dev/range.js.map +1 -0
  325. package/dev/rotate.d.ts +9 -0
  326. package/dev/rotate.d.ts.map +1 -0
  327. package/dev/rotate.js +5 -0
  328. package/dev/rotate.js.map +1 -0
  329. package/dev/router.d.ts +9 -0
  330. package/dev/router.d.ts.map +1 -0
  331. package/dev/router.js +5 -0
  332. package/dev/router.js.map +1 -0
  333. package/dev/select.d.ts +9 -0
  334. package/dev/select.d.ts.map +1 -0
  335. package/dev/select.js +5 -0
  336. package/dev/select.js.map +1 -0
  337. package/dev/skeleton.d.ts +9 -0
  338. package/dev/skeleton.d.ts.map +1 -0
  339. package/dev/skeleton.js +5 -0
  340. package/dev/skeleton.js.map +1 -0
  341. package/dev/split.d.ts +9 -0
  342. package/dev/split.d.ts.map +1 -0
  343. package/dev/split.js +5 -0
  344. package/dev/split.js.map +1 -0
  345. package/dev/switch.d.ts +9 -0
  346. package/dev/switch.d.ts.map +1 -0
  347. package/dev/switch.js +5 -0
  348. package/dev/switch.js.map +1 -0
  349. package/dev/text.d.ts +9 -0
  350. package/dev/text.d.ts.map +1 -0
  351. package/dev/text.js +5 -0
  352. package/dev/text.js.map +1 -0
  353. package/dev/time.d.ts +9 -0
  354. package/dev/time.d.ts.map +1 -0
  355. package/dev/time.js +5 -0
  356. package/dev/time.js.map +1 -0
  357. package/dev/tooltip.d.ts +9 -0
  358. package/dev/tooltip.d.ts.map +1 -0
  359. package/dev/tooltip.js +5 -0
  360. package/dev/tooltip.js.map +1 -0
  361. package/dev/typewriter.d.ts +8 -0
  362. package/dev/typewriter.d.ts.map +1 -0
  363. package/dev/typewriter.js +4 -0
  364. package/dev/typewriter.js.map +1 -0
  365. package/index.js +13 -13
  366. package/package.json +10 -8
  367. package/range.d.ts +1 -1
  368. package/range.d.ts.map +1 -1
  369. package/src/alert.ts +11 -0
  370. package/src/avatar.ts +11 -0
  371. package/src/breath.ts +13 -0
  372. package/src/button.ts +11 -0
  373. package/src/card.ts +11 -0
  374. package/src/carousel.ts +11 -0
  375. package/src/components/alert.ts +282 -0
  376. package/src/components/avatar.ts +95 -0
  377. package/src/components/breath.ts +153 -0
  378. package/src/components/button.ts +286 -0
  379. package/src/components/card.ts +80 -0
  380. package/src/components/carousel.ts +169 -0
  381. package/src/components/details.ts +116 -0
  382. package/src/components/dialog.ts +165 -0
  383. package/src/components/divider.ts +44 -0
  384. package/src/components/dragbox.ts +127 -0
  385. package/src/components/flex.ts +70 -0
  386. package/src/components/form.ts +82 -0
  387. package/src/components/grid.ts +75 -0
  388. package/src/components/input.ts +72 -0
  389. package/src/components/layout.ts +82 -0
  390. package/src/components/link.ts +38 -0
  391. package/src/components/progress.ts +95 -0
  392. package/src/components/range.ts +404 -0
  393. package/src/components/rotate.ts +92 -0
  394. package/src/components/router.ts +273 -0
  395. package/src/components/select.ts +268 -0
  396. package/src/components/skeleton.ts +118 -0
  397. package/src/components/split.ts +221 -0
  398. package/src/components/switch.ts +180 -0
  399. package/src/components/text.ts +95 -0
  400. package/src/components/time.ts +81 -0
  401. package/src/components/tooltip.ts +138 -0
  402. package/src/components/typewriter.ts +154 -0
  403. package/src/core/global-style.ts +86 -0
  404. package/src/core/super-anchor.ts +52 -0
  405. package/src/core/super-input.ts +230 -0
  406. package/src/core/super-openable.ts +51 -0
  407. package/src/details.ts +11 -0
  408. package/src/dialog.ts +11 -0
  409. package/src/divider.ts +11 -0
  410. package/src/dragbox.ts +11 -0
  411. package/src/flex.ts +11 -0
  412. package/src/form.ts +11 -0
  413. package/src/grid.ts +11 -0
  414. package/src/index.ts +28 -0
  415. package/src/input.ts +13 -0
  416. package/src/layout.ts +12 -0
  417. package/src/link.ts +13 -0
  418. package/src/progress.ts +12 -0
  419. package/src/range.ts +13 -0
  420. package/src/rotate.ts +13 -0
  421. package/src/router.ts +12 -0
  422. package/src/select.ts +13 -0
  423. package/src/skeleton.ts +13 -0
  424. package/src/split.ts +13 -0
  425. package/src/switch.ts +13 -0
  426. package/src/text.ts +13 -0
  427. package/src/time.ts +13 -0
  428. package/src/tooltip.ts +13 -0
  429. package/src/typewriter.ts +11 -0
  430. package/vscode.html-custom-data.json +1 -1
  431. package/web-types.json +1 -1
@@ -0,0 +1,39 @@
1
+ import SuperInput from "../core/super-input.js";
2
+ /**
3
+ * {@linkcode Switch} renders a switch.
4
+ *
5
+ * The switch is rectangular by default,
6
+ * set the round property to rounded switch.
7
+ *
8
+ * @category input
9
+ */
10
+ declare class Switch extends SuperInput {
11
+ /**
12
+ * Display rounded.
13
+ */
14
+ round: boolean;
15
+ /**
16
+ * Whether this element is selected or not.
17
+ */
18
+ checked: boolean;
19
+ /**
20
+ * Disable this element.
21
+ */
22
+ disabled: boolean;
23
+ /**
24
+ * Default checked state.
25
+ */
26
+ default: string;
27
+ /**
28
+ * Input value.
29
+ */
30
+ value: string;
31
+ protected _input: HTMLInputElement;
32
+ protected render(): import("lit").TemplateResult<1>;
33
+ reset(): void;
34
+ connectedCallback(): void;
35
+ protected _handleChange(): void;
36
+ namevalue(): [string, boolean];
37
+ }
38
+ export default Switch;
39
+ //# sourceMappingURL=switch.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"switch.d.ts","sourceRoot":"","sources":["../../src/components/switch.ts"],"names":[],"mappings":"AAMA,OAAO,UAAU,MAAM,wBAAwB,CAAC;AAKhD;;;;;;;GAOG;AACH,cAqFM,MAAO,SAAQ,UAAU;IAC7B;;OAEG;IAEH,KAAK,UAAS;IAEd;;OAEG;IAEH,OAAO,UAAS;IAEhB;;OAEG;IAEH,QAAQ,UAAS;IAEjB;;OAEG;IAEH,OAAO,SAAW;IAElB;;OAEG;IAEH,KAAK,SAAQ;IAGb,SAAS,CAAC,MAAM,EAAE,gBAAgB,CAAC;IAEnC,SAAS,CAAC,MAAM;IAehB,KAAK;IAKL,iBAAiB;IAUjB,SAAS,CAAC,aAAa;IAMvB,SAAS,IAAI,CAAC,MAAM,EAAE,OAAO,CAAC;CAG/B;AAED,eAAe,MAAM,CAAC"}
@@ -0,0 +1,182 @@
1
+ import { __decorate } from "tslib";
2
+ import { godown } from "@godown/element/decorators/godown.js";
3
+ import { styles } from "@godown/element/decorators/styles.js";
4
+ import { css, html } from "lit";
5
+ import { property, query } from "lit/decorators.js";
6
+ import { cssGlobalVars, scopePrefix } from "../core/global-style.js";
7
+ import SuperInput from "../core/super-input.js";
8
+ const protoName = "switch";
9
+ const cssScope = scopePrefix(protoName);
10
+ /**
11
+ * {@linkcode Switch} renders a switch.
12
+ *
13
+ * The switch is rectangular by default,
14
+ * set the round property to rounded switch.
15
+ *
16
+ * @category input
17
+ */
18
+ let Switch = class Switch extends SuperInput {
19
+ constructor() {
20
+ super(...arguments);
21
+ /**
22
+ * Display rounded.
23
+ */
24
+ this.round = false;
25
+ /**
26
+ * Whether this element is selected or not.
27
+ */
28
+ this.checked = false;
29
+ /**
30
+ * Disable this element.
31
+ */
32
+ this.disabled = false;
33
+ /**
34
+ * Default checked state.
35
+ */
36
+ this.default = "false";
37
+ /**
38
+ * Input value.
39
+ */
40
+ this.value = "on";
41
+ }
42
+ render() {
43
+ return html `<div part="root" class="${this.round ? "round" : "rect"}">
44
+ <input
45
+ part="input"
46
+ @change="${this._handleChange}"
47
+ ?disabled="${this.disabled}"
48
+ ?checked="${this.checked}"
49
+ name="${this.name}"
50
+ id="${this.makeId}"
51
+ type="checkbox"
52
+ >
53
+ <span part="handle" class="${this.checked}"></span>
54
+ </div>`;
55
+ }
56
+ reset() {
57
+ this.checked = this.default === "true";
58
+ this._input.checked = this.checked;
59
+ }
60
+ connectedCallback() {
61
+ super.connectedCallback();
62
+ if (this.checked) {
63
+ this.default = "true";
64
+ }
65
+ if (this.default === "true") {
66
+ this.checked = true;
67
+ }
68
+ }
69
+ _handleChange() {
70
+ this.checked = this._input.checked;
71
+ this.dispatchEvent(new CustomEvent("input", { detail: this.checked, bubbles: true, composed: true }));
72
+ this.dispatchEvent(new CustomEvent("change", { detail: this.checked, composed: true }));
73
+ }
74
+ namevalue() {
75
+ return [this.name, this.checked];
76
+ }
77
+ };
78
+ __decorate([
79
+ property({ type: Boolean, reflect: true })
80
+ ], Switch.prototype, "round", void 0);
81
+ __decorate([
82
+ property({ type: Boolean, reflect: true })
83
+ ], Switch.prototype, "checked", void 0);
84
+ __decorate([
85
+ property({ type: Boolean, reflect: true })
86
+ ], Switch.prototype, "disabled", void 0);
87
+ __decorate([
88
+ property()
89
+ ], Switch.prototype, "default", void 0);
90
+ __decorate([
91
+ property()
92
+ ], Switch.prototype, "value", void 0);
93
+ __decorate([
94
+ query("input")
95
+ ], Switch.prototype, "_input", void 0);
96
+ Switch = __decorate([
97
+ godown(protoName),
98
+ styles(css `
99
+ :host {
100
+ ${cssScope}-width: 3em;
101
+ ${cssScope}-height: calc(var(${cssScope}-width) / 2);
102
+ ${cssScope}-handle-size: 1.25em;
103
+ ${cssScope}-handle-space: .125em;
104
+ ${cssScope}-transition: .2s ease-in-out;
105
+ background: var(${cssGlobalVars.input}-background);
106
+ width: var(${cssScope}-width);
107
+ height: var(${cssScope}-height);
108
+ display: inline-block;
109
+ vertical-align: bottom;
110
+ border-radius: 0;
111
+ }
112
+
113
+ [part=root],
114
+ span {
115
+ transition: var(${cssScope}-transition);
116
+ }
117
+
118
+ [part=root] {
119
+ border-radius: inherit;
120
+ position: relative;
121
+ height: inherit;
122
+ }
123
+
124
+ [part=root],
125
+ input {
126
+ width: 100%;
127
+ }
128
+
129
+ input {
130
+ opacity: 0;
131
+ height: 100%;
132
+ appearance: none;
133
+ }
134
+
135
+ span {
136
+ height: 100%;
137
+ display: inline-flex;
138
+ align-items: center;
139
+ justify-content: center;
140
+ position: absolute;
141
+ left: 0;
142
+ width: 50%;
143
+ pointer-events: none;
144
+ border-radius: inherit;
145
+ }
146
+
147
+ :host([round]) {
148
+ border-radius: calc(var(${cssScope}-height) / 2);
149
+ }
150
+
151
+ :host([checked]) span {
152
+ left: 50%;
153
+ }
154
+
155
+ .rect .true {
156
+ background: var(${cssGlobalVars.active});
157
+ }
158
+
159
+ .rect .false {
160
+ background: var(${cssGlobalVars.passive});
161
+ }
162
+
163
+ .round span{
164
+ --size: var(${cssScope}-handle-size);
165
+ border-radius: 100%;
166
+ background: var(--godown--input-control);
167
+ width: var(--size);
168
+ height: var(--size);
169
+ margin: var(${cssScope}-handle-space);
170
+ }
171
+
172
+ .round {
173
+ background: var(${cssGlobalVars.passive});
174
+ }
175
+
176
+ :host([checked]) .round {
177
+ background: var(${cssGlobalVars.active});
178
+ }
179
+ `)
180
+ ], Switch);
181
+ export default Switch;
182
+ //# sourceMappingURL=switch.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"switch.js","sourceRoot":"","sources":["../../src/components/switch.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ import { GlobalStyle } from "../core/global-style.js";
2
+ /**
3
+ * {@linkcode Text} renders nowrap text.
4
+ *
5
+ * @category display
6
+ */
7
+ declare class Text extends GlobalStyle {
8
+ /**
9
+ * Underline behavior.
10
+ */
11
+ underline: "none" | "hover" | "active" | "always";
12
+ /**
13
+ * Set background-clip to text.
14
+ */
15
+ clip: boolean;
16
+ protected render(): import("lit").TemplateResult<1>;
17
+ }
18
+ export default Text;
19
+ //# sourceMappingURL=text.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"text.d.ts","sourceRoot":"","sources":["../../src/components/text.ts"],"names":[],"mappings":"AAOA,OAAO,EAAiB,WAAW,EAAe,MAAM,yBAAyB,CAAC;AAMlF;;;;GAIG;AACH,cAiDM,IAAK,SAAQ,WAAW;IAC5B;;OAEG;IAEH,SAAS,EAAE,MAAM,GAAG,OAAO,GAAG,QAAQ,GAAG,QAAQ,CAAU;IAE3D;;OAEG;IAEH,IAAI,EAAE,OAAO,CAAC;IAEd,SAAS,CAAC,MAAM;CAYjB;AAED,eAAe,IAAI,CAAC"}
@@ -0,0 +1,93 @@
1
+ import { __decorate } from "tslib";
2
+ import { godown } from "@godown/element/decorators/godown.js";
3
+ import { styles } from "@godown/element/decorators/styles.js";
4
+ import { classList } from "@godown/element/directives/class-list.js";
5
+ import { htmlSlot } from "@godown/element/directives/html-slot.js";
6
+ import { css, html } from "lit";
7
+ import { property } from "lit/decorators.js";
8
+ import { cssGlobalVars, GlobalStyle, scopePrefix } from "../core/global-style.js";
9
+ const protoName = "text";
10
+ const cssScope = scopePrefix(protoName);
11
+ /**
12
+ * {@linkcode Text} renders nowrap text.
13
+ *
14
+ * @category display
15
+ */
16
+ let Text = class Text extends GlobalStyle {
17
+ constructor() {
18
+ super(...arguments);
19
+ /**
20
+ * Underline behavior.
21
+ */
22
+ this.underline = "none";
23
+ }
24
+ render() {
25
+ return html `<span
26
+ part="root"
27
+ class="${classList(this.underline, {
28
+ clip: this.clip,
29
+ })}"
30
+ >
31
+ ${htmlSlot()}
32
+ </span>`;
33
+ }
34
+ };
35
+ __decorate([
36
+ property()
37
+ ], Text.prototype, "underline", void 0);
38
+ __decorate([
39
+ property({ type: Boolean })
40
+ ], Text.prototype, "clip", void 0);
41
+ Text = __decorate([
42
+ godown(protoName),
43
+ styles(css `
44
+ :host {
45
+ ${cssScope}--color: currentColor;
46
+ ${cssScope}--color-hover: currentColor;
47
+ ${cssScope}--color-active: currentColor;
48
+ display: inline-block;
49
+ text-overflow: ellipsis;
50
+ overflow-wrap: break-word;
51
+ }
52
+
53
+ [part=root] {
54
+ white-space: nowrap;
55
+ width: 100%;
56
+ vertical-align: bottom;
57
+ display: inline-block;
58
+ text-overflow: inherit;
59
+ overflow-wrap: inherit;
60
+ overflow: hidden;
61
+ color: var(${cssScope}--color);
62
+ }
63
+
64
+ [part=root]:hover {
65
+ color: var(${cssScope}--color-hover, var(${cssScope}--color));
66
+ }
67
+
68
+ [part=root]:active {
69
+ color: var(${cssScope}--color-active, var(${cssScope}--color));
70
+ }
71
+
72
+ .hover:hover,
73
+ .active:active,
74
+ .always {
75
+ text-decoration: underline;
76
+ }
77
+
78
+ .none {
79
+ text-decoration: none;
80
+ }
81
+
82
+ .clip{
83
+ background: var(${cssGlobalVars.clipBackground});
84
+ display: inline-block;
85
+ color: transparent;
86
+ -webkit-text-fill-color: transparent;
87
+ background-clip: text;
88
+ -webkit-background-clip: text;
89
+ }
90
+ `)
91
+ ], Text);
92
+ export default Text;
93
+ //# sourceMappingURL=text.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"text.js","sourceRoot":"","sources":["../../src/components/text.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,sCAAsC,CAAC;AAC9D,OAAO,EAAE,MAAM,EAAE,MAAM,sCAAsC,CAAC;AAC9D,OAAO,EAAE,SAAS,EAAE,MAAM,0CAA0C,CAAC;AACrE,OAAO,EAAE,QAAQ,EAAE,MAAM,yCAAyC,CAAC;AACnE,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAElF,MAAM,SAAS,GAAG,MAAM,CAAC;AAEzB,MAAM,QAAQ,GAAG,WAAW,CAAC,SAAS,CAAC,CAAC;AAExC;;;;GAIG;AAkDH,IAAM,IAAI,GAAV,MAAM,IAAK,SAAQ,WAAW;IAA9B;;QACE;;WAEG;QAEH,cAAS,GAA2C,MAAM,CAAC;IAoB7D,CAAC;IAZW,MAAM;QACd,OAAO,IAAI,CAAA;;eAGT,SAAS,CAAC,IAAI,CAAC,SAAS,EAAE;YACxB,IAAI,EAAE,IAAI,CAAC,IAAI;SAChB,CACH;;QAEI,QAAQ,EAAE;YACN,CAAC;IACX,CAAC;CACF,CAAA;AApBC;IADC,QAAQ,EAAE;uCACgD;AAM3D;IADC,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;kCACd;AAXV,IAAI;IAjDT,MAAM,CAAC,SAAS,CAAC;IACjB,MAAM,CAAC,GAAG,CAAA;;QAEH,QAAQ;QACR,QAAQ;QACR,QAAQ;;;;;;;;;;;;;;mBAcG,QAAQ;;;;mBAIR,QAAQ,sBAAsB,QAAQ;;;;mBAItC,QAAQ,uBAAuB,QAAQ;;;;;;;;;;;;;;wBAclC,aAAa,CAAC,cAAc;;;;;;;CAOnD,CAAC;GACI,IAAI,CAyBT;AAED,eAAe,IAAI,CAAC"}
@@ -0,0 +1,37 @@
1
+ import { type PropertyValues } from "lit";
2
+ import { GlobalStyle } from "../core/global-style.js";
3
+ /**
4
+ * {@linkcode Time} renders a formatting time.
5
+ *
6
+ * @category display
7
+ */
8
+ declare class Time extends GlobalStyle {
9
+ /**
10
+ * Escape symbol.
11
+ */
12
+ escape: string;
13
+ /**
14
+ * Format strings.
15
+ */
16
+ format: string;
17
+ /**
18
+ * Time.
19
+ */
20
+ time: Date;
21
+ /**
22
+ * If there is a value, update every gap or timeout.
23
+ */
24
+ timeout: any;
25
+ /**
26
+ * The number of milliseconds that change with each update.
27
+ */
28
+ gap: any;
29
+ protected timeoutId: number;
30
+ protected render(): string;
31
+ protected firstUpdated(): void;
32
+ protected updated(changedProperties: PropertyValues): void;
33
+ disconnectedCallback(): void;
34
+ startTimeout(): number;
35
+ }
36
+ export default Time;
37
+ //# sourceMappingURL=time.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"time.d.ts","sourceRoot":"","sources":["../../src/components/time.ts"],"names":[],"mappings":"AAGA,OAAO,EAAO,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAG/C,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAItD;;;;GAIG;AACH,cAEM,IAAK,SAAQ,WAAW;IAC5B;;OAEG;IAEH,MAAM,SAAO;IAEb;;OAEG;IAEH,MAAM,SAA8B;IAEpC;;OAEG;IAEH,IAAI,OAAc;IAElB;;OAEG;IAEH,OAAO,MAAC;IAER;;OAEG;IAEH,GAAG,MAAC;IAEJ,SAAS,CAAC,SAAS,EAAE,MAAM,CAAC;IAE5B,SAAS,CAAC,MAAM,IAAI,MAAM;IAI1B,SAAS,CAAC,YAAY;IAMtB,SAAS,CAAC,OAAO,CAAC,iBAAiB,EAAE,cAAc,GAAG,IAAI;IAS1D,oBAAoB;IAIpB,YAAY;CAKb;AAED,eAAe,IAAI,CAAC"}
@@ -0,0 +1,75 @@
1
+ import { __decorate } from "tslib";
2
+ import { godown } from "@godown/element/decorators/godown.js";
3
+ import { styles } from "@godown/element/decorators/styles.js";
4
+ import fmtime from "fmtime";
5
+ import { css } from "lit";
6
+ import { property } from "lit/decorators.js";
7
+ import { GlobalStyle } from "../core/global-style.js";
8
+ const protoName = "time";
9
+ /**
10
+ * {@linkcode Time} renders a formatting time.
11
+ *
12
+ * @category display
13
+ */
14
+ let Time = class Time extends GlobalStyle {
15
+ constructor() {
16
+ super(...arguments);
17
+ /**
18
+ * Escape symbol.
19
+ */
20
+ this.escape = "%";
21
+ /**
22
+ * Format strings.
23
+ */
24
+ this.format = "YYYY-MM-DD hh:mm:ss UTFZ";
25
+ /**
26
+ * Time.
27
+ */
28
+ this.time = new Date();
29
+ }
30
+ render() {
31
+ return fmtime(this.format, this.time, this.escape);
32
+ }
33
+ firstUpdated() {
34
+ if (this.timeout) {
35
+ this.timeoutId = this.startTimeout();
36
+ }
37
+ }
38
+ updated(changedProperties) {
39
+ if (changedProperties.has("timeout")) {
40
+ clearInterval(this.timeoutId);
41
+ if (this.timeout) {
42
+ this.timeoutId = this.startTimeout();
43
+ }
44
+ }
45
+ }
46
+ disconnectedCallback() {
47
+ clearInterval(this.timeoutId);
48
+ }
49
+ startTimeout() {
50
+ return window.setInterval(() => {
51
+ this.time = new Date(this.time.getTime() + (this.gap || this.timeout));
52
+ }, Math.abs(this.timeout));
53
+ }
54
+ };
55
+ __decorate([
56
+ property()
57
+ ], Time.prototype, "escape", void 0);
58
+ __decorate([
59
+ property()
60
+ ], Time.prototype, "format", void 0);
61
+ __decorate([
62
+ property({ type: Object })
63
+ ], Time.prototype, "time", void 0);
64
+ __decorate([
65
+ property({ type: Number })
66
+ ], Time.prototype, "timeout", void 0);
67
+ __decorate([
68
+ property({ type: Number })
69
+ ], Time.prototype, "gap", void 0);
70
+ Time = __decorate([
71
+ godown(protoName),
72
+ styles(css `:host{text-align: center;}`)
73
+ ], Time);
74
+ export default Time;
75
+ //# sourceMappingURL=time.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"time.js","sourceRoot":"","sources":["../../src/components/time.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,sCAAsC,CAAC;AAC9D,OAAO,EAAE,MAAM,EAAE,MAAM,sCAAsC,CAAC;AAC9D,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,GAAG,EAAuB,MAAM,KAAK,CAAC;AAC/C,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAEtD,MAAM,SAAS,GAAG,MAAM,CAAC;AAEzB;;;;GAIG;AAGH,IAAM,IAAI,GAAV,MAAM,IAAK,SAAQ,WAAW;IAA9B;;QACE;;WAEG;QAEH,WAAM,GAAG,GAAG,CAAC;QAEb;;WAEG;QAEH,WAAM,GAAG,0BAA0B,CAAC;QAEpC;;WAEG;QAEH,SAAI,GAAG,IAAI,IAAI,EAAE,CAAC;IA4CpB,CAAC;IA5BW,MAAM;QACd,OAAO,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IACrD,CAAC;IAES,YAAY;QACpB,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QACvC,CAAC;IACH,CAAC;IAES,OAAO,CAAC,iBAAiC;QACjD,IAAI,iBAAiB,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC;YACrC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC9B,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;gBACjB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;YACvC,CAAC;QACH,CAAC;IACH,CAAC;IAED,oBAAoB;QAClB,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAChC,CAAC;IAED,YAAY;QACV,OAAO,MAAM,CAAC,WAAW,CAAC,GAAG,EAAE;YAC7B,IAAI,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;QACzE,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;IAC7B,CAAC;CACF,CAAA;AAxDC;IADC,QAAQ,EAAE;oCACE;AAMb;IADC,QAAQ,EAAE;oCACyB;AAMpC;IADC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;kCACT;AAMlB;IADC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;qCACnB;AAMR;IADC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;iCACvB;AA7BA,IAAI;IAFT,MAAM,CAAC,SAAS,CAAC;IACjB,MAAM,CAAC,GAAG,CAAA,4BAA4B,CAAC;GAClC,IAAI,CA6DT;AAED,eAAe,IAAI,CAAC"}
@@ -0,0 +1,48 @@
1
+ import SuperOpenable, { type Direction8 } from "../core/super-openable.js";
2
+ /**
3
+ * {@linkcode Tooltip} provide tooltip for slot elements.
4
+ *
5
+ * If it has the tip property, ignore the slot tip.
6
+ *
7
+ * @slot tip - Tip element if no `tip` provided.
8
+ * @slot - Content.
9
+ * @category feedback
10
+ */
11
+ declare class Tooltip extends SuperOpenable {
12
+ /**
13
+ * Tip text, if there is a value, the slot will be ignored.
14
+ */
15
+ tip: string;
16
+ /**
17
+ * Direction of opening the tip.
18
+ */
19
+ direction: Direction8;
20
+ /**
21
+ * Content alignment.
22
+ */
23
+ align: "center" | "flex-start" | "flex-end" | "start" | "end";
24
+ /**
25
+ * If true, allow penetration of the tip.
26
+ */
27
+ propagation: boolean;
28
+ /**
29
+ * How can tips be triggered.
30
+ *
31
+ * If `focus`, element will be focusable, open tip when focused.
32
+ *
33
+ * If `hover`, element will open tip when hovered.
34
+ *
35
+ * @default "hover"
36
+ */
37
+ type: "hover" | "focus";
38
+ static aligns: {
39
+ start: string;
40
+ end: string;
41
+ center: string;
42
+ "flex-start": string;
43
+ "flex-end": string;
44
+ };
45
+ protected render(): import("lit").TemplateResult<1>;
46
+ }
47
+ export default Tooltip;
48
+ //# sourceMappingURL=tooltip.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tooltip.d.ts","sourceRoot":"","sources":["../../src/components/tooltip.ts"],"names":[],"mappings":"AAOA,OAAO,aAAa,EAAE,EAAE,KAAK,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAK3E;;;;;;;;GAQG;AACH,cAgDM,OAAQ,SAAQ,aAAa;IACjC;;OAEG;IAEH,GAAG,EAAE,MAAM,CAAC;IAEZ;;OAEG;IAEH,SAAS,EAAE,UAAU,CAAS;IAE9B;;OAEG;IAEH,KAAK,EAAE,QAAQ,GAAG,YAAY,GAAG,UAAU,GAAG,OAAO,GAAG,KAAK,CAAY;IAEzE;;OAEG;IAEH,WAAW,UAAS;IAEpB;;;;;;;;OAQG;IAEH,IAAI,EAAE,OAAO,GAAG,OAAO,CAAW;IAElC,MAAM,CAAC,MAAM;;;;;;MAMX;IAEF,SAAS,CAAC,MAAM;CAqBjB;AAED,eAAe,OAAO,CAAC"}
@@ -0,0 +1,137 @@
1
+ var Tooltip_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 { css, html } from "lit";
7
+ import { property } from "lit/decorators.js";
8
+ import { scopePrefix } from "../core/global-style.js";
9
+ import SuperOpenable from "../core/super-openable.js";
10
+ const protoName = "tooltip";
11
+ const cssScope = scopePrefix(protoName);
12
+ /**
13
+ * {@linkcode Tooltip} provide tooltip for slot elements.
14
+ *
15
+ * If it has the tip property, ignore the slot tip.
16
+ *
17
+ * @slot tip - Tip element if no `tip` provided.
18
+ * @slot - Content.
19
+ * @category feedback
20
+ */
21
+ let Tooltip = Tooltip_1 = class Tooltip extends SuperOpenable {
22
+ constructor() {
23
+ super(...arguments);
24
+ /**
25
+ * Direction of opening the tip.
26
+ */
27
+ this.direction = "top";
28
+ /**
29
+ * Content alignment.
30
+ */
31
+ this.align = "center";
32
+ /**
33
+ * If true, allow penetration of the tip.
34
+ */
35
+ this.propagation = false;
36
+ /**
37
+ * How can tips be triggered.
38
+ *
39
+ * If `focus`, element will be focusable, open tip when focused.
40
+ *
41
+ * If `hover`, element will open tip when hovered.
42
+ *
43
+ * @default "hover"
44
+ */
45
+ this.type = "hover";
46
+ }
47
+ render() {
48
+ const align = Tooltip_1.aligns[this.align] || "inherit";
49
+ const isFocusable = this.type === "focus";
50
+ return html `<div part="root"
51
+ tabindex="${isFocusable ? 0 : -1}"
52
+ @focus="${isFocusable ? () => this.open = true : null}"
53
+ @blur="${isFocusable ? () => this.open = false : null}"
54
+ @mouseenter="${isFocusable ? null : () => this.open = true}"
55
+ @mouseleave="${isFocusable ? null : () => this.open = false}"
56
+ style="justify-content:${align};align-items:${align}">
57
+ ${htmlSlot()}
58
+ <div part="tip"
59
+ direction="${this.direction}"
60
+ style="pointer-events:${this.propagation ? "none" : "all"}">
61
+ ${this.tip
62
+ ? html `<span class="passive">${this.tip}</span>`
63
+ : htmlSlot("tip")}</div>
64
+ </div>`;
65
+ }
66
+ };
67
+ Tooltip.aligns = {
68
+ start: "flex-start",
69
+ end: "flex-end",
70
+ center: "center",
71
+ "flex-start": "flex-start",
72
+ "flex-end": "flex-end",
73
+ };
74
+ __decorate([
75
+ property()
76
+ ], Tooltip.prototype, "tip", void 0);
77
+ __decorate([
78
+ property()
79
+ ], Tooltip.prototype, "direction", void 0);
80
+ __decorate([
81
+ property()
82
+ ], Tooltip.prototype, "align", void 0);
83
+ __decorate([
84
+ property({ type: Boolean })
85
+ ], Tooltip.prototype, "propagation", void 0);
86
+ __decorate([
87
+ property()
88
+ ], Tooltip.prototype, "type", void 0);
89
+ Tooltip = Tooltip_1 = __decorate([
90
+ godown(protoName),
91
+ styles(css `
92
+ :host {
93
+ ${cssScope}--tip-background: inherit;
94
+ display: inline-block;
95
+ width: fit-content;
96
+ }
97
+
98
+ [part=root] {
99
+ display: flex;
100
+ position: relative;
101
+ transition: inherit;
102
+ border-radius: inherit;
103
+ }
104
+
105
+ [part=tip] {
106
+ width: fit-content;
107
+ height: fit-content;
108
+ position: absolute;
109
+ visibility: hidden;
110
+ transition: inherit;
111
+ user-select: none;
112
+ }
113
+
114
+ :host([open]) [part=tip] {
115
+ visibility: visible;
116
+ }
117
+
118
+ .passive {
119
+ background: var(${cssScope}--tip-background);
120
+ }
121
+ `, css `
122
+ [direction^=top] {
123
+ bottom: 100%;
124
+ }
125
+ [direction^=bottom] {
126
+ top: 100%;
127
+ }
128
+ [direction$=right] {
129
+ left: 100%;
130
+ }
131
+ [direction$=left] {
132
+ right: 100%;
133
+ }
134
+ `)
135
+ ], Tooltip);
136
+ export default Tooltip;
137
+ //# sourceMappingURL=tooltip.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tooltip.js","sourceRoot":"","sources":["../../src/components/tooltip.ts"],"names":[],"mappings":";;AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,sCAAsC,CAAC;AAC9D,OAAO,EAAE,MAAM,EAAE,MAAM,sCAAsC,CAAC;AAC9D,OAAO,EAAE,QAAQ,EAAE,MAAM,yCAAyC,CAAC;AACnE,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,aAAkC,MAAM,2BAA2B,CAAC;AAE3E,MAAM,SAAS,GAAG,SAAS,CAAC;AAC5B,MAAM,QAAQ,GAAG,WAAW,CAAC,SAAS,CAAC,CAAC;AAExC;;;;;;;;GAQG;AAiDH,IAAM,OAAO,eAAb,MAAM,OAAQ,SAAQ,aAAa;IAAnC;;QAOE;;WAEG;QAEH,cAAS,GAAe,KAAK,CAAC;QAE9B;;WAEG;QAEH,UAAK,GAA2D,QAAQ,CAAC;QAEzE;;WAEG;QAEH,gBAAW,GAAG,KAAK,CAAC;QAEpB;;;;;;;;WAQG;QAEH,SAAI,GAAsB,OAAO,CAAC;IA+BpC,CAAC;IArBW,MAAM;QACd,MAAM,KAAK,GAAG,SAAO,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,SAAS,CAAC;QACtD,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,KAAK,OAAO,CAAC;QAC1C,OAAO,IAAI,CAAA;kBACG,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACtB,WAAW,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI;eAC5C,WAAW,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI;qBACtC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI;qBAC3C,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,GAAG,KAAK;+BAClC,KAAK,gBAAgB,KAAK;QACjD,QAAQ,EAAE;;mBAEC,IAAI,CAAC,SAAS;8BACH,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK;MAEzD,IAAI,CAAC,GAAG;YACN,CAAC,CAAC,IAAI,CAAA,yBAAyB,IAAI,CAAC,GAAG,SAAS;YAChD,CAAC,CAAC,QAAQ,CAAC,KAAK,CACpB;WACO,CAAC;IACV,CAAC;;AA5BM,cAAM,GAAG;IACd,KAAK,EAAE,YAAY;IACnB,GAAG,EAAE,UAAU;IACf,MAAM,EAAE,QAAQ;IAChB,YAAY,EAAE,YAAY;IAC1B,UAAU,EAAE,UAAU;CACvB,AANY,CAMX;AAtCF;IADC,QAAQ,EAAE;oCACC;AAMZ;IADC,QAAQ,EAAE;0CACmB;AAM9B;IADC,QAAQ,EAAE;sCAC8D;AAMzE;IADC,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;4CACR;AAYpB;IADC,QAAQ,EAAE;qCACuB;AAnC9B,OAAO;IAhDZ,MAAM,CAAC,SAAS,CAAC;IACjB,MAAM,CACL,GAAG,CAAA;;QAEG,QAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;wBA0BQ,QAAQ;;GAE7B,EACD,GAAG,CAAA;;;;;;;;;;;;;GAaF,CACF;GACK,OAAO,CAkEZ;AAED,eAAe,OAAO,CAAC"}