@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
@@ -1 +1 @@
1
- {"version":3,"file":"index58.js","sources":["../src/components/molecules/tree-select/lib-tree-select.component.html.ts"],"sourcesContent":["import { html, nothing, TemplateResult } from 'lit';\nimport { map } from 'lit/directives/map.js';\nimport type {\n TreeNode,\n TreeNodeState,\n TreeSelectTemplateProps,\n RenderNodeCtx,\n} from './lib-tree-node.types';\n\n/* ──────────────────────────────────────────────────────────────\n HELPERS\n────────────────────────────────────────────────────────────── */\n\nfunction nodeMatchesSearch(node: TreeNode, term: string): boolean {\n if (!term) return true;\n const t = term.toLowerCase();\n if (node.label.toLowerCase().includes(t)) return true;\n return node.children?.some(c => nodeMatchesSearch(c, term)) ?? false;\n}\n\nfunction highlightLabel(label: string, term: string): TemplateResult {\n if (!term) return html`${label}`;\n const idx = label.toLowerCase().indexOf(term.toLowerCase());\n if (idx === -1) return html`${label}`;\n return html`${label.slice(0, idx)}<mark>${label.slice(idx, idx + term.length)}</mark>${label.slice(idx + term.length)}`;\n}\n\n/* ──────────────────────────────────────────────────────────────\n RENDERIZADO RECURSIVO DE NODO\n────────────────────────────────────────────────────────────── */\n\nfunction renderNode(\n node: TreeNode,\n ctx: RenderNodeCtx,\n depth: number,\n ancestorIsLast: boolean[],\n isLast: boolean,\n): TemplateResult | typeof nothing {\n\n if (ctx.searchValue && !nodeMatchesSearch(node, ctx.searchValue)) return nothing;\n\n const st: TreeNodeState = ctx.nodeStates.get(node.id)\n ?? { selected: false, indeterminate: false, expanded: false };\n\n const hasKids = (node.children?.length ?? 0) > 0;\n const isExpanded = ctx.searchValue ? hasKids : st.expanded;\n\n /* ── Líneas de indentación (estética bambú) ── */\n const indent: TemplateResult | typeof nothing = depth > 0\n ? html`<div class=\"ts-indent\">${\n Array.from({ length: depth }, (_, i) => {\n const isLastUnit = i === depth - 1;\n const ancestorWasLast = ancestorIsLast[i] ?? false;\n const cls = [\n 'ts-indent-unit',\n ancestorWasLast ? 'ts-indent-no-line' : '',\n isLastUnit ? 'ts-indent-last' : '',\n isLastUnit && isLast ? 'ts-indent-last-child' : '',\n ].filter(Boolean).join(' ');\n return html`<div class=\"${cls}\"></div>`;\n })\n }</div>`\n : nothing;\n\n /* ── Toggle expand/collapse ── */\n const toggle: TemplateResult = hasKids\n ? html`\n <div\n class=\"ts-toggle\"\n @click=\"${(e: Event): void => { e.stopPropagation(); ctx.onToggle(node.id); }}\"\n aria-label=\"${isExpanded ? 'Colapsar' : 'Expandir'}\"\n >\n <svg class=\"ts-toggle-icon\" viewBox=\"0 0 8 8\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\">\n <path d=\"M2 1.5l3 2.5-3 2.5\"/>\n </svg>\n </div>`\n : html`<div class=\"ts-toggle-spacer\"></div>`;\n\n /* ── Checkbox (solo en modo multi) ── */\n const checkbox: TemplateResult | typeof nothing = ctx.multi\n ? html`\n <div class=\"ts-checkbox\">\n <svg class=\"ts-checkbox-check\" viewBox=\"0 0 10 10\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <path d=\"M1.5 5l2.5 2.5L8.5 2\"/>\n </svg>\n <div class=\"ts-checkbox-dash\"></div>\n </div>`\n : nothing;\n\n /* ── Row classes ── */\n const rowCls = [\n 'ts-node-row',\n st.selected && !st.indeterminate ? 'is-selected' : '',\n st.indeterminate ? 'is-indeterminate' : '',\n ].filter(Boolean).join(' ');\n\n /* ── Badge (número de hijos directos) ── */\n const badge: TemplateResult | typeof nothing = hasKids\n ? html`<span class=\"ts-node-badge\">${node.children!.length}</span>`\n : nothing;\n\n /* ── Hijos (siempre en DOM, animados con grid-template-rows) ── */\n const childAncestors = [...ancestorIsLast, isLast];\n const children: TemplateResult | typeof nothing = hasKids\n ? html`\n <div class=\"ts-children\">\n <div class=\"ts-children-inner\">\n ${map(node.children!, (child, ci) =>\n renderNode(child, ctx, depth + 1, childAncestors, ci === node.children!.length - 1)\n )}\n </div>\n </div>`\n : nothing;\n\n return html`\n <div class=\"ts-node ${isExpanded ? 'is-expanded' : ''}\">\n <div class=\"${rowCls}\" @click=\"${(): void => ctx.onSelect(node)}\">\n ${indent}\n ${toggle}\n ${checkbox}\n <span class=\"ts-node-label\">${highlightLabel(node.label, ctx.searchValue)}</span>\n ${badge}\n </div>\n ${children}\n </div>\n `;\n}\n\n/* ──────────────────────────────────────────────────────────────\n ÁRBOL COMPLETO\n────────────────────────────────────────────────────────────── */\nfunction renderTree(props: TreeSelectTemplateProps): TemplateResult {\n const ctx: RenderNodeCtx = {\n nodeStates: props.nodeStates,\n multi: props.multi,\n searchValue: props.searchValue,\n onToggle: props.onToggle,\n onSelect: props.onSelect,\n };\n\n const visibleNodes = props.nodes.filter(n =>\n !props.searchValue || nodeMatchesSearch(n, props.searchValue)\n );\n\n if (visibleNodes.length === 0) {\n return html`<div class=\"ts-empty\">${props.emptyText}</div>`;\n }\n\n return html`${map(visibleNodes, (node, i) =>\n renderNode(node, ctx, 0, [], i === visibleNodes.length - 1)\n )}`;\n}\n\n/* ──────────────────────────────────────────────────────────────\n BÚSQUEDA\n────────────────────────────────────────────────────────────── */\nfunction renderSearch(props: TreeSelectTemplateProps): TemplateResult | typeof nothing {\n if (!props.searchable) return nothing;\n return html`\n <div class=\"ts-search-wrap\">\n <svg class=\"ts-search-icon\" width=\"13\" height=\"13\" viewBox=\"0 0 16 16\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\">\n <circle cx=\"7\" cy=\"7\" r=\"5\"/><path d=\"M12 12l2.5 2.5\"/>\n </svg>\n <input\n class=\"ts-search\"\n type=\"text\"\n placeholder=\"Buscar…\"\n .value=\"${props.searchValue}\"\n autocomplete=\"off\"\n @input=\"${(e: Event): void => props.onSearch((e.target as HTMLInputElement).value)}\"\n >\n </div>\n `;\n}\n\n/* ──────────────────────────────────────────────────────────────\n FOOTER (solo en multi)\n────────────────────────────────────────────────────────────── */\nfunction renderFooter(props: TreeSelectTemplateProps): TemplateResult | typeof nothing {\n if (!props.multi) return nothing;\n return html`\n <div class=\"ts-footer\">\n <span class=\"ts-footer-info\">${props.footerInfo}</span>\n <div class=\"ts-footer-actions\">\n <button class=\"ts-btn\" @click=\"${props.onClear}\">Limpiar</button>\n ${props.inline\n ? nothing\n : html`<button class=\"ts-btn ts-btn-confirm\" @click=\"${props.onConfirm}\">Aplicar</button>`}\n </div>\n </div>\n `;\n}\n\n/* ──────────────────────────────────────────────────────────────\n TAGS (multi dropdown — debajo del trigger)\n────────────────────────────────────────────────────────────── */\nfunction renderTags(props: TreeSelectTemplateProps): TemplateResult | typeof nothing {\n if (!props.multi || props.inline) return nothing;\n return html`\n <div class=\"ts-tags\">\n ${map(props.tags, tag => html`\n <div class=\"ts-tag\">\n ${tag.label}\n <span class=\"ts-tag-remove\" @click=\"${(): void => props.onTagRemove(tag.id)}\">×</span>\n </div>\n `)}\n </div>\n `;\n}\n\n/* ──────────────────────────────────────────────────────────────\n TEMPLATE PRINCIPAL\n────────────────────────────────────────────────────────────── */\nexport function treeSelectTemplate(props: TreeSelectTemplateProps): TemplateResult {\n\n /* ── Modo INLINE ── */\n if (props.inline) {\n return html`\n <div class=\"ts-inline\">\n ${renderSearch(props)}\n <div class=\"ts-tree\">${renderTree(props)}</div>\n ${renderFooter(props)}\n </div>\n `;\n }\n\n /* ── Modo DROPDOWN ── */\n return html`\n <div class=\"ts-wrap\">\n\n <div\n class=\"ts-trigger\"\n @click=\"${props.onTriggerClick}\"\n aria-haspopup=\"listbox\"\n aria-expanded=\"${props.open}\"\n >\n <span class=\"ts-trigger-label ${props.isPlaceholder ? 'is-placeholder' : ''}\">\n ${props.isPlaceholder ? props.placeholder : props.triggerLabel}\n </span>\n\n ${props.multi && props.selectionCount > 0\n ? html`<span class=\"ts-trigger-count\">${props.selectionCount}</span>`\n : nothing}\n\n <svg class=\"ts-trigger-chevron\" width=\"14\" height=\"14\" viewBox=\"0 0 16 16\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\">\n <path d=\"M3 6l5 5 5-5\"/>\n </svg>\n </div>\n\n <div class=\"ts-dropdown\" role=\"listbox\">\n ${renderSearch(props)}\n <div class=\"ts-tree\">${renderTree(props)}</div>\n ${renderFooter(props)}\n </div>\n\n </div>\n\n ${renderTags(props)}\n `;\n}"],"names":["map"],"mappings":"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"}
1
+ {"version":3,"file":"index58.js","sources":["../src/components/molecules/input/lib-input.component.ts"],"sourcesContent":["import { LitElement, css, unsafeCSS, TemplateResult } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport sharedTokens from '../../../styles/shared/tokens.css?inline';\nimport inputStyles from './lib-input.css?inline';\nimport { inputTemplate } from './lib-input.html';\n\nexport interface LibInputEventDetail {\n value: string;\n}\n\n/**\n * @element lib-input\n * @fires ui-lib-input - Evento disparado al cambiar el valor del input.\n * @slot prefix - Icono o elemento antes del input.\n * @slot suffix - Icono o elemento después del input.\n */\n@customElement('lib-input')\nexport class LibInput extends LitElement {\n static override styles = [\n css`${unsafeCSS(sharedTokens)}`,\n css`${unsafeCSS(inputStyles)}`,\n ];\n\n @property({ type: String }) label = '';\n @property({ type: String }) placeholder = '';\n @property({ type: String }) type: 'text' | 'email' | 'password' = 'text';\n @property({ type: Boolean, reflect: true }) required = false;\n @property({ type: Boolean, reflect: true }) disabled = false;\n @property({ type: Boolean, reflect: true }) error = false;\n @property({ type: String }) errorMessage = '';\n @property({ type: String }) value = '';\n\n @state() private _showPassword = false;\n\n private readonly _uuid = `lib-input-${Math.random().toString(36).slice(2, 9)}`;\n\n override render(): TemplateResult {\n return inputTemplate({\n uuid: this._uuid,\n type: this.type,\n label: this.label,\n placeholder: this.placeholder,\n required: this.required,\n disabled: this.disabled,\n error: this.error,\n errorMessage: this.errorMessage,\n value: this.value,\n showPassword: this._showPassword,\n handleInput: this._handleInput.bind(this),\n handleTogglePassword: this._handleTogglePassword.bind(this),\n });\n }\n\n private _handleInput(e: InputEvent): void {\n const target = e.target as HTMLInputElement;\n this.value = target.value;\n\n this.dispatchEvent(\n new CustomEvent<LibInputEventDetail>('ui-lib-input', {\n detail: { value: this.value },\n bubbles: true,\n composed: true,\n })\n );\n }\n\n private _handleTogglePassword(): void {\n this._showPassword = !this._showPassword;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'lib-input': LibInput;\n }\n}"],"names":[],"mappings":";;;;;;;;;;;;;;;AAiBO,IAAM,WAAN,cAAuB,WAAW;AAAA,EAAlC,cAAA;AAAA,UAAA,GAAA,SAAA;AAMuB,SAAA,QAAQ;AACR,SAAA,cAAc;AACd,SAAA,OAAsC;AACtB,SAAA,WAAW;AACX,SAAA,WAAW;AACX,SAAA,QAAQ;AACxB,SAAA,eAAe;AACf,SAAA,QAAQ;AAE3B,SAAQ,gBAAgB;AAEjC,SAAiB,QAAQ,aAAa,KAAK,OAAA,EAAS,SAAS,EAAE,EAAE,MAAM,GAAG,CAAC,CAAC;AAAA,EAAA;AAAA,EAEnE,SAAyB;AAChC,WAAO,cAAc;AAAA,MACnB,MAAM,KAAK;AAAA,MACX,MAAM,KAAK;AAAA,MACX,OAAO,KAAK;AAAA,MACZ,aAAa,KAAK;AAAA,MAClB,UAAU,KAAK;AAAA,MACf,UAAU,KAAK;AAAA,MACf,OAAO,KAAK;AAAA,MACZ,cAAc,KAAK;AAAA,MACnB,OAAO,KAAK;AAAA,MACZ,cAAc,KAAK;AAAA,MACnB,aAAa,KAAK,aAAa,KAAK,IAAI;AAAA,MACxC,sBAAsB,KAAK,sBAAsB,KAAK,IAAI;AAAA,IAAA,CAC3D;AAAA,EACH;AAAA,EAEQ,aAAa,GAAqB;AACxC,UAAM,SAAS,EAAE;AACjB,SAAK,QAAQ,OAAO;AAEpB,SAAK;AAAA,MACH,IAAI,YAAiC,gBAAgB;AAAA,QACnD,QAAQ,EAAE,OAAO,KAAK,MAAA;AAAA,QACtB,SAAS;AAAA,QACT,UAAU;AAAA,MAAA,CACX;AAAA,IAAA;AAAA,EAEL;AAAA,EAEQ,wBAA8B;AACpC,SAAK,gBAAgB,CAAC,KAAK;AAAA,EAC7B;AACF;AApDa,SACK,SAAS;AAAA,EACvB,MAAM,UAAU,YAAY,CAAC;AAAA,EAC7B,MAAM,UAAU,WAAW,CAAC;AAC9B;AAE4B,gBAAA;AAAA,EAA3B,SAAS,EAAE,MAAM,OAAA,CAAQ;AAAA,GANf,SAMiB,WAAA,SAAA,CAAA;AACA,gBAAA;AAAA,EAA3B,SAAS,EAAE,MAAM,OAAA,CAAQ;AAAA,GAPf,SAOiB,WAAA,eAAA,CAAA;AACA,gBAAA;AAAA,EAA3B,SAAS,EAAE,MAAM,OAAA,CAAQ;AAAA,GARf,SAQiB,WAAA,QAAA,CAAA;AACgB,gBAAA;AAAA,EAA3C,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GAT/B,SASiC,WAAA,YAAA,CAAA;AACA,gBAAA;AAAA,EAA3C,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GAV/B,SAUiC,WAAA,YAAA,CAAA;AACA,gBAAA;AAAA,EAA3C,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GAX/B,SAWiC,WAAA,SAAA,CAAA;AAChB,gBAAA;AAAA,EAA3B,SAAS,EAAE,MAAM,OAAA,CAAQ;AAAA,GAZf,SAYiB,WAAA,gBAAA,CAAA;AACA,gBAAA;AAAA,EAA3B,SAAS,EAAE,MAAM,OAAA,CAAQ;AAAA,GAbf,SAaiB,WAAA,SAAA,CAAA;AAEX,gBAAA;AAAA,EAAhB,MAAA;AAAM,GAfI,SAeM,WAAA,iBAAA,CAAA;AAfN,WAAN,gBAAA;AAAA,EADN,cAAc,WAAW;AAAA,GACb,QAAA;"}
package/dist/index59.js CHANGED
@@ -1,9 +1,8 @@
1
1
  import { unsafeCSS, css, LitElement } from "lit";
