@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/index53.js CHANGED
@@ -1,8 +1,9 @@
1
1
  import { unsafeCSS, css, LitElement } from "lit";
2
- import { property, query, customElement } from "lit/decorators.js";
3
- import { chipTemplate } from "./index291.js";
4
- import chipCss from "./index292.js";
2
+ import { property, state, customElement } from "lit/decorators.js";
3
+ import pickerCss from "./index203.js";
5
4
  import sharedTokens from "./index196.js";
5
+ import { colorPickerTemplate, swatchGridTemplate } from "./index204.js";
6
+ import { SHIBUI_SWATCHES } from "./index205.js";
6
7
  var __defProp = Object.defineProperty;
7
8
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
8
9
  var __decorateClass = (decorators, target, key, kind) => {
@@ -13,88 +14,358 @@ var __decorateClass = (decorators, target, key, kind) => {
13
14
  if (kind && result) __defProp(target, key, result);
14
15
  return result;
15
16
  };
16
- let LibChip = class extends LitElement {
17
+ function hslToHex(h, s, l) {
18
+ const sl = s / 100;
19
+ const ll = l / 100;
20
+ const k = (n) => (n + h / 30) % 12;
21
+ const a = sl * Math.min(ll, 1 - ll);
22
+ const f = (n) => ll - a * Math.max(-1, Math.min(k(n) - 3, Math.min(9 - k(n), 1)));
23
+ return "#" + [f(0), f(8), f(4)].map((x) => Math.round(x * 255).toString(16).padStart(2, "0")).join("").toUpperCase();
24
+ }
25
+ function hexToRgb(hex) {
26
+ const clean = hex.replace("#", "");
27
+ return {
28
+ r: parseInt(clean.slice(0, 2), 16),
29
+ g: parseInt(clean.slice(2, 4), 16),
30
+ b: parseInt(clean.slice(4, 6), 16)
31
+ };
32
+ }
33
+ function hexToHsl(hex) {
34
+ const { r, g, b } = hexToRgb(hex);
35
+ const rn = r / 255;
36
+ const gn = g / 255;
37
+ const bn = b / 255;
38
+ const max = Math.max(rn, gn, bn);
39
+ const min = Math.min(rn, gn, bn);
40
+ let h = 0;
41
+ let s = 0;
42
+ const l = (max + min) / 2;
43
+ if (max !== min) {
44
+ const d = max - min;
45
+ s = l > 0.5 ? d / (2 - max - min) : d / (max + min);
46
+ if (max === rn) h = ((gn - bn) / d + (gn < bn ? 6 : 0)) / 6;
47
+ else if (max === gn) h = ((bn - rn) / d + 2) / 6;
48
+ else h = ((rn - gn) / d + 4) / 6;
49
+ }
50
+ return {
51
+ h: Math.round(h * 360),
52
+ s: Math.round(s * 100),
53
+ l: Math.round(l * 100)
54
+ };
55
+ }
56
+ function isValidHex(v) {
57
+ return /^#[0-9A-Fa-f]{6}$/.test(v);
58
+ }
59
+ let LibColorPicker = class extends LitElement {
17
60
  constructor() {
18
61
  super(...arguments);
19
- this.kind = "static";
20
- this.size = "md";
21
- this.color = "default";
22
- this.selected = false;
23
- this.dot = false;
24
- this.ariaLabel = "";
25
- }
26
- /* ── Toggle ── */
27
- _handleToggle() {
28
- this.selected = !this.selected;
29
- this.dispatchEvent(new CustomEvent("ui-lib-chip-toggle", {
30
- detail: { selected: this.selected },
31
- bubbles: true,
32
- composed: true
33
- }));
62
+ this.value = "#B85A1E";
63
+ this.variant = "inline";
64
+ this.showAlpha = false;
65
+ this.dark = false;
66
+ this.disabled = false;
67
+ this.label = "";
68
+ this.saved = "";
69
+ this._cs = { h: 25, s: 70, l: 36, alpha: 100 };
70
+ this._inputMode = "hex";
71
+ this._open = false;
72
+ this._savedColors = [];
73
+ this._prevCs = { ...this._cs };
74
+ this._dragging = false;
75
+ this._onDocMouseMove = (e) => {
76
+ if (!this._dragging) return;
77
+ this._updateFromCanvasEvent(e);
78
+ };
79
+ this._onDocMouseUp = () => {
80
+ this._dragging = false;
81
+ };
82
+ this._onDocClick = (e) => {
83
+ var _a;
84
+ if (this.variant !== "trigger" || !this._open) return;
85
+ if (!this.contains(e.target) && !(((_a = this.shadowRoot) == null ? void 0 : _a.contains(e.target)) ?? false)) {
86
+ this._cancel();
87
+ }
88
+ };
89
+ this._onKeyDown = (e) => {
90
+ if (e.key === "Escape" && this._open) this._cancel();
91
+ };
34
92
  }
35
- /* ── Remove con animación de salida ── */
36
- _handleRemove(e) {
37
- e.stopPropagation();
38
- const el = this._inputEl;
39
- if (!el) {
40
- this._emitRemove();
41
- return;
93
+ /* ── Lifecycle ── */
94
+ connectedCallback() {
95
+ super.connectedCallback();
96
+ this._initFromValue(this.value);
97
+ if (this.saved) {
98
+ try {
99
+ this._savedColors = JSON.parse(this.saved);
100
+ } catch {
101
+ }
42
102
  }
43
- el.classList.add("is-removing");
44
- el.addEventListener("animationend", () => {
45
- this._emitRemove();
46
- }, { once: true });
47
- }
48
- _emitRemove() {
49
- this.dispatchEvent(new CustomEvent("ui-lib-chip-remove", {
50
- detail: {},
103
+ document.addEventListener("mouseup", this._onDocMouseUp);
104
+ document.addEventListener("mousemove", this._onDocMouseMove);
105
+ document.addEventListener("click", this._onDocClick);
106
+ document.addEventListener("keydown", this._onKeyDown);
107
+ }
108
+ disconnectedCallback() {
109
+ super.disconnectedCallback();
110
+ document.removeEventListener("mouseup", this._onDocMouseUp);
111
+ document.removeEventListener("mousemove", this._onDocMouseMove);
112
+ document.removeEventListener("click", this._onDocClick);
113
+ document.removeEventListener("keydown", this._onKeyDown);
114
+ }
115
+ /* ── API pública ── */
116
+ /** Devuelve el color actual en todos los formatos */
117
+ getValue() {
118
+ return this._buildColorResult();
119
+ }
120
+ /** Establece el color desde hex */
121
+ setValue(hex) {
122
+ this._initFromValue(hex);
123
+ this.requestUpdate();
124
+ }
125
+ /* ── Render ── */
126
+ render() {
127
+ const res = this._buildColorResult();
128
+ return colorPickerTemplate({
129
+ variant: this.variant,
130
+ label: this.label || res.hex,
131
+ panelOpen: this._open,
132
+ hex: res.hex,
133
+ r: res.r,
134
+ g: res.g,
135
+ b: res.b,
136
+ h: res.h,
137
+ s: res.s,
138
+ l: res.l,
139
+ alpha: res.alpha,
140
+ inputMode: this._inputMode,
141
+ savedColors: this._savedColors,
142
+ showAlpha: this.showAlpha,
143
+ onTriggerClick: () => this._togglePanel(),
144
+ onCanvasMousedown: (e) => this._startCanvasDrag(e),
145
+ onHueInput: (e) => this._onHueInput(e),
146
+ onAlphaInput: (e) => this._onAlphaSliderInput(e),
147
+ onModeToggle: () => this._cycleMode(),
148
+ onHexInput: (e) => this._onHexInput(e),
149
+ onRgbInput: (idx, e) => this._onRgbInput(idx, e),
150
+ onHslInput: (idx, e) => this._onHslInput(idx, e),
151
+ onAlphaNumInput: (e) => this._onAlphaNumInput(e),
152
+ onSaveColor: () => this._saveCurrentColor(),
153
+ onSavedClick: (hex) => this._applySavedColor(hex),
154
+ onCancel: () => this._cancel(),
155
+ onApply: () => this._apply()
156
+ });
157
+ }
158
+ /* ── Canvas drag ── */
159
+ _startCanvasDrag(e) {
160
+ this._dragging = true;
161
+ this._updateFromCanvasEvent(e);
162
+ }
163
+ _updateFromCanvasEvent(e) {
164
+ var _a;
165
+ const canvas = (_a = this.shadowRoot) == null ? void 0 : _a.querySelector(".cp-canvas");
166
+ if (!canvas) return;
167
+ const rect = canvas.getBoundingClientRect();
168
+ const x = Math.max(0, Math.min(1, (e.clientX - rect.left) / rect.width));
169
+ const y = Math.max(0, Math.min(1, (e.clientY - rect.top) / rect.height));
170
+ this._cs = {
171
+ ...this._cs,
172
+ s: Math.round(x * 100),
173
+ l: Math.round((1 - y) * 100)
174
+ };
175
+ this._emitChange();
176
+ }
177
+ /* ── Sliders ── */
178
+ _onHueInput(e) {
179
+ this._cs = { ...this._cs, h: parseInt(e.target.value) };
180
+ this._emitChange();
181
+ }
182
+ _onAlphaSliderInput(e) {
183
+ this._cs = { ...this._cs, alpha: parseInt(e.target.value) };
184
+ this._emitChange();
185
+ }
186
+ /* ── Input mode ── */
187
+ _cycleMode() {
188
+ const modes = ["hex", "rgb", "hsl"];
189
+ const i = modes.indexOf(this._inputMode);
190
+ this._inputMode = modes[(i + 1) % modes.length];
191
+ }
192
+ /* ── Text inputs ── */
193
+ _onHexInput(e) {
194
+ const v = e.target.value;
195
+ if (isValidHex(v)) {
196
+ const hsl = hexToHsl(v);
197
+ this._cs = { ...this._cs, ...hsl };
198
+ this._emitChange();
199
+ }
200
+ }
201
+ _onRgbInput(idx, e) {
202
+ const val = parseInt(e.target.value) || 0;
203
+ const clamped = Math.max(0, Math.min(255, val));
204
+ const { r, g, b } = hexToRgb(this._buildHex());
205
+ const rgb = [r, g, b];
206
+ rgb[idx] = clamped;
207
+ const hex = "#" + rgb.map((x) => x.toString(16).padStart(2, "0")).join("").toUpperCase();
208
+ const hsl = hexToHsl(hex);
209
+ this._cs = { ...this._cs, ...hsl };
210
+ this._emitChange();
211
+ }
212
+ _onHslInput(idx, e) {
213
+ const val = parseInt(e.target.value) || 0;
214
+ const maxes = [360, 100, 100];
215
+ const clamped = Math.max(0, Math.min(maxes[idx], val));
216
+ const next = { ...this._cs };
217
+ if (idx === 0) next.h = clamped;
218
+ else if (idx === 1) next.s = clamped;
219
+ else next.l = clamped;
220
+ this._cs = next;
221
+ this._emitChange();
222
+ }
223
+ _onAlphaNumInput(e) {
224
+ const val = parseInt(e.target.value) || 0;
225
+ this._cs = { ...this._cs, alpha: Math.max(0, Math.min(100, val)) };
226
+ this._emitChange();
227
+ }
228
+ /* ── Saved colors ── */
229
+ _saveCurrentColor() {
230
+ const hex = this._buildHex();
231
+ if (!this._savedColors.includes(hex)) {
232
+ this._savedColors = [...this._savedColors, hex];
233
+ }
234
+ }
235
+ _applySavedColor(hex) {
236
+ this._initFromValue(hex);
237
+ this._emitChange();
238
+ }
239
+ /* ── Panel (trigger mode) ── */
240
+ _togglePanel() {
241
+ if (this._open) {
242
+ this._cancel();
243
+ } else {
244
+ this._prevCs = { ...this._cs };
245
+ this._open = true;
246
+ }
247
+ }
248
+ _cancel() {
249
+ this._cs = { ...this._prevCs };
250
+ this._open = false;
251
+ }
252
+ _apply() {
253
+ this._open = false;
254
+ this.dispatchEvent(new CustomEvent("ui-lib-apply", {
255
+ detail: this._buildColorResult(),
51
256
  bubbles: true,
52
257
  composed: true
53
258
  }));
54
259
  }
55
- /* ── Animación de entrada (llamar desde fuera si se crea dinámicamente) ── */
56
- animateIn() {
57
- var _a;
58
- const el = this._inputEl ?? ((_a = this.shadowRoot) == null ? void 0 : _a.querySelector(".chip, .chip-toggle"));
59
- if (!el) return;
60
- el.classList.remove("is-entering");
61
- void el.offsetWidth;
62
- el.classList.add("is-entering");
63
- el.addEventListener("animationend", () => el.classList.remove("is-entering"), { once: true });
260
+ /* ── Helpers ── */
261
+ _initFromValue(hex) {
262
+ if (!isValidHex(hex)) return;
263
+ const hsl = hexToHsl(hex);
264
+ this._cs = { ...this._cs, ...hsl };
64
265
  }
65
- render() {
66
- return chipTemplate(this);
266
+ _buildHex() {
267
+ return hslToHex(this._cs.h, this._cs.s, this._cs.l);
268
+ }
269
+ _buildColorResult() {
270
+ const hex = this._buildHex();
271
+ const { r, g, b } = hexToRgb(hex);
272
+ return { hex, r, g, b, ...this._cs };
273
+ }
274
+ _emitChange() {
275
+ this.dispatchEvent(new CustomEvent("ui-lib-change", {
276
+ detail: this._buildColorResult(),
277
+ bubbles: true,
278
+ composed: true
279
+ }));
67
280
  }
68
281
  };
69
- LibChip.styles = [
282
+ LibColorPicker.styles = [
70
283
  css`${unsafeCSS(sharedTokens)}`,
71
- css`${unsafeCSS(chipCss)}`
284
+ css`${unsafeCSS(pickerCss)}`
72
285
  ];
73
286
  __decorateClass([
74
- property({ type: String, reflect: true })
75
- ], LibChip.prototype, "kind", 2);
287
+ property({ type: String })
288
+ ], LibColorPicker.prototype, "value", 2);
76
289
  __decorateClass([
77
290
  property({ type: String, reflect: true })
78
- ], LibChip.prototype, "size", 2);
291
+ ], LibColorPicker.prototype, "variant", 2);
79
292
  __decorateClass([
80
- property({ type: String, reflect: true })
81
- ], LibChip.prototype, "color", 2);
293
+ property({ type: Boolean, reflect: true, attribute: "show-alpha" })
294
+ ], LibColorPicker.prototype, "showAlpha", 2);
295
+ __decorateClass([
296
+ property({ type: Boolean, reflect: true })
297
+ ], LibColorPicker.prototype, "dark", 2);
82
298
  __decorateClass([
83
299
  property({ type: Boolean, reflect: true })
84
- ], LibChip.prototype, "selected", 2);
300
+ ], LibColorPicker.prototype, "disabled", 2);
301
+ __decorateClass([
302
+ property({ type: String })
303
+ ], LibColorPicker.prototype, "label", 2);
304
+ __decorateClass([
305
+ property({ type: String })
306
+ ], LibColorPicker.prototype, "saved", 2);
307
+ __decorateClass([
308
+ state()
309
+ ], LibColorPicker.prototype, "_cs", 2);
310
+ __decorateClass([
311
+ state()
312
+ ], LibColorPicker.prototype, "_inputMode", 2);
313
+ __decorateClass([
314
+ state()
315
+ ], LibColorPicker.prototype, "_open", 2);
316
+ __decorateClass([
317
+ state()
318
+ ], LibColorPicker.prototype, "_savedColors", 2);
319
+ LibColorPicker = __decorateClass([
320
+ customElement("lib-color-picker")
321
+ ], LibColorPicker);
322
+ let LibColorSwatches = class extends LitElement {
323
+ constructor() {
324
+ super(...arguments);
325
+ this.dark = false;
326
+ this.value = "";
327
+ this.rowsJson = "";
328
+ }
329
+ render() {
330
+ let rows = SHIBUI_SWATCHES;
331
+ if (this.rowsJson) {
332
+ try {
333
+ rows = JSON.parse(this.rowsJson);
334
+ } catch {
335
+ }
336
+ }
337
+ return swatchGridTemplate({
338
+ rows,
339
+ selected: this.value,
340
+ onSelect: (c) => {
341
+ this.value = c.value;
342
+ this.dispatchEvent(new CustomEvent("ui-lib-swatch-click", {
343
+ detail: c,
344
+ bubbles: true,
345
+ composed: true
346
+ }));
347
+ }
348
+ });
349
+ }
350
+ };
351
+ LibColorSwatches.styles = [
352
+ css`${unsafeCSS(sharedTokens)}`,
353
+ css`${unsafeCSS(pickerCss)}`
354
+ ];
85
355
  __decorateClass([
86
356
  property({ type: Boolean, reflect: true })
87
- ], LibChip.prototype, "dot", 2);
357
+ ], LibColorSwatches.prototype, "dark", 2);
88
358
  __decorateClass([
89
- property({ type: String, attribute: "aria-label" })
90
- ], LibChip.prototype, "ariaLabel", 2);
359
+ property({ type: String })
360
+ ], LibColorSwatches.prototype, "value", 2);
91
361
  __decorateClass([
92
- query(".chip-input")
93
- ], LibChip.prototype, "_inputEl", 2);
94
- LibChip = __decorateClass([
95
- customElement("lib-chip")
96
- ], LibChip);
362
+ property({ type: String })
363
+ ], LibColorSwatches.prototype, "rowsJson", 2);
364
+ LibColorSwatches = __decorateClass([
365
+ customElement("lib-color-swatches")
366
+ ], LibColorSwatches);
97
367
  export {
98
- LibChip
368
+ LibColorPicker,
369
+ LibColorSwatches
99
370
  };
