@shibui-ui/ui 1.24.1 → 1.25.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 (460) hide show
  1. package/dist/components/atoms/index.d.ts +45 -16
  2. package/dist/components/atoms/index.d.ts.map +1 -1
  3. package/dist/components/molecules/index.d.ts +20 -1
  4. package/dist/components/molecules/index.d.ts.map +1 -1
  5. package/dist/components/organisms/index.d.ts +17 -1
  6. package/dist/components/organisms/index.d.ts.map +1 -1
  7. package/dist/index.d.ts +3 -82
  8. package/dist/index.d.ts.map +1 -1
  9. package/dist/index.js +79 -80
  10. package/dist/index.js.map +1 -1
  11. package/dist/index10.js +82 -18
  12. package/dist/index10.js.map +1 -1
  13. package/dist/index11.js +84 -69
  14. package/dist/index11.js.map +1 -1
  15. package/dist/index12.js +40 -26
  16. package/dist/index12.js.map +1 -1
  17. package/dist/index13.js +16 -39
  18. package/dist/index13.js.map +1 -1
  19. package/dist/index14.js +29 -44
  20. package/dist/index14.js.map +1 -1
  21. package/dist/index15.js +16 -117
  22. package/dist/index15.js.map +1 -1
  23. package/dist/index16.js +48 -40
  24. package/dist/index16.js.map +1 -1
  25. package/dist/index17.js +41 -25
  26. package/dist/index17.js.map +1 -1
  27. package/dist/index18.js +76 -49
  28. package/dist/index18.js.map +1 -1
  29. package/dist/index19.js +19 -39
  30. package/dist/index19.js.map +1 -1
  31. package/dist/index194.js +94 -24
  32. package/dist/index194.js.map +1 -1
  33. package/dist/index195.js +2 -2
  34. package/dist/index197.js +2 -24
  35. package/dist/index197.js.map +1 -1
  36. package/dist/index198.js +74 -2
  37. package/dist/index198.js.map +1 -1
  38. package/dist/index199.js +64 -35
  39. package/dist/index199.js.map +1 -1
  40. package/dist/index20.js +21 -41
  41. package/dist/index20.js.map +1 -1
  42. package/dist/index200.js +2 -2
  43. package/dist/index201.js +54 -13
  44. package/dist/index201.js.map +1 -1
  45. package/dist/index202.js +2 -2
  46. package/dist/index203.js +2 -2
  47. package/dist/index204.js +143 -157
  48. package/dist/index204.js.map +1 -1
  49. package/dist/index205.js +43 -24
  50. package/dist/index205.js.map +1 -1
  51. package/dist/index206.js +51 -2
  52. package/dist/index206.js.map +1 -1
  53. package/dist/index207.js +2 -11
  54. package/dist/index207.js.map +1 -1
  55. package/dist/index208.js +33 -2
  56. package/dist/index208.js.map +1 -1
  57. package/dist/index209.js +2 -91
  58. package/dist/index209.js.map +1 -1
  59. package/dist/index21.js +90 -26
  60. package/dist/index21.js.map +1 -1
  61. package/dist/index210.js +6 -2
  62. package/dist/index210.js.map +1 -1
  63. package/dist/index211.js +2 -41
  64. package/dist/index211.js.map +1 -1
  65. package/dist/index212.js +260 -2
  66. package/dist/index212.js.map +1 -1
  67. package/dist/index213.js +16 -5
  68. package/dist/index213.js.map +1 -1
  69. package/dist/index214.js +2 -2
  70. package/dist/index215.js +2 -35
  71. package/dist/index215.js.map +1 -1
  72. package/dist/index216.js +59 -42
  73. package/dist/index216.js.map +1 -1
  74. package/dist/index217.js +32 -2
  75. package/dist/index217.js.map +1 -1
  76. package/dist/index218.js +2 -85
  77. package/dist/index218.js.map +1 -1
  78. package/dist/index219.js +2 -2
  79. package/dist/index22.js +41 -48
  80. package/dist/index22.js.map +1 -1
  81. package/dist/index220.js +73 -65
  82. package/dist/index220.js.map +1 -1
  83. package/dist/index221.js +81 -2
  84. package/dist/index221.js.map +1 -1
  85. package/dist/index222.js +2 -10
  86. package/dist/index222.js.map +1 -1
  87. package/dist/index223.js +133 -2
  88. package/dist/index223.js.map +1 -1
  89. package/dist/index224.js +2 -26
  90. package/dist/index224.js.map +1 -1
  91. package/dist/index225.js +2 -2
  92. package/dist/index226.js +66 -12
  93. package/dist/index226.js.map +1 -1
  94. package/dist/index227.js +97 -2
  95. package/dist/index227.js.map +1 -1
  96. package/dist/index228.js +2 -2
  97. package/dist/index229.js +62 -24
  98. package/dist/index229.js.map +1 -1
  99. package/dist/index23.js +50 -94
  100. package/dist/index23.js.map +1 -1
  101. package/dist/index230.js +2 -2
  102. package/dist/index231.js +2 -2
  103. package/dist/index232.js +12 -2
  104. package/dist/index232.js.map +1 -1
  105. package/dist/index233.js +5 -16
  106. package/dist/index233.js.map +1 -1
  107. package/dist/index234.js +2 -2
  108. package/dist/index235.js +11 -9
  109. package/dist/index235.js.map +1 -1
  110. package/dist/index236.js +2 -2
  111. package/dist/index237.js +76 -34
  112. package/dist/index237.js.map +1 -1
  113. package/dist/index238.js +2 -2
  114. package/dist/index239.js +2 -27
  115. package/dist/index239.js.map +1 -1
  116. package/dist/index24.js +37 -34
  117. package/dist/index24.js.map +1 -1
  118. package/dist/index240.js +39 -2
  119. package/dist/index240.js.map +1 -1
  120. package/dist/index241.js +2 -34
  121. package/dist/index241.js.map +1 -1
  122. package/dist/index242.js +235 -12
  123. package/dist/index242.js.map +1 -1
  124. package/dist/index243.js +82 -2
  125. package/dist/index243.js.map +1 -1
  126. package/dist/index244.js +2 -9
  127. package/dist/index244.js.map +1 -1
  128. package/dist/index245.js +94 -2
  129. package/dist/index245.js.map +1 -1
  130. package/dist/index246.js +2 -5
  131. package/dist/index246.js.map +1 -1
  132. package/dist/index247.js +268 -2
  133. package/dist/index247.js.map +1 -1
  134. package/dist/index248.js +2 -36
  135. package/dist/index248.js.map +1 -1
  136. package/dist/index249.js +21 -2
  137. package/dist/index249.js.map +1 -1
  138. package/dist/index25.js +51 -32
  139. package/dist/index25.js.map +1 -1
  140. package/dist/index250.js +2 -31
  141. package/dist/index250.js.map +1 -1
  142. package/dist/index251.js +9 -2
  143. package/dist/index251.js.map +1 -1
  144. package/dist/index252.js +2 -19
  145. package/dist/index252.js.map +1 -1
  146. package/dist/index253.js +15 -2
  147. package/dist/index253.js.map +1 -1
  148. package/dist/index254.js +2 -2
  149. package/dist/index255.js +135 -69
  150. package/dist/index255.js.map +1 -1
  151. package/dist/index256.js +2 -11
  152. package/dist/index256.js.map +1 -1
  153. package/dist/index257.js +5 -2
  154. package/dist/index257.js.map +1 -1
  155. package/dist/index258.js +2 -78
  156. package/dist/index258.js.map +1 -1
  157. package/dist/index259.js +9 -2
  158. package/dist/index259.js.map +1 -1
  159. package/dist/index26.js +31 -236
  160. package/dist/index26.js.map +1 -1
  161. package/dist/index260.js +2 -32
  162. package/dist/index260.js.map +1 -1
  163. package/dist/index261.js +2 -2
  164. package/dist/index262.js +92 -9
  165. package/dist/index262.js.map +1 -1
  166. package/dist/index263.js +59 -2
  167. package/dist/index263.js.map +1 -1
  168. package/dist/index264.js +2 -16
  169. package/dist/index264.js.map +1 -1
  170. package/dist/index265.js +41 -2
  171. package/dist/index265.js.map +1 -1
  172. package/dist/index266.js +2 -16
  173. package/dist/index266.js.map +1 -1
  174. package/dist/index267.js +34 -9
  175. package/dist/index267.js.map +1 -1
  176. package/dist/index268.js +8 -54
  177. package/dist/index268.js.map +1 -1
  178. package/dist/index269.js +2 -2
  179. package/dist/index27.js +27 -58
  180. package/dist/index27.js.map +1 -1
  181. package/dist/index270.js +42 -7
  182. package/dist/index270.js.map +1 -1
  183. package/dist/index271.js +2 -2
  184. package/dist/index272.js +2 -34
  185. package/dist/index272.js.map +1 -1
  186. package/dist/index273.js +16 -2
  187. package/dist/index273.js.map +1 -1
  188. package/dist/index274.js +9 -2
  189. package/dist/index274.js.map +1 -1
  190. package/dist/index275.js +6 -13
  191. package/dist/index275.js.map +1 -1
  192. package/dist/index276.js +2 -2
  193. package/dist/index277.js +8 -15
  194. package/dist/index277.js.map +1 -1
  195. package/dist/index278.js +2 -2
  196. package/dist/index279.js +55 -2
  197. package/dist/index279.js.map +1 -1
  198. package/dist/index28.js +247 -24
  199. package/dist/index28.js.map +1 -1
  200. package/dist/index280.js +2 -42
  201. package/dist/index280.js.map +1 -1
  202. package/dist/index281.js +2 -100
  203. package/dist/index281.js.map +1 -1
  204. package/dist/index282.js +20 -2
  205. package/dist/index282.js.map +1 -1
  206. package/dist/index283.js +2 -97
  207. package/dist/index283.js.map +1 -1
  208. package/dist/index284.js +33 -2
  209. package/dist/index284.js.map +1 -1
  210. package/dist/index285.js +6 -27
  211. package/dist/index285.js.map +1 -1
  212. package/dist/index286.js +2 -2
  213. package/dist/index287.js +9 -44
  214. package/dist/index287.js.map +1 -1
  215. package/dist/index288.js +2 -2
  216. package/dist/index289.js +2 -33
  217. package/dist/index289.js.map +1 -1
  218. package/dist/index29.js +249 -39
  219. package/dist/index29.js.map +1 -1
  220. package/dist/index290.js +36 -2
  221. package/dist/index290.js.map +1 -1
  222. package/dist/index291.js +2 -57
  223. package/dist/index291.js.map +1 -1
  224. package/dist/index292.js +24 -2
  225. package/dist/index292.js.map +1 -1
  226. package/dist/index293.js +2 -2
  227. package/dist/index294.js +26 -247
  228. package/dist/index294.js.map +1 -1
  229. package/dist/index295.js +2 -2
  230. package/dist/index296.js +2 -72
  231. package/dist/index296.js.map +1 -1
  232. package/dist/index297.js +42 -2
  233. package/dist/index297.js.map +1 -1
  234. package/dist/index298.js +7 -56
  235. package/dist/index298.js.map +1 -1
  236. package/dist/index299.js +2 -133
  237. package/dist/index299.js.map +1 -1
  238. package/dist/index30.js +32 -19
  239. package/dist/index30.js.map +1 -1
  240. package/dist/index300.js +30 -2
  241. package/dist/index300.js.map +1 -1
  242. package/dist/index301.js +2 -12
  243. package/dist/index301.js.map +1 -1
  244. package/dist/index302.js +34 -2
  245. package/dist/index302.js.map +1 -1
  246. package/dist/index303.js +2 -162
  247. package/dist/index303.js.map +1 -1
  248. package/dist/index304.js +26 -42
  249. package/dist/index304.js.map +1 -1
  250. package/dist/index305.js +2 -81
  251. package/dist/index305.js.map +1 -1
  252. package/dist/index306.js +10 -2
  253. package/dist/index306.js.map +1 -1
  254. package/dist/index307.js +2 -71
  255. package/dist/index307.js.map +1 -1
  256. package/dist/index308.js +2 -2
  257. package/dist/index309.js +19 -2
  258. package/dist/index309.js.map +1 -1
  259. package/dist/index31.js +96 -11
  260. package/dist/index31.js.map +1 -1
  261. package/dist/index310.js +2 -81
  262. package/dist/index310.js.map +1 -1
  263. package/dist/index311.js +2 -2
  264. package/dist/index312.js +42 -2
  265. package/dist/index312.js.map +1 -1
  266. package/dist/index313.js +2 -74
  267. package/dist/index313.js.map +1 -1
  268. package/dist/index314.js +25 -67
  269. package/dist/index314.js.map +1 -1
  270. package/dist/index315.js +2 -2
  271. package/dist/index316.js +9 -17
  272. package/dist/index316.js.map +1 -1
  273. package/dist/index317.js +2 -2
  274. package/dist/index318.js +84 -32
  275. package/dist/index318.js.map +1 -1
  276. package/dist/index319.js +2 -2
  277. package/dist/index32.js +40 -48
  278. package/dist/index32.js.map +1 -1
  279. package/dist/index320.js +68 -77
  280. package/dist/index320.js.map +1 -1
  281. package/dist/index321.js +2 -2
  282. package/dist/index322.js +12 -148
  283. package/dist/index322.js.map +1 -1
  284. package/dist/index323.js +1 -1
  285. package/dist/index324.js +28 -6
  286. package/dist/index324.js.map +1 -1
  287. package/dist/index325.js +2 -2
  288. package/dist/index326.js +78 -87
  289. package/dist/index326.js.map +1 -1
  290. package/dist/index327.js +2 -2
  291. package/dist/index328.js +78 -2
  292. package/dist/index328.js.map +1 -1
  293. package/dist/index329.js +2 -237
  294. package/dist/index329.js.map +1 -1
  295. package/dist/index33.js +20 -56
  296. package/dist/index33.js.map +1 -1
  297. package/dist/index330.js +11 -6
  298. package/dist/index330.js.map +1 -1
  299. package/dist/index331.js +2 -2
  300. package/dist/index332.js +18 -59
  301. package/dist/index332.js.map +1 -1
  302. package/dist/index333.js +2 -2
  303. package/dist/index334.js +12 -5
  304. package/dist/index334.js.map +1 -1
  305. package/dist/index335.js +2 -2
  306. package/dist/index336.js +2 -15
  307. package/dist/index336.js.map +1 -1
  308. package/dist/index337.js +88 -2
  309. package/dist/index337.js.map +1 -1
  310. package/dist/index338.js +24 -2
  311. package/dist/index338.js.map +1 -1
  312. package/dist/index339.js +2 -92
  313. package/dist/index339.js.map +1 -1
  314. package/dist/index34.js +59 -35
  315. package/dist/index34.js.map +1 -1
  316. package/dist/index340.js +42 -14
  317. package/dist/index340.js.map +1 -1
  318. package/dist/index341.js +2 -2
  319. package/dist/index342.js +22 -80
  320. package/dist/index342.js.map +1 -1
  321. package/dist/index343.js +2 -2
  322. package/dist/index344.js +2 -18
  323. package/dist/index344.js.map +1 -1
  324. package/dist/index345.js +16 -2
  325. package/dist/index345.js.map +1 -1
  326. package/dist/index346.js +2 -268
  327. package/dist/index346.js.map +1 -1
  328. package/dist/index347.js +176 -2
  329. package/dist/index347.js.map +1 -1
  330. package/dist/index348.js +2 -2
  331. package/dist/index349.js +35 -39
  332. package/dist/index349.js.map +1 -1
  333. package/dist/index35.js +101 -28
  334. package/dist/index35.js.map +1 -1
  335. package/dist/index350.js +3 -3
  336. package/dist/index350.js.map +1 -1
  337. package/dist/index351.js +2 -2
  338. package/dist/index352.js +19 -26
  339. package/dist/index352.js.map +1 -1
  340. package/dist/index357.js +26 -19
  341. package/dist/index357.js.map +1 -1
  342. package/dist/index36.js +115 -33
  343. package/dist/index36.js.map +1 -1
  344. package/dist/index37.js +41 -115
  345. package/dist/index37.js.map +1 -1
  346. package/dist/index38.js +34 -246
  347. package/dist/index38.js.map +1 -1
  348. package/dist/index39.js +30 -137
  349. package/dist/index39.js.map +1 -1
  350. package/dist/index4.js +26 -84
  351. package/dist/index4.js.map +1 -1
  352. package/dist/index40.js +26 -400
  353. package/dist/index40.js.map +1 -1
  354. package/dist/index41.js +28 -77
  355. package/dist/index41.js.map +1 -1
  356. package/dist/index42.js +23 -26
  357. package/dist/index42.js.map +1 -1
  358. package/dist/index43.js +36 -33
  359. package/dist/index43.js.map +1 -1
  360. package/dist/index44.js +62 -16
  361. package/dist/index44.js.map +1 -1
  362. package/dist/index45.js +138 -21
  363. package/dist/index45.js.map +1 -1
  364. package/dist/index46.js +129 -22
  365. package/dist/index46.js.map +1 -1
  366. package/dist/index47.js +41 -19
  367. package/dist/index47.js.map +1 -1
  368. package/dist/index48.js +11 -82
  369. package/dist/index48.js.map +1 -1
  370. package/dist/index49.js +56 -279
  371. package/dist/index49.js.map +1 -1
  372. package/dist/index5.js +21 -34
  373. package/dist/index5.js.map +1 -1
  374. package/dist/index50.js +280 -33
  375. package/dist/index50.js.map +1 -1
  376. package/dist/index51.js +74 -94
  377. package/dist/index51.js.map +1 -1
  378. package/dist/index52.js +66 -41
  379. package/dist/index52.js.map +1 -1
  380. package/dist/index53.js +333 -62
  381. package/dist/index53.js.map +1 -1
  382. package/dist/index54.js +96 -256
  383. package/dist/index54.js.map +1 -1
  384. package/dist/index55.js +38 -130
  385. package/dist/index55.js.map +1 -1
  386. package/dist/index56.js +251 -50
  387. package/dist/index56.js.map +1 -1
  388. package/dist/index57.js +144 -115
  389. package/dist/index57.js.map +1 -1
  390. package/dist/index58.js +93 -183
  391. package/dist/index58.js.map +1 -1
  392. package/dist/index59.js +33 -339
  393. package/dist/index59.js.map +1 -1
  394. package/dist/index6.js +2 -2
  395. package/dist/index60.js +102 -66
  396. package/dist/index60.js.map +1 -1
  397. package/dist/index61.js +73 -179
  398. package/dist/index61.js.map +1 -1
  399. package/dist/index62.js +117 -97
  400. package/dist/index62.js.map +1 -1
  401. package/dist/index63.js +113 -263
  402. package/dist/index63.js.map +1 -1
  403. package/dist/index64.js +258 -251
  404. package/dist/index64.js.map +1 -1
  405. package/dist/index65.js +177 -79
  406. package/dist/index65.js.map +1 -1
  407. package/dist/index66.js +261 -140
  408. package/dist/index66.js.map +1 -1
  409. package/dist/index67.js +183 -100
  410. package/dist/index67.js.map +1 -1
  411. package/dist/index68.js +28 -89
  412. package/dist/index68.js.map +1 -1
  413. package/dist/index69.js +20 -161
  414. package/dist/index69.js.map +1 -1
  415. package/dist/index7.js +394 -32
  416. package/dist/index7.js.map +1 -1
  417. package/dist/index70.js +190 -53
  418. package/dist/index70.js.map +1 -1
  419. package/dist/index71.js +204 -112
  420. package/dist/index71.js.map +1 -1
  421. package/dist/index72.js +2 -2
  422. package/dist/index73.js +89 -28
  423. package/dist/index73.js.map +1 -1
  424. package/dist/index74.js +126 -63
  425. package/dist/index74.js.map +1 -1
  426. package/dist/index75.js +122 -111
  427. package/dist/index75.js.map +1 -1
  428. package/dist/index76.js +67 -64
  429. package/dist/index76.js.map +1 -1
  430. package/dist/index77.js +112 -88
  431. package/dist/index77.js.map +1 -1
  432. package/dist/index78.js +87 -16
  433. package/dist/index78.js.map +1 -1
  434. package/dist/index79.js +151 -79
  435. package/dist/index79.js.map +1 -1
  436. package/dist/index8.js +25 -127
  437. package/dist/index8.js.map +1 -1
  438. package/dist/index80.js +104 -186
  439. package/dist/index80.js.map +1 -1
  440. package/dist/index81.js +59 -20
  441. package/dist/index81.js.map +1 -1
  442. package/dist/index82.js +17 -129
  443. package/dist/index82.js.map +1 -1
  444. package/dist/index83.js +88 -217
  445. package/dist/index83.js.map +1 -1
  446. package/dist/index84.js +64 -112
  447. package/dist/index84.js.map +1 -1
  448. package/dist/index9.js +30 -45
  449. package/dist/index9.js.map +1 -1
  450. package/dist/src/components/atoms/index.d.ts +45 -16
  451. package/dist/src/components/atoms/index.d.ts.map +1 -1
  452. package/dist/src/components/molecules/index.d.ts +20 -1
  453. package/dist/src/components/molecules/index.d.ts.map +1 -1
  454. package/dist/src/components/organisms/index.d.ts +17 -1
  455. package/dist/src/components/organisms/index.d.ts.map +1 -1
  456. package/dist/src/index.d.ts +3 -82
  457. package/dist/src/index.d.ts.map +1 -1
  458. package/dist/tokens.css +353 -7
  459. package/dist/vite.config.d.ts.map +1 -1
  460. package/package.json +4 -4