2
- import { property, state, customElement } from "lit/decorators.js";
3
- import pickerCss from "./index302.js";
2
+ import { property, customElement } from "lit/decorators.js";
3
+ import { alertTemplate } from "./index217.js";
4
+ import alertCss from "./index218.js";
4
5
  import sharedTokens from "./index196.js";
5
- import { colorPickerTemplate, swatchGridTemplate } from "./index303.js";
6
- import { SHIBUI_SWATCHES } from "./index304.js";
7
6
  var __defProp = Object.defineProperty;
8
7
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
9
8
  var __decorateClass = (decorators, target, key, kind) => {
@@ -14,358 +13,53 @@ var __decorateClass = (decorators, target, key, kind) => {
14
13
  if (kind && result) __defProp(target, key, result);
15
14
  return result;
16
15
  };
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 {
16
+ let LibAlert = class extends LitElement {
60
17
  constructor() {
61
18
  super(...arguments);
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
- };
92
- }
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
- }
102
- }
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);
19
+ this.type = "default";
20
+ this.heading = "";
21
+ this.closable = false;
22
+ this.glass = false;
114
23
  }
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
24
  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()
25
+ return alertTemplate({
26
+ type: this.type,
27
+ heading: this.heading,
28
+ closable: this.closable,
29
+ glass: this.glass,
30
+ handleClose: this._handleClose.bind(this)
156
31
  });