100
371
  //# sourceMappingURL=index53.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index53.js","sources":["../src/components/molecules/chip/lib-chip.component.ts"],"sourcesContent":["import { LitElement, css, unsafeCSS, TemplateResult } from 'lit';\nimport { customElement, property, query } from 'lit/decorators.js';\nimport { chipTemplate } from './lib-chip.html';\nimport chipCss from './lib-chip.css?inline';\nimport sharedTokens from '../../../styles/shared/tokens.css?inline';\nimport type { ChipKind, ChipSize, ChipColor } from './lib-chip.types';\n\n/**\n * lib-chip — Chip Shibui (SG-26)\n *\n * Tres familias semánticas controladas por `kind`:\n * - static → etiqueta read-only, taxonomía\n * - toggle → filtro seleccionable (aria-checkbox)\n * - input → tag removible con botón ×\n *\n * @prop kind — 'static' | 'toggle' | 'input'\n * @prop size — 'xs' | 'sm' | 'md' | 'lg'\n * @prop color — 'default' | 'kaki' | 'celadon' | 'error' | 'info' | 'dark'\n * @prop selected — Estado seleccionado (solo kind=toggle)\n * @prop dot — Dot de color antes del texto\n * @prop aria-label — Texto accesible del chip\n *\n * @fires ui-lib-chip-toggle — { detail: { selected: boolean } } (kind=toggle)\n * @fires ui-lib-chip-remove — { detail: {} } (kind=input)\n *\n * @slot — Texto/label del chip\n * @slot icon — Icono a la izquierda del texto\n * @slot avatar — Avatar circular (solo kind=input, opcionalmente static)\n */\n@customElement('lib-chip')\nexport class LibChip extends LitElement {\n static override styles = [\n css`${unsafeCSS(sharedTokens)}`,\n css`${unsafeCSS(chipCss)}`,\n ];\n\n @property({ type: String, reflect: true })\n kind: ChipKind = 'static';\n\n @property({ type: String, reflect: true })\n size: ChipSize = 'md';\n\n @property({ type: String, reflect: true })\n color: ChipColor = 'default';\n\n @property({ type: Boolean, reflect: true })\n selected = false;\n\n @property({ type: Boolean, reflect: true })\n dot = false;\n\n @property({ type: String, attribute: 'aria-label' })\n override ariaLabel = '';\n\n @query('.chip-input')\n declare private _inputEl: HTMLElement | null;\n\n /* ── Toggle ── */\n _handleToggle(): void {\n this.selected = !this.selected;\n this.dispatchEvent(new CustomEvent('ui-lib-chip-toggle', {\n detail: { selected: this.selected },\n bubbles: true,\n composed: true,\n }));\n }\n\n /* ── Remove con animación de salida ── */\n _handleRemove(e: MouseEvent): void {\n e.stopPropagation();\n const el = this._inputEl;\n if (!el) {\n this._emitRemove();\n return;\n }\n el.classList.add('is-removing');\n el.addEventListener('animationend', (): void => {\n this._emitRemove();\n }, { once: true });\n }\n\n private _emitRemove(): void {\n this.dispatchEvent(new CustomEvent('ui-lib-chip-remove', {\n detail: {},\n bubbles: true,\n composed: true,\n }));\n }\n\n /* ── Animación de entrada (llamar desde fuera si se crea dinámicamente) ── */\n animateIn(): void {\n const el = this._inputEl ?? this.shadowRoot?.querySelector('.chip, .chip-toggle') as HTMLElement | null;\n if (!el) return;\n el.classList.remove('is-entering');\n void el.offsetWidth; // reflow\n el.classList.add('is-entering');\n el.addEventListener('animationend', (): void => el.classList.remove('is-entering'), { once: true });\n }\n\n protected override render(): TemplateResult {\n return chipTemplate(this);\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'lib-chip': LibChip;\n }\n}"],"names":[],"mappings":";;;;;;;;;;;;;;;AA8BO,IAAM,UAAN,cAAsB,WAAW;AAAA,EAAjC,cAAA;AAAA,UAAA,GAAA,SAAA;AAOL,SAAA,OAAiB;AAGjB,SAAA,OAAiB;AAGjB,SAAA,QAAmB;AAGnB,SAAA,WAAW;AAGX,SAAA,MAAM;AAGN,SAAS,YAAY;AAAA,EAAA;AAAA;AAAA,EAMrB,gBAAsB;AACpB,SAAK,WAAW,CAAC,KAAK;AACtB,SAAK,cAAc,IAAI,YAAY,sBAAsB;AAAA,MACvD,QAAQ,EAAE,UAAU,KAAK,SAAA;AAAA,MACzB,SAAS;AAAA,MACT,UAAU;AAAA,IAAA,CACX,CAAC;AAAA,EACJ;AAAA;AAAA,EAGA,cAAc,GAAqB;AACjC,MAAE,gBAAA;AACF,UAAM,KAAK,KAAK;AAChB,QAAI,CAAC,IAAI;AACP,WAAK,YAAA;AACL;AAAA,IACF;AACA,OAAG,UAAU,IAAI,aAAa;AAC9B,OAAG,iBAAiB,gBAAgB,MAAY;AAC9C,WAAK,YAAA;AAAA,IACP,GAAG,EAAE,MAAM,MAAM;AAAA,EACnB;AAAA,EAEQ,cAAoB;AAC1B,SAAK,cAAc,IAAI,YAAY,sBAAsB;AAAA,MACvD,QAAQ,CAAA;AAAA,MACR,SAAS;AAAA,MACT,UAAU;AAAA,IAAA,CACX,CAAC;AAAA,EACJ;AAAA;AAAA,EAGA,YAAkB;;AAChB,UAAM,KAAK,KAAK,cAAY,UAAK,eAAL,mBAAiB,cAAc;AAC3D,QAAI,CAAC,GAAI;AACT,OAAG,UAAU,OAAO,aAAa;AACjC,SAAK,GAAG;AACR,OAAG,UAAU,IAAI,aAAa;AAC9B,OAAG,iBAAiB,gBAAgB,MAAY,GAAG,UAAU,OAAO,aAAa,GAAG,EAAE,MAAM,KAAA,CAAM;AAAA,EACpG;AAAA,EAEmB,SAAyB;AAC1C,WAAO,aAAa,IAAI;AAAA,EAC1B;AACF;AAxEa,QACK,SAAS;AAAA,EACvB,MAAM,UAAU,YAAY,CAAC;AAAA,EAC7B,MAAM,UAAU,OAAO,CAAC;AAC1B;AAGA,gBAAA;AAAA,EADC,SAAS,EAAE,MAAM,QAAQ,SAAS,MAAM;AAAA,GAN9B,QAOX,WAAA,QAAA,CAAA;AAGA,gBAAA;AAAA,EADC,SAAS,EAAE,MAAM,QAAQ,SAAS,MAAM;AAAA,GAT9B,QAUX,WAAA,QAAA,CAAA;AAGA,gBAAA;AAAA,EADC,SAAS,EAAE,MAAM,QAAQ,SAAS,MAAM;AAAA,GAZ9B,QAaX,WAAA,SAAA,CAAA;AAGA,gBAAA;AAAA,EADC,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GAf/B,QAgBX,WAAA,YAAA,CAAA;AAGA,gBAAA;AAAA,EADC,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GAlB/B,QAmBX,WAAA,OAAA,CAAA;AAGS,gBAAA;AAAA,EADR,SAAS,EAAE,MAAM,QAAQ,WAAW,cAAc;AAAA,GArBxC,QAsBF,WAAA,aAAA,CAAA;AAGO,gBAAA;AAAA,EADf,MAAM,aAAa;AAAA,GAxBT,QAyBK,WAAA,YAAA,CAAA;AAzBL,UAAN,gBAAA;AAAA,EADN,cAAc,UAAU;AAAA,GACZ,OAAA;"}