package/dist/index204.js CHANGED
@@ -1,179 +1,165 @@
1
1
  import { html, nothing } from "lit";
2
- import { map as o } from "./index301.js";
3
- function renderContentItem(item, marker) {
2
+ const ROTATE_SVG = html`<svg width="12" height="12" viewBox="0 0 12 12" fill="none" stroke="currentColor"
3
+ stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round">
4
+ <path d="M10 2.5A4.5 4.5 0 1 0 11 6"/>
5
+ <path d="M10 .5v2h2"/>
6
+ </svg>`;
7
+ const CARET_SVG = html`<svg width="10" height="10" viewBox="0 0 10 10" fill="none" stroke="currentColor"
8
+ stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round">
9
+ <path d="M2 4l3 3 3-3"/>
10
+ </svg>`;
11
+ function swatchGridTemplate(props) {
12
+ const { rows, selected, onSelect } = props;
4
13
  return html`
5
- <li class="lst-item">
6
- ${marker === "check" ? html`
7
- <span class="lst-check-icon" style="${item.checked === false ? "color:var(--color-washi-300)" : ""}">
8
- <lib-icon
9
- name="${item.checked === false ? "circle" : "check-circle"}"
10
- weight="${item.checked === false ? "regular" : "fill"}"
11
- size="sm"
12
- ></lib-icon>
13
- </span>` : nothing}
14
-
15
- <span class="lst-item-text">${item.label}</span>
16
-
17
- ${item.children && item.children.length ? html`
18
- <ul class="lst">
19
- ${o(
20
- item.children,
21
- (child) => renderContentItem(child, marker)
22
- )}
23
- </ul>` : nothing}
24
- </li>
14
+ <div class="cp-swatches">
15
+ ${rows.map((row) => html`
16
+ <div class="cp-swatches-row">
17
+ <span class="cp-swatches-label">${row.label}</span>
18
+ ${row.colors.map((c) => html`
19
+ <div
20
+ class="cp-swatch ${c.value.toLowerCase() === selected.toLowerCase() ? "is-selected" : ""}"
21
+ style="background:${c.value};"
22
+ data-name="${c.name ?? ""}"
23
+ @click="${() => onSelect(c)}"
24
+ role="button"
25
+ aria-label="${c.name ?? c.value}"
26
+ ></div>
27
+ `)}
28
+ </div>
29
+ `)}
30
+ </div>
25
31
  `;
26
32
  }
27
- function renderUiItem(item, interactive, onRowClick, onToggle) {
28
- if (item.type === "separator") {
29
- return html`<li class="lst-sep" role="separator"></li>`;
30
- }
31
- if (item.type === "header") {
32
- const h = item;
33
- return html`<li class="lst-section-header">${h.label}</li>`;
34
- }
35
- const row = item;
36
- const rowCls = [
37
- "lst-row",
38
- row.selected ? "is-selected" : "",
39
- row.disabled ? "is-disabled" : "",
40
- row.danger ? "is-danger" : ""
41
- ].filter(Boolean).join(" ");
33
+ function pickerPanelTemplate(p) {
34
+ const { hex, r, g, b, h, s, l, alpha, inputMode, savedColors, showAlpha } = p;
35
+ const thumbX = s;
36
+ const thumbY = 100 - l;
37
+ const cssColor = alpha < 100 ? `rgba(${r},${g},${b},${(alpha / 100).toFixed(2)})` : hex;
38
+ const alphaGradient = `linear-gradient(to right, transparent, hsl(${h},${s}%,${l}%))`;
39
+ const inputsBlock = inputMode === "hex" ? html`
40
+ <div class="cp-input-group" style="flex:3">
41
+ <input class="cp-input" type="text" .value="${hex}" maxlength="7"
42
+ @input="${p.onHexInput}">
43
+ <span class="cp-input-label">HEX</span>
44
+ </div>
45
+ ${showAlpha ? html`
46
+ <div class="cp-input-group" style="flex:1">
47
+ <input class="cp-input" type="number" .value="${String(Math.round(alpha))}" min="0" max="100"
48
+ @input="${p.onAlphaNumInput}">
49
+ <span class="cp-input-label">A%</span>
50
+ </div>` : nothing}
51
+ ` : inputMode === "rgb" ? html`
52
+ <div class="cp-input-group" style="flex:1"><input class="cp-input" type="number" .value="${String(r)}" min="0" max="255" @input="${(e) => p.onRgbInput(0, e)}"><span class="cp-input-label">R</span></div>
53
+ <div class="cp-input-group" style="flex:1"><input class="cp-input" type="number" .value="${String(g)}" min="0" max="255" @input="${(e) => p.onRgbInput(1, e)}"><span class="cp-input-label">G</span></div>
54
+ <div class="cp-input-group" style="flex:1"><input class="cp-input" type="number" .value="${String(b)}" min="0" max="255" @input="${(e) => p.onRgbInput(2, e)}"><span class="cp-input-label">B</span></div>
55
+ ${showAlpha ? html`<div class="cp-input-group" style="flex:1"><input class="cp-input" type="number" .value="${String(Math.round(alpha))}" min="0" max="100" @input="${p.onAlphaNumInput}"><span class="cp-input-label">A%</span></div>` : nothing}
56
+ ` : html`
57
+ <div class="cp-input-group" style="flex:1"><input class="cp-input" type="number" .value="${String(h)}" min="0" max="360" @input="${(e) => p.onHslInput(0, e)}"><span class="cp-input-label">H</span></div>
58
+ <div class="cp-input-group" style="flex:1"><input class="cp-input" type="number" .value="${String(s)}" min="0" max="100" @input="${(e) => p.onHslInput(1, e)}"><span class="cp-input-label">S%</span></div>
59
+ <div class="cp-input-group" style="flex:1"><input class="cp-input" type="number" .value="${String(l)}" min="0" max="100" @input="${(e) => p.onHslInput(2, e)}"><span class="cp-input-label">L%</span></div>
60
+ ${showAlpha ? html`<div class="cp-input-group" style="flex:1"><input class="cp-input" type="number" .value="${String(Math.round(alpha))}" min="0" max="100" @input="${p.onAlphaNumInput}"><span class="cp-input-label">A%</span></div>` : nothing}
61
+ `;
42
62
  return html`
43
- <li
44
- class="${rowCls}"
45
- role="${interactive ? "button" : "listitem"}"
46
- tabindex="${interactive && !row.disabled ? "0" : "-1"}"
47
- aria-selected="${row.selected ?? false}"
48
- aria-disabled="${row.disabled ?? false}"
49
- @click="${() => {
50
- if (!row.disabled) onRowClick(row);
51
- }}"
52
- @keydown="${(e) => {
53
- if ((e.key === "Enter" || e.key === " ") && !row.disabled) {
54
- e.preventDefault();
55
- onRowClick(row);
56
- }
57
- }}"
63
+ <!-- Canvas 2D -->
64
+ <div class="cp-canvas"
65
+ style="background: hsl(${h},100%,50%);"
66
+ @mousedown="${p.onCanvasMousedown}"
58
67
  >
59
- <!-- Icon o Avatar -->
60
- ${row.avatar ? html`<div class="lst-row-avatar">${row.avatar}</div>` : row.icon ? html`
61
- <div class="lst-row-icon ${row.iconVariant ? `icon-${row.iconVariant}` : ""}">
62
- <lib-icon name="${row.icon}" size="sm"></lib-icon>
63
- </div>` : nothing}
68
+ <div class="cp-thumb"
69
+ style="left:${thumbX}%;top:${thumbY}%;background:${cssColor};"
70
+ ></div>
71
+ </div>
64
72
 
65
- <!-- Body -->
66
- <div class="lst-row-body">
67
- <span class="lst-row-label">${row.label}</span>
68
- ${row.desc ? html`<span class="lst-row-desc">${row.desc}</span>` : nothing}
73
+ <!-- Sliders -->
74
+ <div class="cp-sliders">
75
+ <div class="cp-preview-dot">
76
+ <div class="cp-preview-color" style="background:${cssColor};"></div>
69
77
  </div>
78
+ <div class="cp-sliders-stack">
79
+ <input type="range" class="cp-range cp-range-hue"
80
+ min="0" max="360" .value="${String(h)}"
81
+ @input="${p.onHueInput}">
82
+ ${showAlpha ? html`
83
+ <div class="cp-alpha-wrap" style="height:10px;">
84
+ <div class="cp-alpha-checker">
85
+ <input type="range" class="cp-range cp-range-alpha"
86
+ min="0" max="100" .value="${String(Math.round(alpha))}"
87
+ style="background:${alphaGradient};"
88
+ @input="${p.onAlphaInput}">
89
+ </div>
90
+ </div>` : nothing}
91
+ </div>
92
+ </div>
70
93
 
71
- <!-- Meta -->
72
- ${row.meta ? html`<span class="lst-row-meta">${row.meta}</span>` : nothing}
73
-
74
- <!-- Badge -->
75
- ${row.badge ? html`
76
- <span class="lst-badge lst-badge-${row.badge.variant ?? "default"}">
77
- ${row.badge.label}
78
- </span>` : nothing}
94
+ <!-- Inputs -->
95
+ <div class="cp-inputs-wrap">
96
+ <button class="cp-mode-btn" title="Cambiar modo" @click="${p.onModeToggle}">
97
+ ${ROTATE_SVG}
98
+ </button>
99
+ <div style="display:flex;gap:var(--lib-space-xs);flex:1;">
100
+ ${inputsBlock}
101
+ </div>
102
+ </div>
79
103
 
80
- <!-- Toggle -->
81
- ${row.toggle != null ? html`
82
- <input
83
- type="checkbox"
84
- class="lst-row-toggle"
85
- .checked="${row.toggle}"
86
- @click="${(e) => {
87
- e.stopPropagation();
88
- const target = e.currentTarget;
89
- onToggle(row, target.checked);
90
- }}"
91
- aria-label="${row.label}"
92
- />` : nothing}
104
+ <!-- Saved colors -->
105
+ <div class="cp-saved">
106
+ <span class="cp-saved-label">Guardados</span>
107
+ ${savedColors.map((sc) => html`
108
+ <div class="cp-swatch cp-swatch-sm"
109
+ style="background:${sc};"
110
+ data-name="${sc}"
111
+ @click="${() => p.onSavedClick(sc)}"
112
+ ></div>
113
+ `)}
114
+ <button class="cp-saved-add" title="Guardar color actual" @click="${p.onSaveColor}">+</button>
115
+ </div>
93
116
 
94
- <!-- Chevron -->
95
- ${row.chevron ? html`
96
- <span class="lst-row-action">
97
- <lib-icon name="caret-right" size="sm"></lib-icon>
98
- </span>` : nothing}
99
- </li>
117
+ <!-- Actions -->
118
+ <div class="cp-actions">
119
+ <button class="cp-btn cp-btn-cancel" @click="${p.onCancel}">Cancelar</button>
120
+ <button class="cp-btn cp-btn-ok" @click="${p.onApply}">Aplicar</button>
121
+ </div>
100
122
  `;
101
123
  }