157
32
  }
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(),
256
- bubbles: true,
257
- composed: true
258
- }));
259
- }
260
- /* ── Helpers ── */
261
- _initFromValue(hex) {
262
- if (!isValidHex(hex)) return;
263
- const hsl = hexToHsl(hex);
264
- this._cs = { ...this._cs, ...hsl };
265
- }
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
- }));
33
+ _handleClose() {
34
+ this.dispatchEvent(
35
+ new CustomEvent("ui-lib-alert-close", {
36
+ detail: { type: this.type },
37
+ bubbles: true,
38
+ composed: true
39
+ })
40
+ );
280
41
  }
281
42
  };
282
- LibColorPicker.styles = [
43
+ LibAlert.styles = [
283
44
  css`${unsafeCSS(sharedTokens)}`,
284
- css`${unsafeCSS(pickerCss)}`
45
+ css`${unsafeCSS(alertCss)}`
285
46
  ];
286
- __decorateClass([
287
- property({ type: String })
288
- ], LibColorPicker.prototype, "value", 2);
289
47
  __decorateClass([
290
48
  property({ type: String, reflect: true })
291
- ], LibColorPicker.prototype, "variant", 2);
292
- __decorateClass([
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);
298
- __decorateClass([
299
- property({ type: Boolean, reflect: true })
300
- ], LibColorPicker.prototype, "disabled", 2);
301
- __decorateClass([
302
- property({ type: String })
303
- ], LibColorPicker.prototype, "label", 2);
49
+ ], LibAlert.prototype, "type", 2);
304
50
  __decorateClass([
305
51
  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
- ];
52
+ ], LibAlert.prototype, "heading", 2);
355
53
  __decorateClass([
356
54
  property({ type: Boolean, reflect: true })
357
- ], LibColorSwatches.prototype, "dark", 2);
358
- __decorateClass([
359
- property({ type: String })
360
- ], LibColorSwatches.prototype, "value", 2);
55
+ ], LibAlert.prototype, "closable", 2);
361
56
  __decorateClass([
362
- property({ type: String })
363
- ], LibColorSwatches.prototype, "rowsJson", 2);
364
- LibColorSwatches = __decorateClass([
365
- customElement("lib-color-swatches")
366
- ], LibColorSwatches);
57
+ property({ type: Boolean, reflect: true })
58
+ ], LibAlert.prototype, "glass", 2);
59
+ LibAlert = __decorateClass([
60
+ customElement("lib-alert")
61
+ ], LibAlert);
367
62
  export {
368
- LibColorPicker,
369
- LibColorSwatches
63
+ LibAlert
370
64
  };