1
+ {"version":3,"file":"index53.js","sources":["../src/components/molecules/color-picker/lib-color-picker.component.ts"],"sourcesContent":["import { LitElement, css, unsafeCSS, TemplateResult } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport pickerCss from './lib-color-picker.css?inline';\nimport sharedTokens from '../../../styles/shared/tokens.css?inline';\nimport { colorPickerTemplate, swatchGridTemplate } from './lib-color-picker.html';\nimport { SHIBUI_SWATCHES } from './lib-color-picker.types';\nimport type {\n ColorPickerVariant,\n ColorInputMode,\n SwatchRow,\n SwatchColor,\n ColorState,\n} from './lib-color-picker.types';\n\n/* ──────────────────────────────────────\n Color conversion utilities\n ────────────────────────────────────── */\nfunction hslToHex(h: number, s: number, l: number): string {\n const sl = s / 100;\n const ll = l / 100;\n const k = (n: number): number => (n + h / 30) % 12;\n const a = sl * Math.min(ll, 1 - ll);\n const f = (n: number): number =>\n ll - a * Math.max(-1, Math.min(k(n) - 3, Math.min(9 - k(n), 1)));\n return '#' + ([f(0), f(8), f(4)] as number[])\n .map(x => Math.round(x * 255).toString(16).padStart(2, '0'))\n .join('')\n .toUpperCase();\n}\n\nfunction hexToRgb(hex: string): { r: number; g: number; b: number } {\n const clean = hex.replace('#', '');\n return {\n r: parseInt(clean.slice(0, 2), 16),\n g: parseInt(clean.slice(2, 4), 16),\n b: parseInt(clean.slice(4, 6), 16),\n };\n}\n\nfunction hexToHsl(hex: string): { h: number; s: number; l: number } {\n const { r, g, b } = hexToRgb(hex);\n const rn = r / 255; const gn = g / 255; const bn = b / 255;\n const max = Math.max(rn, gn, bn);\n const min = Math.min(rn, gn, bn);\n let h = 0; let s = 0;\n const l = (max + min) / 2;\n\n if (max !== min) {\n const d = max - min;\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n if (max === rn) h = ((gn - bn) / d + (gn < bn ? 6 : 0)) / 6;\n else if (max === gn) h = ((bn - rn) / d + 2) / 6;\n else h = ((rn - gn) / d + 4) / 6;\n }\n return {\n h: Math.round(h * 360),\n s: Math.round(s * 100),\n l: Math.round(l * 100),\n };\n}\n\nfunction isValidHex(v: string): boolean {\n return /^#[0-9A-Fa-f]{6}$/.test(v);\n}\n\n/**\n * @element lib-color-picker\n *\n * Selector de color con canvas 2D (saturación/luminosidad), slider de tono,\n * slider de opacidad, inputs HEX/RGB/HSL intercambiables y colores guardados.\n *\n * @prop {string} value — Color inicial en HEX (#RRGGBB)\n * @prop {ColorPickerVariant} variant — inline · trigger (default: inline)\n * @prop {boolean} show-alpha— Mostrar slider y campo de opacidad\n * @prop {boolean} dark — Modo oscuro\n * @prop {boolean} disabled — Desactivado\n * @prop {string} label — Texto del trigger (variant=trigger)\n * @prop {string} saved — Colores guardados iniciales (JSON array)\n *\n * @fires ui-lib-change — {detail: {value: string, hex: string, r, g, b, h, s, l, alpha}}\n * @fires ui-lib-apply — Igual a change pero solo al pulsar \"Aplicar\"\n * @fires ui-lib-swatch-click — {detail: {value: string, name?: string}} al clickar un swatch\n *\n * @method getValue() — Devuelve el color actual como {hex, r, g, b, h, s, l, alpha}\n * @method setValue(hex)— Establece el color programáticamente\n */\n@customElement('lib-color-picker')\nexport class LibColorPicker extends LitElement {\n static override styles = [\n css`${unsafeCSS(sharedTokens)}`,\n css`${unsafeCSS(pickerCss)}`,\n ];\n\n /* ── Props ── */\n\n @property({ type: String })\n value = '#B85A1E';\n\n @property({ type: String, reflect: true })\n variant: ColorPickerVariant = 'inline';\n\n @property({ type: Boolean, reflect: true, attribute: 'show-alpha' })\n showAlpha = false;\n\n @property({ type: Boolean, reflect: true })\n dark = false;\n\n @property({ type: Boolean, reflect: true })\n disabled = false;\n\n @property({ type: String })\n label = '';\n\n /** Colores guardados iniciales — JSON array, e.g. '[\"#B85A1E\",\"#357164\"]' */\n @property({ type: String })\n saved = '';\n\n /* ── Internal state ── */\n\n @state() private _cs: ColorState = { h: 25, s: 70, l: 36, alpha: 100 };\n @state() private _inputMode: ColorInputMode = 'hex';\n @state() private _open = false;\n @state() private _savedColors: string[] = [];\n\n /** Color anterior al abrir, para cancelar */\n private _prevCs: ColorState = { ...this._cs };\n\n /** Dragging en el canvas */\n private _dragging = false;\n\n /* ── Lifecycle ── */\n\n override connectedCallback(): void {\n super.connectedCallback();\n this._initFromValue(this.value);\n\n if (this.saved) {\n try { this._savedColors = JSON.parse(this.saved) as string[]; }\n catch { /* ignore */ }\n }\n\n document.addEventListener('mouseup', this._onDocMouseUp);\n document.addEventListener('mousemove', this._onDocMouseMove);\n document.addEventListener('click', this._onDocClick);\n document.addEventListener('keydown', this._onKeyDown);\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n document.removeEventListener('mouseup', this._onDocMouseUp);\n document.removeEventListener('mousemove', this._onDocMouseMove);\n document.removeEventListener('click', this._onDocClick);\n document.removeEventListener('keydown', this._onKeyDown);\n }\n\n /* ── API pública ── */\n\n /** Devuelve el color actual en todos los formatos */\n public getValue(): { hex: string; r: number; g: number; b: number; h: number; s: number; l: number; alpha: number } {\n return this._buildColorResult();\n }\n\n /** Establece el color desde hex */\n public setValue(hex: string): void {\n this._initFromValue(hex);\n this.requestUpdate();\n }\n\n /* ── Render ── */\n\n protected override render(): TemplateResult {\n const res = this._buildColorResult();\n\n return colorPickerTemplate({\n variant: this.variant,\n label: this.label || res.hex,\n panelOpen: this._open,\n hex: res.hex, r: res.r, g: res.g, b: res.b,\n h: res.h, s: res.s, l: res.l,\n alpha: res.alpha,\n inputMode: this._inputMode,\n savedColors: this._savedColors,\n showAlpha: this.showAlpha,\n\n onTriggerClick: (): void => this._togglePanel(),\n onCanvasMousedown: (e: MouseEvent): void => this._startCanvasDrag(e),\n onHueInput: (e: Event): void => this._onHueInput(e),\n onAlphaInput: (e: Event): void => this._onAlphaSliderInput(e),\n onModeToggle: (): void => this._cycleMode(),\n onHexInput: (e: Event): void => this._onHexInput(e),\n onRgbInput: (idx: 0|1|2, e: Event): void => this._onRgbInput(idx, e),\n onHslInput: (idx: 0|1|2, e: Event): void => this._onHslInput(idx, e),\n onAlphaNumInput: (e: Event): void => this._onAlphaNumInput(e),\n onSaveColor: (): void => this._saveCurrentColor(),\n onSavedClick: (hex: string): void => this._applySavedColor(hex),\n onCancel: (): void => this._cancel(),\n onApply: (): void => this._apply(),\n });\n }\n\n /* ── Canvas drag ── */\n\n private _startCanvasDrag(e: MouseEvent): void {\n this._dragging = true;\n this._updateFromCanvasEvent(e);\n }\n\n private _onDocMouseMove = (e: MouseEvent): void => {\n if (!this._dragging) return;\n this._updateFromCanvasEvent(e);\n };\n\n private _onDocMouseUp = (): void => { this._dragging = false; };\n\n private _updateFromCanvasEvent(e: MouseEvent): void {\n const canvas = this.shadowRoot?.querySelector('.cp-canvas');\n if (!canvas) return;\n const rect = canvas.getBoundingClientRect();\n const x = Math.max(0, Math.min(1, (e.clientX - rect.left) / rect.width));\n const y = Math.max(0, Math.min(1, (e.clientY - rect.top) / rect.height));\n this._cs = {\n ...this._cs,\n s: Math.round(x * 100),\n l: Math.round((1 - y) * 100),\n };\n this._emitChange();\n }\n\n /* ── Sliders ── */\n\n private _onHueInput(e: Event): void {\n this._cs = { ...this._cs, h: parseInt((e.target as HTMLInputElement).value) };\n this._emitChange();\n }\n\n private _onAlphaSliderInput(e: Event): void {\n this._cs = { ...this._cs, alpha: parseInt((e.target as HTMLInputElement).value) };\n this._emitChange();\n }\n\n /* ── Input mode ── */\n\n private _cycleMode(): void {\n const modes: ColorInputMode[] = ['hex', 'rgb', 'hsl'];\n const i = modes.indexOf(this._inputMode);\n this._inputMode = modes[(i + 1) % modes.length]!;\n }\n\n /* ── Text inputs ── */\n\n private _onHexInput(e: Event): void {\n const v = (e.target as HTMLInputElement).value;\n if (isValidHex(v)) {\n const hsl = hexToHsl(v);\n this._cs = { ...this._cs, ...hsl };\n this._emitChange();\n }\n }\n\n private _onRgbInput(idx: 0|1|2, e: Event): void {\n const val = parseInt((e.target as HTMLInputElement).value) || 0;\n const clamped = Math.max(0, Math.min(255, val));\n const { r, g, b } = hexToRgb(this._buildHex());\n const rgb: [number, number, number] = [r, g, b];\n rgb[idx] = clamped;\n const hex = '#' + (rgb as number[]).map(x => x.toString(16).padStart(2, '0')).join('').toUpperCase();\n const hsl = hexToHsl(hex);\n this._cs = { ...this._cs, ...hsl };\n this._emitChange();\n }\n\n private _onHslInput(idx: 0|1|2, e: Event): void {\n const val = parseInt((e.target as HTMLInputElement).value) || 0;\n const maxes: [number, number, number] = [360, 100, 100];\n const clamped = Math.max(0, Math.min(maxes[idx]!, val));\n const next = { ...this._cs };\n if (idx === 0) next.h = clamped;\n else if (idx === 1) next.s = clamped;\n else next.l = clamped;\n this._cs = next;\n this._emitChange();\n }\n\n private _onAlphaNumInput(e: Event): void {\n const val = parseInt((e.target as HTMLInputElement).value) || 0;\n this._cs = { ...this._cs, alpha: Math.max(0, Math.min(100, val)) };\n this._emitChange();\n }\n\n /* ── Saved colors ── */\n\n private _saveCurrentColor(): void {\n const hex = this._buildHex();\n if (!this._savedColors.includes(hex)) {\n this._savedColors = [...this._savedColors, hex];\n }\n }\n\n private _applySavedColor(hex: string): void {\n this._initFromValue(hex);\n this._emitChange();\n }\n\n /* ── Panel (trigger mode) ── */\n\n private _togglePanel(): void {\n if (this._open) {\n this._cancel();\n } else {\n this._prevCs = { ...this._cs };\n this._open = true;\n }\n }\n\n private _cancel(): void {\n this._cs = { ...this._prevCs };\n this._open = false;\n }\n\n private _apply(): void {\n this._open = false;\n this.dispatchEvent(new CustomEvent('ui-lib-apply', {\n detail: this._buildColorResult(),\n bubbles: true,\n composed: true,\n }));\n }\n\n /* ── Close on outside click / Escape ── */\n\n private _onDocClick = (e: MouseEvent): void => {\n if (this.variant !== 'trigger' || !this._open) return;\n if (!this.contains(e.target as Node) && !(this.shadowRoot?.contains(e.target as Node) ?? false)) {\n this._cancel();\n }\n };\n\n private _onKeyDown = (e: KeyboardEvent): void => {\n if (e.key === 'Escape' && this._open) this._cancel();\n };\n\n /* ── Helpers ── */\n\n private _initFromValue(hex: string): void {\n if (!isValidHex(hex)) return;\n const hsl = hexToHsl(hex);\n this._cs = { ...this._cs, ...hsl };\n }\n\n private _buildHex(): string {\n return hslToHex(this._cs.h, this._cs.s, this._cs.l);\n }\n\n private _buildColorResult(): { hex: string; r: number; g: number; b: number; h: number; s: number; l: number; alpha: number } {\n const hex = this._buildHex();\n const { r, g, b } = hexToRgb(hex);\n return { hex, r, g, b, ...this._cs };\n }\n\n private _emitChange(): void {\n this.dispatchEvent(new CustomEvent('ui-lib-change', {\n detail: this._buildColorResult(),\n bubbles: true,\n composed: true,\n }));\n }\n}\n\n/* ──────────────────────────────────────\n Swatch-only component\n ────────────────────────────────────── */\n\n/**\n * @element lib-color-swatches\n *\n * Cuadrícula de swatches de color. Puede usarse de forma independiente o\n * para mostrar la paleta del design system.\n *\n * @prop {boolean} dark\n * @prop {string} value — Color seleccionado (hex)\n *\n * @fires ui-lib-swatch-click — {detail: {value, name}}\n */\n@customElement('lib-color-swatches')\nexport class LibColorSwatches extends LitElement {\n static override styles = [\n css`${unsafeCSS(sharedTokens)}`,\n css`${unsafeCSS(pickerCss)}`,\n ];\n\n @property({ type: Boolean, reflect: true }) dark = false;\n @property({ type: String }) value = '';\n @property({ type: String }) rowsJson = '';\n\n protected override render(): TemplateResult {\n let rows: SwatchRow[] = SHIBUI_SWATCHES;\n if (this.rowsJson) {\n try { rows = JSON.parse(this.rowsJson) as SwatchRow[]; } catch { /* ignore */ }\n }\n return swatchGridTemplate({\n rows,\n selected: this.value,\n onSelect: (c: SwatchColor): void => {\n this.value = c.value;\n this.dispatchEvent(new CustomEvent('ui-lib-swatch-click', {\n detail: c, bubbles: true, composed: true,\n }));\n },\n });\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'lib-color-picker': LibColorPicker;\n 'lib-color-swatches': LibColorSwatches;\n }\n}"],"names":[],"mappings":"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"}