102
- function renderDlItem(item) {
103
- return html`
104
- <dt class="lst-dt">${item.term}</dt>
105
- <dd class="lst-dd ${item.mono ? "lst-dd-mono" : ""}">${item.description}</dd>
106
- `;
107
- }
108
- function textListTemplate(props) {
124
+ function colorPickerTemplate(props) {
109
125
  const {
110
- family,
111
- contentItems,
112
- marker,
113
- counter,
114
- size,
115
- uiItems,
116
- divided,
117
- bordered,
118
- inset,
119
- interactive,
120
- dark,
121
- dlItems,
122
- dlLayout,
123
- dlDivided,
124
- onRowClick,
125
- onToggle
126
+ variant,
127
+ /*label,*/
128
+ hex,
129
+ alpha,
130
+ panelOpen,
131
+ onTriggerClick
126
132
  } = props;
127
- if (family === "ul" || family === "ol") {
128
- const trackCls = [
129
- "lst",
130
- size !== "md" ? `lst-${size}` : "",
131
- marker === "kaki" ? "lst-kaki" : "",
132
- marker === "dash" ? "lst-dash" : "",
133
- marker === "check" ? "lst-checked" : "",
134
- family === "ol" && counter === "roman" ? "lst-ordered-roman" : "",
135
- family === "ol" && counter === "alpha" ? "lst-ordered-alpha" : ""
136
- ].filter(Boolean).join(" ");
137
- const items = html`
138
- ${o(contentItems, (item) => renderContentItem(item, marker))}
139
- `;
140
- return family === "ol" ? html`<ol class="${trackCls}">${items}</ol>` : html`<ul class="${trackCls}">${items}</ul>`;
141
- }
142
- if (family === "ui") {
143
- const trackCls = [
144
- "lst-ui",
145
- divided ? "lst-divided" : "",
146
- bordered ? "lst-bordered" : "",
147
- inset ? "lst-inset" : "",
148
- interactive ? "lst-interactive" : "",
149
- dark ? "lst-dark" : ""
150
- ].filter(Boolean).join(" ");
151
- return html`
152
- <ul
153
- class="${trackCls}"
154
- role="${interactive ? "listbox" : "list"}"
155
- >
156
- ${o(
157
- uiItems,
158
- (item) => renderUiItem(item, interactive, onRowClick, onToggle)
159
- )}
160
- </ul>
161
- `;
133
+ const panel = html`
134
+ <div class="cp ${variant === "trigger" && panelOpen ? "is-open" : ""}">
135
+ ${pickerPanelTemplate(props)}
136
+ </div>
137
+ `;
138
+ if (variant === "inline") {
139
+ return panel;
162
140
  }
163
- const dlCls = [
164
- "lst-dl",
165
- dlLayout === "wide" ? "lst-dl-wide" : "",
166
- dlLayout === "stack" ? "lst-dl-stack" : "",
167
- dlDivided ? "lst-dl-divided" : "",
168
- dark ? "lst-dark" : ""
169
- ].filter(Boolean).join(" ");
141
+ const cssColor = alpha < 100 ? `rgba(${props.r},${props.g},${props.b},${(alpha / 100).toFixed(2)})` : hex;
170
142
  return html`
171
- <dl class="${dlCls}">
172
- ${o(dlItems, (item) => renderDlItem(item))}
173
- </dl>
143
+ <div class="cp-trigger-wrap">
144
+ <button
145
+ class="cp-trigger ${panelOpen ? "is-open" : ""}"
146
+ @click="${onTriggerClick}"
147
+ aria-expanded="${panelOpen}"
148
+ aria-haspopup="true"
149
+ >
150
+ <div class="cp-trigger-dot">
151
+ <div class="cp-trigger-color" style="background:${cssColor};"></div>
152
+ </div>
153
+ <span>${hex.toUpperCase()}</span>
154
+ ${CARET_SVG}
155
+ </button>
156
+ ${panel}
157
+ </div>
174
158
  `;
175
159
  }
176
160
  export {
177
- textListTemplate
161
+ colorPickerTemplate,
162
+ pickerPanelTemplate,
163
+ swatchGridTemplate
178
164
  };
179
165
  //# sourceMappingURL=index204.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index204.js","sources":["../src/components/atoms/text-list/lib-text-list.html.ts"],"sourcesContent":["import { html, nothing, TemplateResult } from 'lit';\nimport { map } from 'lit/directives/map.js';\nimport type {\n TextListTemplateProps,\n ContentItem,\n UiItem,\n UiRow,\n UiSectionHeader,\n DlItem,\n} from './lib-text-list.types';\n\n/* ================================================================\n HELPERS — Content List\n ================================================================ */\n\nfunction renderContentItem(\n item: ContentItem,\n marker: TextListTemplateProps['marker'],\n): TemplateResult {\n return html`\n <li class=\"lst-item\">\n ${marker === 'check'\n ? html`\n <span class=\"lst-check-icon\" style=\"${item.checked === false ? 'color:var(--color-washi-300)' : ''}\">\n <lib-icon\n name=\"${item.checked === false ? 'circle' : 'check-circle'}\"\n weight=\"${item.checked === false ? 'regular' : 'fill'}\"\n size=\"sm\"\n ></lib-icon>\n </span>`\n : nothing}\n\n <span class=\"lst-item-text\">${item.label}</span>\n\n ${item.children && item.children.length\n ? html`\n <ul class=\"lst\">\n ${map(item.children, (child: ContentItem) =>\n renderContentItem(child, marker)\n )}\n </ul>`\n : nothing}\n </li>\n `;\n}\n\n/* ================================================================\n HELPERS — UI List\n ================================================================ */\n\nfunction renderUiItem(\n item: UiItem,\n interactive: boolean,\n onRowClick: (r: UiRow) => void,\n onToggle: (r: UiRow, v: boolean) => void,\n): TemplateResult {\n /* Separator */\n if (item.type === 'separator') {\n return html`<li class=\"lst-sep\" role=\"separator\"></li>`;\n }\n\n /* Section header */\n if (item.type === 'header') {\n const h = item as UiSectionHeader;\n return html`<li class=\"lst-section-header\">${h.label}</li>`;\n }\n\n /* Row */\n const row = item as UiRow;\n const rowCls = [\n 'lst-row',\n row.selected ? 'is-selected' : '',\n row.disabled ? 'is-disabled' : '',\n row.danger ? 'is-danger' : '',\n ].filter(Boolean).join(' ');\n\n return html`\n <li\n class=\"${rowCls}\"\n role=\"${interactive ? 'button' : 'listitem'}\"\n tabindex=\"${interactive && !row.disabled ? '0' : '-1'}\"\n aria-selected=\"${row.selected ?? false}\"\n aria-disabled=\"${row.disabled ?? false}\"\n @click=\"${(): void => { if (!row.disabled) onRowClick(row); }}\"\n @keydown=\"${(e: KeyboardEvent): void => {\n if ((e.key === 'Enter' || e.key === ' ') && !row.disabled) {\n e.preventDefault();\n onRowClick(row);\n }\n }}\"\n >\n <!-- Icon o Avatar -->\n ${row.avatar\n ? html`<div class=\"lst-row-avatar\">${row.avatar}</div>`\n : row.icon\n ? html`\n <div class=\"lst-row-icon ${row.iconVariant ? `icon-${row.iconVariant}` : ''}\">\n <lib-icon name=\"${row.icon}\" size=\"sm\"></lib-icon>\n </div>`\n : nothing}\n\n <!-- Body -->\n <div class=\"lst-row-body\">\n <span class=\"lst-row-label\">${row.label}</span>\n ${row.desc ? html`<span class=\"lst-row-desc\">${row.desc}</span>` : nothing}\n </div>\n\n <!-- Meta -->\n ${row.meta ? html`<span class=\"lst-row-meta\">${row.meta}</span>` : nothing}\n\n <!-- Badge -->\n ${row.badge\n ? html`\n <span class=\"lst-badge lst-badge-${row.badge.variant ?? 'default'}\">\n ${row.badge.label}\n </span>`\n : nothing}\n\n <!-- Toggle -->\n ${row.toggle != null\n ? html`\n <input\n type=\"checkbox\"\n class=\"lst-row-toggle\"\n .checked=\"${row.toggle}\"\n @click=\"${(e: Event): void => {\n e.stopPropagation();\n const target = e.currentTarget as HTMLInputElement;\n onToggle(row, target.checked);\n }}\"\n aria-label=\"${row.label}\"\n />`\n : nothing}\n\n <!-- Chevron -->\n ${row.chevron\n ? html`\n <span class=\"lst-row-action\">\n <lib-icon name=\"caret-right\" size=\"sm\"></lib-icon>\n </span>`\n : nothing}\n </li>\n `;\n}\n\n/* ================================================================\n HELPERS — Description List\n ================================================================ */\n\nfunction renderDlItem(item: DlItem): TemplateResult {\n return html`\n <dt class=\"lst-dt\">${item.term}</dt>\n <dd class=\"lst-dd ${item.mono ? 'lst-dd-mono' : ''}\">${item.description}</dd>\n `;\n}\n\n/* ================================================================\n TEMPLATE PRINCIPAL\n ================================================================ */\n\nexport function textListTemplate(props: TextListTemplateProps): TemplateResult {\n const {\n family, contentItems, marker, counter, size,\n uiItems, divided, bordered, inset, interactive, dark,\n dlItems, dlLayout, dlDivided,\n onRowClick, onToggle,\n } = props;\n\n /* ── CONTENT LIST ── */\n if (family === 'ul' || family === 'ol') {\n const trackCls = [\n 'lst',\n size !== 'md' ? `lst-${size}` : '',\n marker === 'kaki' ? 'lst-kaki' : '',\n marker === 'dash' ? 'lst-dash' : '',\n marker === 'check' ? 'lst-checked' : '',\n family === 'ol' && counter === 'roman' ? 'lst-ordered-roman' : '',\n family === 'ol' && counter === 'alpha' ? 'lst-ordered-alpha' : '',\n ].filter(Boolean).join(' ');\n\n const items = html`\n ${map(contentItems, (item: ContentItem) => renderContentItem(item, marker))}\n `;\n\n return family === 'ol'\n ? html`<ol class=\"${trackCls}\">${items}</ol>`\n : html`<ul class=\"${trackCls}\">${items}</ul>`;\n }\n\n /* ── UI LIST ── */\n if (family === 'ui') {\n const trackCls = [\n 'lst-ui',\n divided ? 'lst-divided' : '',\n bordered ? 'lst-bordered' : '',\n inset ? 'lst-inset' : '',\n interactive ? 'lst-interactive' : '',\n dark ? 'lst-dark' : '',\n ].filter(Boolean).join(' ');\n\n return html`\n <ul\n class=\"${trackCls}\"\n role=\"${interactive ? 'listbox' : 'list'}\"\n >\n ${map(uiItems, (item: UiItem) =>\n renderUiItem(item, interactive, onRowClick, onToggle)\n )}\n </ul>\n `;\n }\n\n /* ── DESCRIPTION LIST ── */\n const dlCls = [\n 'lst-dl',\n dlLayout === 'wide' ? 'lst-dl-wide' : '',\n dlLayout === 'stack' ? 'lst-dl-stack' : '',\n dlDivided ? 'lst-dl-divided' : '',\n dark ? 'lst-dark' : '',\n ].filter(Boolean).join(' ');\n\n return html`\n <dl class=\"${dlCls}\">\n ${map(dlItems, (item: DlItem) => renderDlItem(item))}\n </dl>\n `;\n}"],"names":["map"],"mappings":"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"}
1
+ {"version":3,"file":"index204.js","sources":["../src/components/molecules/color-picker/lib-color-picker.html.ts"],"sourcesContent":["import { html, nothing, TemplateResult } from 'lit';\nimport type { ColorPickerVariant, ColorInputMode, SwatchRow, SwatchColor } from './lib-color-picker.types';\n\n/* ── Icono ↺ inline para el mode button ── */\nconst ROTATE_SVG = html`<svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" stroke=\"currentColor\"\n stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <path d=\"M10 2.5A4.5 4.5 0 1 0 11 6\"/>\n <path d=\"M10 .5v2h2\"/>\n</svg>`;\n\n/* ── Caret-down para trigger ── */\nconst CARET_SVG = html`<svg width=\"10\" height=\"10\" viewBox=\"0 0 10 10\" fill=\"none\" stroke=\"currentColor\"\n stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <path d=\"M2 4l3 3 3-3\"/>\n</svg>`;\n\n/* ────────────────────────────────────────────\n Interfaces de props para cada sub-sección\n ──────────────────────────────────────────── */\n\nexport interface PickerPanelProps {\n hex: string;\n r: number; g: number; b: number;\n h: number; s: number; l: number;\n alpha: number; // 0–100\n inputMode: ColorInputMode;\n savedColors: string[];\n showAlpha: boolean;\n /** Callbacks */\n onCanvasMousedown: (e: MouseEvent) => void;\n onHueInput: (e: Event) => void;\n onAlphaInput: (e: Event) => void;\n onModeToggle: () => void;\n onHexInput: (e: Event) => void;\n onRgbInput: (rIdx: 0|1|2, e: Event) => void;\n onHslInput: (cIdx: 0|1|2, e: Event) => void;\n onAlphaNumInput: (e: Event) => void;\n onSaveColor: () => void;\n onSavedClick: (hex: string) => void;\n onCancel: () => void;\n onApply: () => void;\n}\n\nexport interface SwatchGridProps {\n rows: SwatchRow[];\n selected: string;\n onSelect: (color: SwatchColor) => void;\n}\n\n/* ────────────────────────────────────────────\n Swatch grid template\n ──────────────────────────────────────────── */\nexport function swatchGridTemplate(props: SwatchGridProps): TemplateResult {\n const { rows, selected, onSelect } = props;\n return html`\n <div class=\"cp-swatches\">\n ${rows.map(row => html`\n <div class=\"cp-swatches-row\">\n <span class=\"cp-swatches-label\">${row.label}</span>\n ${row.colors.map(c => html`\n <div\n class=\"cp-swatch ${c.value.toLowerCase() === selected.toLowerCase() ? 'is-selected' : ''}\"\n style=\"background:${c.value};\"\n data-name=\"${c.name ?? ''}\"\n @click=\"${(): void => onSelect(c)}\"\n role=\"button\"\n aria-label=\"${c.name ?? c.value}\"\n ></div>\n `)}\n </div>\n `)}\n </div>\n `;\n}\n\n/* ────────────────────────────────────────────\n Picker panel template (canvas + sliders + inputs + saved + actions)\n ──────────────────────────────────────────── */\nexport function pickerPanelTemplate(p: PickerPanelProps): TemplateResult {\n const { hex, r, g, b, h, s, l, alpha, inputMode, savedColors, showAlpha } = p;\n\n /* Thumb position: x = saturation %, y = inverted lightness % */\n const thumbX = s;\n const thumbY = 100 - l;\n\n const cssColor = alpha < 100\n ? `rgba(${r},${g},${b},${(alpha / 100).toFixed(2)})`\n : hex;\n\n const alphaGradient =\n `linear-gradient(to right, transparent, hsl(${h},${s}%,${l}%))`;\n\n /* Inputs según el modo */\n const inputsBlock: TemplateResult = inputMode === 'hex'\n ? html`\n <div class=\"cp-input-group\" style=\"flex:3\">\n <input class=\"cp-input\" type=\"text\" .value=\"${hex}\" maxlength=\"7\"\n @input=\"${p.onHexInput}\">\n <span class=\"cp-input-label\">HEX</span>\n </div>\n ${showAlpha ? html`\n <div class=\"cp-input-group\" style=\"flex:1\">\n <input class=\"cp-input\" type=\"number\" .value=\"${String(Math.round(alpha))}\" min=\"0\" max=\"100\"\n @input=\"${p.onAlphaNumInput}\">\n <span class=\"cp-input-label\">A%</span>\n </div>` : nothing}\n `\n : inputMode === 'rgb'\n ? html`\n <div class=\"cp-input-group\" style=\"flex:1\"><input class=\"cp-input\" type=\"number\" .value=\"${String(r)}\" min=\"0\" max=\"255\" @input=\"${(e: Event): void => p.onRgbInput(0, e)}\"><span class=\"cp-input-label\">R</span></div>\n <div class=\"cp-input-group\" style=\"flex:1\"><input class=\"cp-input\" type=\"number\" .value=\"${String(g)}\" min=\"0\" max=\"255\" @input=\"${(e: Event): void => p.onRgbInput(1, e)}\"><span class=\"cp-input-label\">G</span></div>\n <div class=\"cp-input-group\" style=\"flex:1\"><input class=\"cp-input\" type=\"number\" .value=\"${String(b)}\" min=\"0\" max=\"255\" @input=\"${(e: Event): void => p.onRgbInput(2, e)}\"><span class=\"cp-input-label\">B</span></div>\n ${showAlpha ? html`<div class=\"cp-input-group\" style=\"flex:1\"><input class=\"cp-input\" type=\"number\" .value=\"${String(Math.round(alpha))}\" min=\"0\" max=\"100\" @input=\"${p.onAlphaNumInput}\"><span class=\"cp-input-label\">A%</span></div>` : nothing}\n `\n : html`\n <div class=\"cp-input-group\" style=\"flex:1\"><input class=\"cp-input\" type=\"number\" .value=\"${String(h)}\" min=\"0\" max=\"360\" @input=\"${(e: Event): void => p.onHslInput(0, e)}\"><span class=\"cp-input-label\">H</span></div>\n <div class=\"cp-input-group\" style=\"flex:1\"><input class=\"cp-input\" type=\"number\" .value=\"${String(s)}\" min=\"0\" max=\"100\" @input=\"${(e: Event): void => p.onHslInput(1, e)}\"><span class=\"cp-input-label\">S%</span></div>\n <div class=\"cp-input-group\" style=\"flex:1\"><input class=\"cp-input\" type=\"number\" .value=\"${String(l)}\" min=\"0\" max=\"100\" @input=\"${(e: Event): void => p.onHslInput(2, e)}\"><span class=\"cp-input-label\">L%</span></div>\n ${showAlpha ? html`<div class=\"cp-input-group\" style=\"flex:1\"><input class=\"cp-input\" type=\"number\" .value=\"${String(Math.round(alpha))}\" min=\"0\" max=\"100\" @input=\"${p.onAlphaNumInput}\"><span class=\"cp-input-label\">A%</span></div>` : nothing}\n `;\n\n return html`\n <!-- Canvas 2D -->\n <div class=\"cp-canvas\"\n style=\"background: hsl(${h},100%,50%);\"\n @mousedown=\"${p.onCanvasMousedown}\"\n >\n <div class=\"cp-thumb\"\n style=\"left:${thumbX}%;top:${thumbY}%;background:${cssColor};\"\n ></div>\n </div>\n\n <!-- Sliders -->\n <div class=\"cp-sliders\">\n <div class=\"cp-preview-dot\">\n <div class=\"cp-preview-color\" style=\"background:${cssColor};\"></div>\n </div>\n <div class=\"cp-sliders-stack\">\n <input type=\"range\" class=\"cp-range cp-range-hue\"\n min=\"0\" max=\"360\" .value=\"${String(h)}\"\n @input=\"${p.onHueInput}\">\n ${showAlpha ? html`\n <div class=\"cp-alpha-wrap\" style=\"height:10px;\">\n <div class=\"cp-alpha-checker\">\n <input type=\"range\" class=\"cp-range cp-range-alpha\"\n min=\"0\" max=\"100\" .value=\"${String(Math.round(alpha))}\"\n style=\"background:${alphaGradient};\"\n @input=\"${p.onAlphaInput}\">\n </div>\n </div>` : nothing}\n </div>\n </div>\n\n <!-- Inputs -->\n <div class=\"cp-inputs-wrap\">\n <button class=\"cp-mode-btn\" title=\"Cambiar modo\" @click=\"${p.onModeToggle}\">\n ${ROTATE_SVG}\n </button>\n <div style=\"display:flex;gap:var(--lib-space-xs);flex:1;\">\n ${inputsBlock}\n </div>\n </div>\n\n <!-- Saved colors -->\n <div class=\"cp-saved\">\n <span class=\"cp-saved-label\">Guardados</span>\n ${savedColors.map(sc => html`\n <div class=\"cp-swatch cp-swatch-sm\"\n style=\"background:${sc};\"\n data-name=\"${sc}\"\n @click=\"${(): void => p.onSavedClick(sc)}\"\n ></div>\n `)}\n <button class=\"cp-saved-add\" title=\"Guardar color actual\" @click=\"${p.onSaveColor}\">+</button>\n </div>\n\n <!-- Actions -->\n <div class=\"cp-actions\">\n <button class=\"cp-btn cp-btn-cancel\" @click=\"${p.onCancel}\">Cancelar</button>\n <button class=\"cp-btn cp-btn-ok\" @click=\"${p.onApply}\">Aplicar</button>\n </div>\n `;\n}\n\n/* ────────────────────────────────────────────\n Root template — inline vs trigger\n ──────────────────────────────────────────── */\n\nexport interface ColorPickerRootProps extends PickerPanelProps {\n variant: ColorPickerVariant;\n label: string;\n panelOpen: boolean;\n onTriggerClick: () => void;\n}\n\nexport function colorPickerTemplate(props: ColorPickerRootProps): TemplateResult {\n const { variant, /*label,*/ hex, alpha, panelOpen, onTriggerClick } = props;\n\n const panel = html`\n <div class=\"cp ${variant === 'trigger' && panelOpen ? 'is-open' : ''}\">\n ${pickerPanelTemplate(props)}\n </div>\n `;\n\n if (variant === 'inline') {\n return panel;\n }\n\n /* Trigger variant — botón + panel flotante */\n const cssColor = alpha < 100\n ? `rgba(${props.r},${props.g},${props.b},${(alpha / 100).toFixed(2)})`\n : hex;\n\n return html`\n <div class=\"cp-trigger-wrap\">\n <button\n class=\"cp-trigger ${panelOpen ? 'is-open' : ''}\"\n @click=\"${onTriggerClick}\"\n aria-expanded=\"${panelOpen}\"\n aria-haspopup=\"true\"\n >\n <div class=\"cp-trigger-dot\">\n <div class=\"cp-trigger-color\" style=\"background:${cssColor};\"></div>\n </div>\n <span>${hex.toUpperCase()}</span>\n ${CARET_SVG}\n </button>\n ${panel}\n </div>\n `;\n}"],"names":[],"mappings":"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"}
package/dist/index205.js CHANGED
@@ -1,27 +1,46 @@
1
- import { html } from "lit";
2
- const ICON_SIZE = {
3
- sm: "xs",
4
- md: "sm",
5
- lg: "sm",
6
- xl: "md"
7
- };
8
- function closeButtonTemplate(props) {
9
- return html`
10
- <button
11
- type="button"
12
- class="close-btn"
13
- aria-label="${props.ariaLabel}"
14
- ?disabled="${props.disabled}"
15
- @click="${props.onClick}"
16
- >
17
- <lib-icon
18
- name="${props.icon}"
19
- size="${ICON_SIZE[props.size]}"
20
- ></lib-icon>
21
- </button>
22
- `;
23
- }
1
+ const SHIBUI_SWATCHES = [
2
+ {
3
+ label: "washi",
4
+ colors: [
5
+ { value: "#FAF7F4", name: "washi-50" },
6
+ { value: "#F2EDE6", name: "washi-100" },
7
+ { value: "#E5DDD3", name: "washi-200" },
8
+ { value: "#D3C8BC", name: "washi-300" },
9
+ { value: "#B8A99A", name: "washi-400" },
10
+ { value: "#9A8878", name: "washi-500" },
11
+ { value: "#7A6A5C", name: "washi-600" },
12
+ { value: "#5C4E42", name: "washi-700" },
13
+ { value: "#3D332A", name: "washi-800" },
14
+ { value: "#221C16", name: "washi-900" },
15
+ { value: "#120E0A", name: "washi-950" }
16
+ ]
17
+ },
18
+ {
19
+ label: "kaki",
20
+ colors: [
21
+ { value: "#FDF3EC", name: "kaki-50" },
22
+ { value: "#FAE2CC", name: "kaki-100" },
23
+ { value: "#F5C89A", name: "kaki-200" },
24
+ { value: "#EBAA66", name: "kaki-300" },
25
+ { value: "#D97234", name: "kaki-400" },
26
+ { value: "#B85A1E", name: "kaki-500" },
27
+ { value: "#8C4115", name: "kaki-600" }
28
+ ]
29
+ },
30
+ {
31
+ label: "celadón",
32
+ colors: [
33
+ { value: "#EFF5F3", name: "celadon-50" },
34
+ { value: "#D3E8E1", name: "celadon-100" },
35
+ { value: "#A8D0C5", name: "celadon-200" },
36
+ { value: "#76B3A5", name: "celadon-300" },
37
+ { value: "#4D8E82", name: "celadon-400" },
38
+ { value: "#357164", name: "celadon-500" },
39
+ { value: "#245249", name: "celadon-600" }
40
+ ]
41
+ }
42
+ ];
24
43
  export {
25
- closeButtonTemplate
44
+ SHIBUI_SWATCHES
26
45
  };
27
46
  //# sourceMappingURL=index205.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index205.js","sources":["../src/components/atoms/close-button/lib-close-button.html.ts"],"sourcesContent":["import { html, TemplateResult } from 'lit';\n\nexport type LibCloseVariant =\n | 'ghost'\n | 'subtle'\n | 'outlined'\n | 'filled'\n | 'filled-round'\n | 'danger'\n | 'on-dark';\n\nexport type LibCloseSize = 'sm' | 'md' | 'lg' | 'xl';\nexport type LibCloseIcon = 'x' | 'x-circle' | 'x-square';\n\n/** Maps component size → lib-icon size prop */\nconst ICON_SIZE: Record<LibCloseSize, string> = {\n sm: 'xs',\n md: 'sm',\n lg: 'sm',\n xl: 'md',\n};\n\nexport interface CloseButtonTemplateProps {\n variant: LibCloseVariant;\n size: LibCloseSize;\n icon: LibCloseIcon;\n disabled: boolean;\n ariaLabel: string;\n onClick: (e: Event) => void;\n}\n\n/**\n * Plantilla para lib-close-button.\n *\n * Renderiza un <button> con lib-icon interno.\n * La variante y el tamaño se aplican via :host() selectors en CSS.\n */\nexport function closeButtonTemplate(props: CloseButtonTemplateProps): TemplateResult {\n return html`\n <button\n type=\"button\"\n class=\"close-btn\"\n aria-label=\"${props.ariaLabel}\"\n ?disabled=\"${props.disabled}\"\n @click=\"${props.onClick}\"\n >\n <lib-icon\n name=\"${props.icon}\"\n size=\"${ICON_SIZE[props.size]}\"\n ></lib-icon>\n </button>\n `;\n}"],"names":[],"mappings":";AAeA,MAAM,YAA0C;AAAA,EAC9C,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AACN;AAiBO,SAAS,oBAAoB,OAAiD;AACnF,SAAO;AAAA;AAAA;AAAA;AAAA,oBAIW,MAAM,SAAS;AAAA,mBAChB,MAAM,QAAQ;AAAA,gBACjB,MAAM,OAAO;AAAA;AAAA;AAAA,gBAGb,MAAM,IAAI;AAAA,gBACV,UAAU,MAAM,IAAI,CAAC;AAAA;AAAA;AAAA;AAIrC;"}
1
+ {"version":3,"file":"index205.js","sources":["../src/components/molecules/color-picker/lib-color-picker.types.ts"],"sourcesContent":["/** Modo de visualización del componente */\nexport type ColorPickerVariant = 'inline' | 'trigger';\n\n/** Modo de los inputs de texto */\nexport type ColorInputMode = 'hex' | 'rgb' | 'hsl';\n\n/** Fila de swatches para el swatch-grid */\nexport interface SwatchRow {\n label: string;\n colors: SwatchColor[];\n}\n\nexport interface SwatchColor {\n value: string; // hex\n name?: string; // tooltip\n}\n\n/** Props internas del estado de color (HSL + alpha) */\nexport interface ColorState {\n h: number; // 0–360\n s: number; // 0–100\n l: number; // 0–100\n alpha: number; // 0–100\n}\n\n/** Paleta Shibui por defecto para el swatch grid */\nexport const SHIBUI_SWATCHES: SwatchRow[] = [\n {\n label: 'washi',\n colors: [\n { value: '#FAF7F4', name: 'washi-50' },\n { value: '#F2EDE6', name: 'washi-100' },\n { value: '#E5DDD3', name: 'washi-200' },\n { value: '#D3C8BC', name: 'washi-300' },\n { value: '#B8A99A', name: 'washi-400' },\n { value: '#9A8878', name: 'washi-500' },\n { value: '#7A6A5C', name: 'washi-600' },\n { value: '#5C4E42', name: 'washi-700' },\n { value: '#3D332A', name: 'washi-800' },\n { value: '#221C16', name: 'washi-900' },\n { value: '#120E0A', name: 'washi-950' },\n ],\n },\n {\n label: 'kaki',\n colors: [\n { value: '#FDF3EC', name: 'kaki-50' },\n { value: '#FAE2CC', name: 'kaki-100' },\n { value: '#F5C89A', name: 'kaki-200' },\n { value: '#EBAA66', name: 'kaki-300' },\n { value: '#D97234', name: 'kaki-400' },\n { value: '#B85A1E', name: 'kaki-500' },\n { value: '#8C4115', name: 'kaki-600' },\n ],\n },\n {\n label: 'celadón',\n colors: [\n { value: '#EFF5F3', name: 'celadon-50' },\n { value: '#D3E8E1', name: 'celadon-100' },\n { value: '#A8D0C5', name: 'celadon-200' },\n { value: '#76B3A5', name: 'celadon-300' },\n { value: '#4D8E82', name: 'celadon-400' },\n { value: '#357164', name: 'celadon-500' },\n { value: '#245249', name: 'celadon-600' },\n ],\n },\n];"],"names":[],"mappings":"AA0BO,MAAM,kBAA+B;AAAA,EAC1C;AAAA,IACE,OAAO;AAAA,IACP,QAAQ;AAAA,MACN,EAAE,OAAO,WAAW,MAAM,WAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,YAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,YAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,YAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,YAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,YAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,YAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,YAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,YAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,YAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,YAAA;AAAA,IAAY;AAAA,EACxC;AAAA,EAEF;AAAA,IACE,OAAO;AAAA,IACP,QAAQ;AAAA,MACN,EAAE,OAAO,WAAW,MAAM,UAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,WAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,WAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,WAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,WAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,WAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,WAAA;AAAA,IAAW;AAAA,EACvC;AAAA,EAEF;AAAA,IACE,OAAO;AAAA,IACP,QAAQ;AAAA,MACN,EAAE,OAAO,WAAW,MAAM,aAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,cAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,cAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,cAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,cAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,cAAA;AAAA,MAC1B,EAAE,OAAO,WAAW,MAAM,cAAA;AAAA,IAAc;AAAA,EAC1C;AAEJ;"}
package/dist/index206.js CHANGED
@@ -1,5 +1,54 @@
1
- const closeButtonCss = '@layer tokens,reset,components;@layer reset{:host{display:inline-flex;flex-shrink:0}*,*:before,*:after{box-sizing:border-box}}@layer components{.close-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;padding:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;color:var(--text-muted);line-height:1;outline:none;transition:color var(--duration-fast) var(--ease-default),background var(--duration-base) var(--ease-default),border-color var(--duration-base) var(--ease-default),transform var(--duration-base) var(--ease-bounce),opacity var(--duration-base)}.close-btn:disabled{opacity:.35;pointer-events:none;cursor:not-allowed}.close-btn:focus-visible{box-shadow:0 0 0 3px var(--color-ink-20)}:host([size="sm"]) .close-btn{width:24px;height:24px}:host([size="md"]) .close-btn{width:32px;height:32px}:host([size="lg"]) .close-btn{width:40px;height:40px}:host([size="xl"]) .close-btn{width:48px;height:48px}:host([variant="ghost"]) .close-btn{color:var(--text-muted);border-radius:var(--radius-sm)}:host([variant="ghost"]) .close-btn:hover{color:var(--text-primary);background:var(--color-washi-200)}:host([variant="ghost"]) .close-btn:active{transform:scale(.88)}:host([variant="subtle"]) .close-btn{color:var(--text-secondary);border-radius:var(--radius-full)}:host([variant="subtle"]) .close-btn:hover{color:var(--text-primary);background:var(--color-washi-200);transform:rotate(90deg)}:host([variant="subtle"]) .close-btn:active{transform:rotate(90deg) scale(.88);background:var(--color-washi-300)}:host([variant="outlined"]) .close-btn{color:var(--text-secondary);border:1px solid var(--border-default);border-radius:var(--radius-sm)}:host([variant="outlined"]) .close-btn:hover{color:var(--text-primary);background:var(--bg-surface);border-color:var(--border-strong)}:host([variant="outlined"]) .close-btn:active{transform:scale(.9)}:host([variant="filled"]) .close-btn{color:var(--bg-elevated);background:var(--color-washi-800);border-radius:var(--radius-sm)}:host([variant="filled"]) .close-btn:hover{background:var(--color-washi-900);transform:scale(1.05)}:host([variant="filled"]) .close-btn:active{transform:scale(.9)}:host([variant="filled-round"]) .close-btn{color:var(--bg-elevated);background:var(--color-washi-800);border-radius:var(--radius-full)}:host([variant="filled-round"]) .close-btn:hover{background:var(--color-washi-900);transform:rotate(90deg) scale(1.08)}:host([variant="filled-round"]) .close-btn:active{transform:rotate(90deg) scale(.9)}:host([variant="danger"]) .close-btn{color:var(--color-error);border-radius:var(--radius-sm)}:host([variant="danger"]) .close-btn:hover{color:var(--color-error);background:#651f241a}:host([variant="danger"]) .close-btn:active{transform:scale(.88)}:host([variant="danger"]) .close-btn:focus-visible{box-shadow:0 0 0 3px #651f2426}:host([variant="on-dark"]) .close-btn{color:#ffffff73;border-radius:var(--radius-full)}:host([variant="on-dark"]) .close-btn:hover{color:#ffffffe6;background:#ffffff1a;transform:rotate(90deg)}:host([variant="on-dark"]) .close-btn:active{transform:rotate(90deg) scale(.88)}:host([variant="on-dark"]) .close-btn:focus-visible{box-shadow:0 0 0 3px #fff3}@media(prefers-reduced-motion:reduce){.close-btn{transition:none}}}';
1
+ import { html } from "lit";
2
+ const chevronSvg = html`
3
+ <svg viewBox="0 0 256 256" fill="currentColor" aria-hidden="true">
4
+ <path d="M213.66,101.66l-80,80a8,8,0,0,1-11.32,0l-80-80a8,8,0,0,1,11.32-11.32L128,164.69l74.34-74.35a8,8,0,0,1,11.32,11.32Z"/>
5
+ </svg>`;
6
+ function dropdownTemplate(ctx) {
7
+ return html`
8
+ <div class="dd" part="root">
9
+
10
+ <!-- ── Trigger ── -->
11
+ <button
12
+ class="dd-trigger"
13
+ part="trigger"
14
+ aria-haspopup="true"
15
+ aria-expanded="${ctx.open}"
16
+ aria-label="${ctx.ariaLabel || ctx.label}"
17
+ @click="${() => ctx._toggle()}"
18
+ @keydown="${(e) => ctx._handleTriggerKey(e)}"
19
+ >
20
+ <slot name="trigger">${ctx.label}</slot>
21
+ <span class="dd-chevron" part="chevron">${chevronSvg}</span>
22
+ </button>
23
+
24
+ <!-- ── Panel ── -->
25
+ <div
26
+ class="dd-menu"
27
+ part="menu"
28
+ role="menu"
29
+ style="${ctx.minWidth ? `--dd-min-width:${ctx.minWidth}` : ""}"
30
+ @keydown="${(e) => ctx._handleMenuKey(e)}"
31
+ >
32
+ <!-- Header opcional (búsqueda, título) -->
33
+ <div class="dd-header-wrap" part="header-wrap"
34
+ style="${ctx._hasSlot("header") ? "" : "display:none"}">
35
+ <slot name="header"></slot>
36
+ </div>
37
+
38
+ <!-- Contenido: items, separadores, grupos -->
39
+ <slot></slot>
40
+
41
+ <!-- Footer opcional (acciones, confirmación) -->
42
+ <div class="dd-footer-wrap" part="footer-wrap"
43
+ style="${ctx._hasSlot("footer") ? "" : "display:none"}">
44
+ <slot name="footer"></slot>
45
+ </div>
46
+ </div>
47
+
48
+ </div>
49
+ `;
50
+ }
2
51
  export {
3
- closeButtonCss as default
52
+ dropdownTemplate
4
53
  };
5
54
  //# sourceMappingURL=index206.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index206.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
1
+ {"version":3,"file":"index206.js","sources":["../src/components/molecules/dropdown/lib-dropdown.html.ts"],"sourcesContent":["import { html, TemplateResult } from 'lit';\nimport type { LibDropdown } from './lib-dropdown.component';\n\n/* Chevron SVG inline — no depende de Phosphor ni ninguna lib */\nconst chevronSvg: TemplateResult = html`\n <svg viewBox=\"0 0 256 256\" fill=\"currentColor\" aria-hidden=\"true\">\n <path d=\"M213.66,101.66l-80,80a8,8,0,0,1-11.32,0l-80-80a8,8,0,0,1,11.32-11.32L128,164.69l74.34-74.35a8,8,0,0,1,11.32,11.32Z\"/>\n </svg>`;\n\nexport function dropdownTemplate(ctx: LibDropdown): TemplateResult {\n return html`\n <div class=\"dd\" part=\"root\">\n\n <!-- ── Trigger ── -->\n <button\n class=\"dd-trigger\"\n part=\"trigger\"\n aria-haspopup=\"true\"\n aria-expanded=\"${ctx.open}\"\n aria-label=\"${ctx.ariaLabel || ctx.label}\"\n @click=\"${(): void => ctx._toggle()}\"\n @keydown=\"${(e: KeyboardEvent): void => ctx._handleTriggerKey(e)}\"\n >\n <slot name=\"trigger\">${ctx.label}</slot>\n <span class=\"dd-chevron\" part=\"chevron\">${chevronSvg}</span>\n </button>\n\n <!-- ── Panel ── -->\n <div\n class=\"dd-menu\"\n part=\"menu\"\n role=\"menu\"\n style=\"${ctx.minWidth ? `--dd-min-width:${ctx.minWidth}` : ''}\"\n @keydown=\"${(e: KeyboardEvent): void => ctx._handleMenuKey(e)}\"\n >\n <!-- Header opcional (búsqueda, título) -->\n <div class=\"dd-header-wrap\" part=\"header-wrap\"\n style=\"${ctx._hasSlot('header') ? '' : 'display:none'}\">\n <slot name=\"header\"></slot>\n </div>\n\n <!-- Contenido: items, separadores, grupos -->\n <slot></slot>\n\n <!-- Footer opcional (acciones, confirmación) -->\n <div class=\"dd-footer-wrap\" part=\"footer-wrap\"\n style=\"${ctx._hasSlot('footer') ? '' : 'display:none'}\">\n <slot name=\"footer\"></slot>\n </div>\n </div>\n\n </div>\n `;\n}"],"names":[],"mappings":";AAIA,MAAM,aAA6B;AAAA;AAAA;AAAA;AAK5B,SAAS,iBAAiB,KAAkC;AACjE,SAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,yBAQgB,IAAI,IAAI;AAAA,sBACX,IAAI,aAAa,IAAI,KAAK;AAAA,kBAC9B,MAAY,IAAI,SAAS;AAAA,oBACvB,CAAC,MAA2B,IAAI,kBAAkB,CAAC,CAAC;AAAA;AAAA,+BAEzC,IAAI,KAAK;AAAA,kDACU,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,iBAQ3C,IAAI,WAAW,kBAAkB,IAAI,QAAQ,KAAK,EAAE;AAAA,oBACjD,CAAC,MAA2B,IAAI,eAAe,CAAC,CAAC;AAAA;AAAA;AAAA;AAAA,mBAIlD,IAAI,SAAS,QAAQ,IAAI,KAAK,cAAc;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAS5C,IAAI,SAAS,QAAQ,IAAI,KAAK,cAAc;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAO/D;"}
package/dist/index207.js CHANGED
@@ -1,14 +1,5 @@
1
- import { html } from "lit";
2
- function glassCardTemplate(_props) {
3
- return html`
4
- <div class="glass-card">
5
- <div class="glass-card__slot">
6
- <slot></slot>
7
- </div>
8
- </div>
9
- `;
10
- }
1
+ const dropdownCss = '@layer tokens,reset,components;@layer reset{:host{display:inline-block;position:relative}*,*:before,*:after{box-sizing:border-box}button{font:inherit;background:none;border:none;padding:0;margin:0;cursor:pointer}}@layer components{.dd{position:relative;display:inline-block;-webkit-user-select:none;user-select:none}.dd-trigger{display:inline-flex;align-items:center;gap:var(--lib-space-sm);font-family:var(--lib-font-mono);font-size:var(--text-xs);letter-spacing:var(--tracking-wider);text-transform:uppercase;cursor:pointer;background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-default);padding:calc(var(--lib-space-sm) + var(--lib-space-xs)) var(--lib-space-md);white-space:nowrap;transition:background var(--duration-base) var(--ease-out),border-color var(--duration-base) var(--ease-out),color var(--duration-base) var(--ease-out)}.dd-trigger:hover{background:var(--bg-surface);border-color:var(--border-strong)}:host([open]) .dd-trigger{background:var(--bg-surface);border-color:var(--color-washi-700)}.dd-trigger:focus-visible{outline:2px solid var(--color-kaki-400);outline-offset:2px}.dd-chevron{display:flex;align-items:center;flex-shrink:0;color:var(--text-muted);transition:transform var(--duration-slow) var(--ease-out);line-height:1}.dd-chevron svg{width:12px;height:12px}:host([open]) .dd-chevron{transform:rotate(180deg)}:host([variant="ghost"]) .dd-trigger{background:transparent;border-color:transparent;color:var(--text-secondary)}:host([variant="ghost"]) .dd-trigger:hover{background:var(--bg-surface);border-color:transparent}:host([variant="ghost"][open]) .dd-trigger{background:var(--bg-surface);border-color:transparent}:host([variant="filled"]) .dd-trigger{background:var(--color-washi-900);border-color:var(--color-washi-900);color:var(--color-washi-50)}:host([variant="filled"]) .dd-trigger:hover{background:var(--color-washi-800);border-color:var(--color-washi-800)}:host([variant="filled"]) .dd-chevron{color:var(--color-washi-400)}:host([variant="kaki"]) .dd-trigger{background:var(--color-kaki-500);border-color:var(--color-kaki-500);color:#fff}:host([variant="kaki"]) .dd-trigger:hover{background:var(--color-kaki-600);border-color:var(--color-kaki-600)}:host([variant="kaki"]) .dd-chevron{color:#fff9}.dd-menu{position:absolute;top:calc(100% + 4px);left:0;z-index:300;min-width:var(--dd-min-width, 200px);background:var(--bg-elevated);border:1px solid var(--border-default);box-shadow:var(--shadow-lg);opacity:0;transform:translateY(-6px) scaleY(.97);transform-origin:top center;pointer-events:none;transition:opacity .16s var(--ease-out),transform .2s var(--ease-out)}:host([open]) .dd-menu{opacity:1;transform:translateY(0) scaleY(1);pointer-events:auto}:host([align="right"]) .dd-menu{left:auto;right:0}::slotted(.dd-item){display:flex!important;align-items:center;gap:.75rem;width:100%;padding:.75rem var(--lib-space-md);font-family:var(--lib-font-body);font-size:var(--text-sm);color:var(--text-secondary);background:transparent;border:none;cursor:pointer;text-align:left;text-decoration:none;white-space:nowrap;transition:background var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}::slotted(.dd-item:hover){background:var(--bg-surface);color:var(--text-primary)}::slotted(.dd-item.is-active){color:var(--text-primary);background:var(--color-washi-100)}::slotted(.dd-item.is-disabled){opacity:.38;cursor:not-allowed;pointer-events:none}::slotted(.dd-item.is-danger){color:var(--color-error)}::slotted(.dd-item.is-danger:hover){background:var(--color-error-light);color:var(--color-error)}::slotted(.dd-sep){display:block!important;height:1px;background:var(--border-subtle);margin:var(--lib-space-xs) 0;border:none}::slotted(.dd-group-label){display:block!important;font-family:var(--lib-font-mono);font-size:9px;letter-spacing:var(--tracking-widest);text-transform:uppercase;color:var(--text-muted);padding:.75rem var(--lib-space-md) var(--lib-space-xs)}.dd-header-wrap{border-bottom:1px solid var(--border-subtle)}.dd-footer-wrap{border-top:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:flex-end;gap:var(--lib-space-sm);padding:var(--lib-space-sm) var(--lib-space-md)}.dd-scroll-wrap{max-height:220px;overflow-y:auto;overscroll-behavior:contain}.dd-scroll-wrap::-webkit-scrollbar{width:4px}.dd-scroll-wrap::-webkit-scrollbar-track{background:transparent}.dd-scroll-wrap::-webkit-scrollbar-thumb{background:var(--color-washi-300);border-radius:2px}:host([dark]) .dd-menu{background:var(--color-washi-900);border-color:var(--color-washi-800)}:host([dark]) .dd-header-wrap{border-color:var(--color-washi-800)}:host([dark]) .dd-footer-wrap{border-color:var(--color-washi-800)}:host([dark]) ::slotted(.dd-item){color:var(--color-washi-400)}:host([dark]) ::slotted(.dd-item:hover){background:var(--color-washi-800);color:var(--color-washi-100)}:host([dark]) ::slotted(.dd-item.is-active){background:var(--color-washi-800);color:var(--color-washi-100)}:host([dark]) ::slotted(.dd-item.is-danger){color:#e87a6a}:host([dark]) ::slotted(.dd-item.is-danger:hover){background:#8c2a1a4d;color:#e87a6a}:host([dark]) ::slotted(.dd-sep){background:var(--color-washi-800)}:host([dark]) ::slotted(.dd-group-label){color:var(--color-washi-600)}}';
11
2
  export {
12
- glassCardTemplate
3
+ dropdownCss as default
13
4
  };
14
5
  //# sourceMappingURL=index207.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index207.js","sources":["../src/components/atoms/card/glass-card/lib-glass-card.html.ts"],"sourcesContent":["import { html, TemplateResult } from 'lit';\nimport type { GlassCardTemplateProps } from './lib-glass-card.types';\n\n/**\n * Template del glass card.\n *\n * Estructura de capas (de abajo a arriba):\n * 1. .glass-card — backdrop-filter + background tintado\n * 2. ::before (CSS) — reflexión de luz (--lib-glass-shine)\n * 3. .glass-card__slot — slot del contenido, z-index: 1\n */\nexport function glassCardTemplate(_props: GlassCardTemplateProps): TemplateResult {\n return html`\n <div class=\"glass-card\">\n <div class=\"glass-card__slot\">\n <slot></slot>\n </div>\n </div>\n `;\n}"],"names":[],"mappings":";AAWO,SAAS,kBAAkB,QAAgD;AAChF,SAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAOT;"}
1
+ {"version":3,"file":"index207.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}