371
65
  //# sourceMappingURL=index59.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index59.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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"}
1
+ {"version":3,"file":"index59.js","sources":["../src/components/molecules/lib-alert/lib-alert.component.ts"],"sourcesContent":["import { LitElement, css, unsafeCSS, TemplateResult } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { alertTemplate } from './lib-alert.html';\nimport alertCss from './lib-alert.css?inline';\nimport sharedTokens from '../../../styles/shared/tokens.css?inline';\nimport type { AlertType, AlertCloseDetail } from './lib-alert.types';\n\n/**\n * @element lib-alert\n *\n * Alerta estática para feedback contextual dentro del layout.\n * A diferencia de los Toasts, pertenece a una sección específica.\n *\n * @attr type — default · info · warning · error · success\n * @attr heading — Título override. Si no se pasa, se usa el nombre del tipo.\n * @attr closable — Muestra el botón ×\n * @attr glass — Activa el efecto Agua (glassmorphism)\n *\n * @fires ui-lib-alert-close — { type } — al pulsar el botón de cierre\n *\n * @slot — Cuerpo del mensaje\n */\n@customElement('lib-alert')\nexport class LibAlert extends LitElement {\n static override styles = [\n css`${unsafeCSS(sharedTokens)}`,\n css`${unsafeCSS(alertCss)}`,\n ];\n\n @property({ type: String, reflect: true }) type: AlertType = 'default';\n @property({ type: String }) heading = '';\n @property({ type: Boolean, reflect: true }) closable = false;\n @property({ type: Boolean, reflect: true }) glass = false;\n\n override render(): TemplateResult {\n return alertTemplate({\n type: this.type,\n heading: this.heading,\n closable: this.closable,\n glass: this.glass,\n handleClose: this._handleClose.bind(this),\n });\n }\n\n private _handleClose(): void {\n this.dispatchEvent(\n new CustomEvent<AlertCloseDetail>('ui-lib-alert-close', {\n detail: { type: this.type },\n bubbles: true,\n composed: true,\n })\n );\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'lib-alert': LibAlert;\n }\n}"],"names":[],"mappings":";;;;;;;;;;;;;;;AAuBO,IAAM,WAAN,cAAuB,WAAW;AAAA,EAAlC,cAAA;AAAA,UAAA,GAAA,SAAA;AAMsC,SAAA,OAAqB;AACrB,SAAA,UAAW;AACV,SAAA,WAAW;AACX,SAAA,QAAW;AAAA,EAAA;AAAA,EAE9C,SAAyB;AAChC,WAAO,cAAc;AAAA,MACnB,MAAa,KAAK;AAAA,MAClB,SAAa,KAAK;AAAA,MAClB,UAAa,KAAK;AAAA,MAClB,OAAa,KAAK;AAAA,MAClB,aAAa,KAAK,aAAa,KAAK,IAAI;AAAA,IAAA,CACzC;AAAA,EACH;AAAA,EAEQ,eAAqB;AAC3B,SAAK;AAAA,MACH,IAAI,YAA8B,sBAAsB;AAAA,QACtD,QAAU,EAAE,MAAM,KAAK,KAAA;AAAA,QACvB,SAAU;AAAA,QACV,UAAU;AAAA,MAAA,CACX;AAAA,IAAA;AAAA,EAEL;AACF;AA9Ba,SACK,SAAS;AAAA,EACvB,MAAM,UAAU,YAAY,CAAC;AAAA,EAC7B,MAAM,UAAU,QAAQ,CAAC;AAC3B;AAE2C,gBAAA;AAAA,EAA1C,SAAS,EAAE,MAAM,QAAQ,SAAS,MAAM;AAAA,GAN9B,SAMgC,WAAA,QAAA,CAAA;AACA,gBAAA;AAAA,EAA1C,SAAS,EAAE,MAAM,OAAA,CAAQ;AAAA,GAPf,SAOgC,WAAA,WAAA,CAAA;AACC,gBAAA;AAAA,EAA3C,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GAR/B,SAQiC,WAAA,YAAA,CAAA;AACA,gBAAA;AAAA,EAA3C,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GAT/B,SASiC,WAAA,SAAA,CAAA;AATjC,WAAN,gBAAA;AAAA,EADN,cAAc,WAAW;AAAA,GACb,QAAA;"}
package/dist/index6.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import { unsafeCSS, css, LitElement } from "lit";
2
2
  import { property, state, customElement } from "lit/decorators.js";
3
- import { avatarTemplate } from "./index199.js";
4
- import avatarCss from "./index200.js";
3
+ import { avatarTemplate } from "./index270.js";
4
+ import avatarCss from "./index271.js";
5
5
  import sharedTokens from "./index196.js";
6
6
  var __defProp = Object.defineProperty;
7
7
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;