se-design 1.0.75 → 1.0.76-dev1

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 (483) hide show
  1. package/dist/assets/style.css +1 -1
  2. package/dist/components/AccessibleDiv/index.d.ts +24 -0
  3. package/dist/components/Checkbox/index.d.ts +12 -0
  4. package/dist/components/CustomAccordion/index.d.ts +1 -0
  5. package/dist/components/CustomModal/index.d.ts +15 -12
  6. package/dist/components/DatePicker/useDatePickerA11y.d.ts +50 -0
  7. package/dist/components/Dropdown/index.d.ts +13 -0
  8. package/dist/components/Icon/index.d.ts +8 -2
  9. package/dist/components/InputWithIcon/index.d.ts +9 -1
  10. package/dist/components/LabelChip/index.d.ts +1 -0
  11. package/dist/components/Modal/index.d.ts +1 -0
  12. package/dist/components/PhoneInput/index.d.ts +13 -5
  13. package/dist/components/Popover/index.d.ts +2 -0
  14. package/dist/components/SidebarOverlay/index.d.ts +8 -0
  15. package/dist/components/index.d.ts +1 -0
  16. package/dist/index.js +144 -133
  17. package/dist/index.js.map +1 -1
  18. package/dist/index10.js +23 -59
  19. package/dist/index10.js.map +1 -1
  20. package/dist/index100.js +1 -1
  21. package/dist/index100.js.map +1 -1
  22. package/dist/index101.js +1 -1
  23. package/dist/index101.js.map +1 -1
  24. package/dist/index102.js +2 -2
  25. package/dist/index102.js.map +1 -1
  26. package/dist/index103.js +2 -2
  27. package/dist/index103.js.map +1 -1
  28. package/dist/index104.js +1 -1
  29. package/dist/index104.js.map +1 -1
  30. package/dist/index105.js +1 -1
  31. package/dist/index105.js.map +1 -1
  32. package/dist/index106.js +1 -1
  33. package/dist/index106.js.map +1 -1
  34. package/dist/index107.js +2 -2
  35. package/dist/index107.js.map +1 -1
  36. package/dist/index108.js +2 -2
  37. package/dist/index108.js.map +1 -1
  38. package/dist/index109.js +2 -2
  39. package/dist/index109.js.map +1 -1
  40. package/dist/index11.js +70 -63
  41. package/dist/index11.js.map +1 -1
  42. package/dist/index110.js +2 -2
  43. package/dist/index110.js.map +1 -1
  44. package/dist/index111.js +1 -1
  45. package/dist/index111.js.map +1 -1
  46. package/dist/index112.js +1 -1
  47. package/dist/index112.js.map +1 -1
  48. package/dist/index113.js +2 -2
  49. package/dist/index113.js.map +1 -1
  50. package/dist/index114.js +2 -2
  51. package/dist/index114.js.map +1 -1
  52. package/dist/index115.js +1 -1
  53. package/dist/index115.js.map +1 -1
  54. package/dist/index116.js +1 -1
  55. package/dist/index116.js.map +1 -1
  56. package/dist/index117.js +1 -1
  57. package/dist/index117.js.map +1 -1
  58. package/dist/index118.js +2 -2
  59. package/dist/index118.js.map +1 -1
  60. package/dist/index119.js +1 -1
  61. package/dist/index119.js.map +1 -1
  62. package/dist/index12.js +71 -34
  63. package/dist/index12.js.map +1 -1
  64. package/dist/index120.js +2 -2
  65. package/dist/index120.js.map +1 -1
  66. package/dist/index121.js +2 -2
  67. package/dist/index121.js.map +1 -1
  68. package/dist/index122.js +2 -2
  69. package/dist/index122.js.map +1 -1
  70. package/dist/index123.js +2 -2
  71. package/dist/index123.js.map +1 -1
  72. package/dist/index124.js +2 -2
  73. package/dist/index124.js.map +1 -1
  74. package/dist/index125.js +2 -2
  75. package/dist/index125.js.map +1 -1
  76. package/dist/index126.js +1 -1
  77. package/dist/index126.js.map +1 -1
  78. package/dist/index127.js +1 -1
  79. package/dist/index127.js.map +1 -1
  80. package/dist/index128.js +1 -1
  81. package/dist/index128.js.map +1 -1
  82. package/dist/index129.js +1 -1
  83. package/dist/index129.js.map +1 -1
  84. package/dist/index13.js +50 -14
  85. package/dist/index13.js.map +1 -1
  86. package/dist/index130.js +2 -2
  87. package/dist/index130.js.map +1 -1
  88. package/dist/index131.js +2 -2
  89. package/dist/index131.js.map +1 -1
  90. package/dist/index132.js +1 -1
  91. package/dist/index132.js.map +1 -1
  92. package/dist/index133.js +1 -1
  93. package/dist/index133.js.map +1 -1
  94. package/dist/index134.js +2 -2
  95. package/dist/index134.js.map +1 -1
  96. package/dist/index135.js +1 -1
  97. package/dist/index135.js.map +1 -1
  98. package/dist/index136.js +1 -1
  99. package/dist/index136.js.map +1 -1
  100. package/dist/index137.js +1 -1
  101. package/dist/index137.js.map +1 -1
  102. package/dist/index138.js +1 -1
  103. package/dist/index138.js.map +1 -1
  104. package/dist/index139.js +1 -1
  105. package/dist/index139.js.map +1 -1
  106. package/dist/index14.js +15 -9
  107. package/dist/index14.js.map +1 -1
  108. package/dist/index140.js +1 -1
  109. package/dist/index140.js.map +1 -1
  110. package/dist/index141.js +2 -2
  111. package/dist/index141.js.map +1 -1
  112. package/dist/index142.js +1 -1
  113. package/dist/index142.js.map +1 -1
  114. package/dist/index143.js +2 -2
  115. package/dist/index143.js.map +1 -1
  116. package/dist/index144.js +2 -2
  117. package/dist/index144.js.map +1 -1
  118. package/dist/index145.js +1 -1
  119. package/dist/index145.js.map +1 -1
  120. package/dist/index146.js +2 -2
  121. package/dist/index146.js.map +1 -1
  122. package/dist/index147.js +2 -2
  123. package/dist/index147.js.map +1 -1
  124. package/dist/index148.js +1 -1
  125. package/dist/index148.js.map +1 -1
  126. package/dist/index149.js +1 -1
  127. package/dist/index149.js.map +1 -1
  128. package/dist/index15.js +10 -218
  129. package/dist/index15.js.map +1 -1
  130. package/dist/index150.js +2 -2
  131. package/dist/index150.js.map +1 -1
  132. package/dist/index151.js +2 -2
  133. package/dist/index151.js.map +1 -1
  134. package/dist/index152.js +1 -1
  135. package/dist/index152.js.map +1 -1
  136. package/dist/index153.js +2 -2
  137. package/dist/index153.js.map +1 -1
  138. package/dist/index154.js +2 -2
  139. package/dist/index154.js.map +1 -1
  140. package/dist/index155.js +1 -1
  141. package/dist/index155.js.map +1 -1
  142. package/dist/index156.js +1 -1
  143. package/dist/index156.js.map +1 -1
  144. package/dist/index157.js +1 -1
  145. package/dist/index157.js.map +1 -1
  146. package/dist/index158.js +1 -1
  147. package/dist/index158.js.map +1 -1
  148. package/dist/index159.js +1 -1
  149. package/dist/index159.js.map +1 -1
  150. package/dist/index16.js +220 -60
  151. package/dist/index16.js.map +1 -1
  152. package/dist/index160.js +1 -1
  153. package/dist/index160.js.map +1 -1
  154. package/dist/index161.js +1 -1
  155. package/dist/index161.js.map +1 -1
  156. package/dist/index162.js +1 -1
  157. package/dist/index162.js.map +1 -1
  158. package/dist/index163.js +1 -1
  159. package/dist/index163.js.map +1 -1
  160. package/dist/index164.js +1 -1
  161. package/dist/index164.js.map +1 -1
  162. package/dist/index165.js +1 -1
  163. package/dist/index165.js.map +1 -1
  164. package/dist/index166.js +1 -1
  165. package/dist/index166.js.map +1 -1
  166. package/dist/index167.js +1 -1
  167. package/dist/index167.js.map +1 -1
  168. package/dist/index168.js +1 -1
  169. package/dist/index168.js.map +1 -1
  170. package/dist/index169.js +1 -1
  171. package/dist/index169.js.map +1 -1
  172. package/dist/index17.js +60 -99
  173. package/dist/index17.js.map +1 -1
  174. package/dist/index170.js +1 -1
  175. package/dist/index170.js.map +1 -1
  176. package/dist/index171.js +1 -1
  177. package/dist/index171.js.map +1 -1
  178. package/dist/index172.js +1 -1
  179. package/dist/index172.js.map +1 -1
  180. package/dist/index173.js +2 -2
  181. package/dist/index173.js.map +1 -1
  182. package/dist/index174.js +1 -1
  183. package/dist/index174.js.map +1 -1
  184. package/dist/index175.js +1 -1
  185. package/dist/index175.js.map +1 -1
  186. package/dist/index176.js +1 -1
  187. package/dist/index176.js.map +1 -1
  188. package/dist/index177.js +2 -2
  189. package/dist/index177.js.map +1 -1
  190. package/dist/index178.js +1 -1
  191. package/dist/index178.js.map +1 -1
  192. package/dist/index179.js +1 -1
  193. package/dist/index179.js.map +1 -1
  194. package/dist/index18.js +95 -282
  195. package/dist/index18.js.map +1 -1
  196. package/dist/index180.js +2 -2
  197. package/dist/index180.js.map +1 -1
  198. package/dist/index181.js +1 -1
  199. package/dist/index181.js.map +1 -1
  200. package/dist/index182.js +1 -1
  201. package/dist/index182.js.map +1 -1
  202. package/dist/index183.js +1 -1
  203. package/dist/index183.js.map +1 -1
  204. package/dist/index184.js +2 -2
  205. package/dist/index184.js.map +1 -1
  206. package/dist/index185.js +1 -1
  207. package/dist/index185.js.map +1 -1
  208. package/dist/index186.js +1 -1
  209. package/dist/index186.js.map +1 -1
  210. package/dist/index187.js +2 -2
  211. package/dist/index187.js.map +1 -1
  212. package/dist/index188.js +1 -1
  213. package/dist/index188.js.map +1 -1
  214. package/dist/index189.js +2 -2
  215. package/dist/index189.js.map +1 -1
  216. package/dist/index19.js +317 -16
  217. package/dist/index19.js.map +1 -1
  218. package/dist/index190.js +2 -149
  219. package/dist/index190.js.map +1 -1
  220. package/dist/index191.js +2 -9
  221. package/dist/index191.js.map +1 -1
  222. package/dist/index192.js +2 -6
  223. package/dist/index192.js.map +1 -1
  224. package/dist/index193.js +2 -5
  225. package/dist/index193.js.map +1 -1
  226. package/dist/index194.js +2 -40
  227. package/dist/index194.js.map +1 -1
  228. package/dist/index195.js +2 -59
  229. package/dist/index195.js.map +1 -1
  230. package/dist/index196.js +2 -23
  231. package/dist/index196.js.map +1 -1
  232. package/dist/index197.js +152 -0
  233. package/dist/index197.js.map +1 -0
  234. package/dist/index198.js +12 -0
  235. package/dist/index198.js.map +1 -0
  236. package/dist/index199.js +5 -23
  237. package/dist/index199.js.map +1 -1
  238. package/dist/index20.js +15 -31
  239. package/dist/index20.js.map +1 -1
  240. package/dist/index200.js +8 -0
  241. package/dist/index200.js.map +1 -0
  242. package/dist/index201.js +36 -80
  243. package/dist/index201.js.map +1 -1
  244. package/dist/index206.js +26 -0
  245. package/dist/index206.js.map +1 -0
  246. package/dist/index207.js +71 -0
  247. package/dist/index207.js.map +1 -0
  248. package/dist/index21.js +33 -61
  249. package/dist/index21.js.map +1 -1
  250. package/dist/{index210.js → index215.js} +1 -1
  251. package/dist/{index210.js.map → index215.js.map} +1 -1
  252. package/dist/index22.js +57 -76
  253. package/dist/index22.js.map +1 -1
  254. package/dist/{index218.js → index223.js} +1 -1
  255. package/dist/{index218.js.map → index223.js.map} +1 -1
  256. package/dist/{index221.js → index226.js} +2 -2
  257. package/dist/{index221.js.map → index226.js.map} +1 -1
  258. package/dist/index23.js +83 -21
  259. package/dist/index23.js.map +1 -1
  260. package/dist/index235.js +171 -8
  261. package/dist/index235.js.map +1 -1
  262. package/dist/index236.js +3 -9
  263. package/dist/index236.js.map +1 -1
  264. package/dist/index238.js +18 -169
  265. package/dist/index238.js.map +1 -1
  266. package/dist/index239.js +10 -11
  267. package/dist/index239.js.map +1 -1
  268. package/dist/index24.js +20 -222
  269. package/dist/index24.js.map +1 -1
  270. package/dist/index240.js +8 -4
  271. package/dist/index240.js.map +1 -1
  272. package/dist/index241.js +4 -5
  273. package/dist/index241.js.map +1 -1
  274. package/dist/index242.js +168 -36
  275. package/dist/index242.js.map +1 -1
  276. package/dist/index243.js +11 -2
  277. package/dist/index243.js.map +1 -1
  278. package/dist/index244.js +5 -7
  279. package/dist/index244.js.map +1 -1
  280. package/dist/index245.js +5 -326
  281. package/dist/index245.js.map +1 -1
  282. package/dist/index246.js +36 -48
  283. package/dist/index246.js.map +1 -1
  284. package/dist/index247.js +2 -2
  285. package/dist/index248.js +7 -75
  286. package/dist/index248.js.map +1 -1
  287. package/dist/index249.js +308 -74
  288. package/dist/index249.js.map +1 -1
  289. package/dist/index25.js +289 -43
  290. package/dist/index25.js.map +1 -1
  291. package/dist/index250.js +45 -47
  292. package/dist/index250.js.map +1 -1
  293. package/dist/index251.js +2 -8
  294. package/dist/index251.js.map +1 -1
  295. package/dist/index252.js +75 -4
  296. package/dist/index252.js.map +1 -1
  297. package/dist/index253.js +89 -48
  298. package/dist/index253.js.map +1 -1
  299. package/dist/index254.js +52 -2
  300. package/dist/index254.js.map +1 -1
  301. package/dist/index255.js +8 -2
  302. package/dist/index255.js.map +1 -1
  303. package/dist/index256.js +8 -0
  304. package/dist/index256.js.map +1 -0
  305. package/dist/index257.js +55 -0
  306. package/dist/index257.js.map +1 -0
  307. package/dist/index258.js +5 -0
  308. package/dist/index258.js.map +1 -0
  309. package/dist/index259.js +5 -0
  310. package/dist/index259.js.map +1 -0
  311. package/dist/index26.js +48 -23
  312. package/dist/index26.js.map +1 -1
  313. package/dist/index27.js +21 -81
  314. package/dist/index27.js.map +1 -1
  315. package/dist/index28.js +101 -138
  316. package/dist/index28.js.map +1 -1
  317. package/dist/index29.js +139 -128
  318. package/dist/index29.js.map +1 -1
  319. package/dist/index3.js +57 -98
  320. package/dist/index3.js.map +1 -1
  321. package/dist/index30.js +133 -69
  322. package/dist/index30.js.map +1 -1
  323. package/dist/index31.js +67 -96
  324. package/dist/index31.js.map +1 -1
  325. package/dist/index32.js +96 -71
  326. package/dist/index32.js.map +1 -1
  327. package/dist/index33.js +70 -38
  328. package/dist/index33.js.map +1 -1
  329. package/dist/index34.js +40 -71
  330. package/dist/index34.js.map +1 -1
  331. package/dist/index35.js +67 -82
  332. package/dist/index35.js.map +1 -1
  333. package/dist/index36.js +99 -54
  334. package/dist/index36.js.map +1 -1
  335. package/dist/index37.js +53 -280
  336. package/dist/index37.js.map +1 -1
  337. package/dist/index38.js +281 -70
  338. package/dist/index38.js.map +1 -1
  339. package/dist/index39.js +69 -80
  340. package/dist/index39.js.map +1 -1
  341. package/dist/index4.js +102 -42
  342. package/dist/index4.js.map +1 -1
  343. package/dist/index40.js +82 -32
  344. package/dist/index40.js.map +1 -1
  345. package/dist/index41.js +26 -44
  346. package/dist/index41.js.map +1 -1
  347. package/dist/index42.js +45 -67
  348. package/dist/index42.js.map +1 -1
  349. package/dist/index43.js +65 -49
  350. package/dist/index43.js.map +1 -1
  351. package/dist/index44.js +53 -139
  352. package/dist/index44.js.map +1 -1
  353. package/dist/index45.js +132 -179
  354. package/dist/index45.js.map +1 -1
  355. package/dist/index46.js +194 -35
  356. package/dist/index46.js.map +1 -1
  357. package/dist/index47.js +34 -29
  358. package/dist/index47.js.map +1 -1
  359. package/dist/index48.js +31 -145
  360. package/dist/index48.js.map +1 -1
  361. package/dist/index49.js +131 -70
  362. package/dist/index49.js.map +1 -1
  363. package/dist/index5.js +40 -315
  364. package/dist/index5.js.map +1 -1
  365. package/dist/index50.js +80 -371
  366. package/dist/index50.js.map +1 -1
  367. package/dist/index51.js +451 -91
  368. package/dist/index51.js.map +1 -1
  369. package/dist/index52.js +98 -38
  370. package/dist/index52.js.map +1 -1
  371. package/dist/index53.js +35 -35
  372. package/dist/index53.js.map +1 -1
  373. package/dist/index54.js +35 -90
  374. package/dist/index54.js.map +1 -1
  375. package/dist/index55.js +89 -159
  376. package/dist/index55.js.map +1 -1
  377. package/dist/index56.js +157 -143
  378. package/dist/index56.js.map +1 -1
  379. package/dist/index57.js +149 -33
  380. package/dist/index57.js.map +1 -1
  381. package/dist/index58.js +33 -86
  382. package/dist/index58.js.map +1 -1
  383. package/dist/index59.js +80 -113
  384. package/dist/index59.js.map +1 -1
  385. package/dist/index6.js +323 -43
  386. package/dist/index6.js.map +1 -1
  387. package/dist/index60.js +114 -62
  388. package/dist/index60.js.map +1 -1
  389. package/dist/index61.js +62 -147
  390. package/dist/index61.js.map +1 -1
  391. package/dist/index62.js +146 -312
  392. package/dist/index62.js.map +1 -1
  393. package/dist/index63.js +317 -44
  394. package/dist/index63.js.map +1 -1
  395. package/dist/index64.js +44 -143
  396. package/dist/index64.js.map +1 -1
  397. package/dist/index65.js +145 -12
  398. package/dist/index65.js.map +1 -1
  399. package/dist/index66.js +10 -44
  400. package/dist/index66.js.map +1 -1
  401. package/dist/index67.js +42 -15
  402. package/dist/index67.js.map +1 -1
  403. package/dist/index68.js +76 -48
  404. package/dist/index68.js.map +1 -1
  405. package/dist/index69.js +18 -58
  406. package/dist/index69.js.map +1 -1
  407. package/dist/index7.js +44 -51
  408. package/dist/index7.js.map +1 -1
  409. package/dist/index70.js +66 -5
  410. package/dist/index70.js.map +1 -1
  411. package/dist/index71.js +25 -7
  412. package/dist/index71.js.map +1 -1
  413. package/dist/index72.js +105 -0
  414. package/dist/index72.js.map +1 -0
  415. package/dist/index73.js +62 -2
  416. package/dist/index73.js.map +1 -1
  417. package/dist/index74.js +21 -2
  418. package/dist/index74.js.map +1 -1
  419. package/dist/index75.js +5 -2
  420. package/dist/index75.js.map +1 -1
  421. package/dist/index76.js +54 -2
  422. package/dist/index76.js.map +1 -1
  423. package/dist/index77.js +24 -2
  424. package/dist/index77.js.map +1 -1
  425. package/dist/index78.js +9 -2
  426. package/dist/index78.js.map +1 -1
  427. package/dist/index8.js +48 -85
  428. package/dist/index8.js.map +1 -1
  429. package/dist/index80.js +2 -2
  430. package/dist/index80.js.map +1 -1
  431. package/dist/index81.js +2 -2
  432. package/dist/index81.js.map +1 -1
  433. package/dist/index82.js +1 -1
  434. package/dist/index82.js.map +1 -1
  435. package/dist/index83.js +2 -2
  436. package/dist/index83.js.map +1 -1
  437. package/dist/index84.js +1 -1
  438. package/dist/index84.js.map +1 -1
  439. package/dist/index85.js +1 -1
  440. package/dist/index85.js.map +1 -1
  441. package/dist/index86.js +1 -1
  442. package/dist/index86.js.map +1 -1
  443. package/dist/index87.js +1 -1
  444. package/dist/index87.js.map +1 -1
  445. package/dist/index88.js +1 -1
  446. package/dist/index88.js.map +1 -1
  447. package/dist/index89.js +1 -1
  448. package/dist/index89.js.map +1 -1
  449. package/dist/index9.js +91 -27
  450. package/dist/index9.js.map +1 -1
  451. package/dist/index90.js +1 -1
  452. package/dist/index90.js.map +1 -1
  453. package/dist/index91.js +1 -1
  454. package/dist/index91.js.map +1 -1
  455. package/dist/index92.js +1 -1
  456. package/dist/index92.js.map +1 -1
  457. package/dist/index93.js +1 -1
  458. package/dist/index93.js.map +1 -1
  459. package/dist/index94.js +1 -1
  460. package/dist/index94.js.map +1 -1
  461. package/dist/index95.js +1 -1
  462. package/dist/index95.js.map +1 -1
  463. package/dist/index96.js +1 -1
  464. package/dist/index96.js.map +1 -1
  465. package/dist/index97.js +1 -1
  466. package/dist/index97.js.map +1 -1
  467. package/dist/index98.js +1 -1
  468. package/dist/index98.js.map +1 -1
  469. package/dist/index99.js +1 -1
  470. package/dist/index99.js.map +1 -1
  471. package/package.json +1 -1
  472. package/dist/index230.js +0 -7
  473. package/dist/index230.js.map +0 -1
  474. package/dist/index232.js +0 -25
  475. package/dist/index232.js.map +0 -1
  476. package/dist/index233.js +0 -57
  477. package/dist/index233.js.map +0 -1
  478. package/dist/index234.js +0 -22
  479. package/dist/index234.js.map +0 -1
  480. package/dist/index237.js +0 -8
  481. package/dist/index237.js.map +0 -1
  482. package/dist/index79.js +0 -5
  483. package/dist/index79.js.map +0 -1
package/dist/index30.js CHANGED
@@ -1,73 +1,137 @@
1
- import n from "react";
2
- import { Icon as f } from "./index5.js";
3
- const c = {
4
- pageNavigation: "px-[6px] py-[6px] flex items-center justify-center",
5
- pageItem: "px-[7px] py-[1px] min-w-[24px] text-sm flex items-center justify-center rounded border hover:cursor-pointer appearance-none focus-outline"
6
- }, k = ({
7
- currentPage: a,
8
- itemsPerPage: l,
9
- totalItems: i,
10
- onPageChange: p,
11
- mobileView: m = !1,
12
- ariaLabel: x = "Pagination Controls"
13
- }) => {
14
- const o = Math.ceil(i / l), d = 1, b = o, g = (a - 1) * l + 1, u = Math.min(a * l, i), v = u < i, y = a > 1, E = () => {
15
- const e = [], t = (s) => {
16
- const h = a === s;
17
- return /* @__PURE__ */ n.createElement("li", {
18
- key: s
19
- }, /* @__PURE__ */ n.createElement("button", {
20
- type: "button",
21
- onClick: () => p(s),
22
- className: `${c.pageItem} ${h ? "bg-[var(--color-gray-100)] border-[var(--color-gray-300)]" : "border-[var(--color-gray-200)] hover:bg-[var(--color-gray-50)]"}`,
23
- "aria-label": `Page ${s}`,
24
- "aria-current": h ? "page" : void 0,
25
- "data-automation-id": `page-number-${s}`
26
- }, s));
27
- }, r = (s) => /* @__PURE__ */ n.createElement("li", {
28
- key: s,
29
- "aria-hidden": "true"
30
- }, /* @__PURE__ */ n.createElement("span", {
31
- className: "w-5 h-5 text-sm rounded border border-[var(--color-gray-200)] flex items-end justify-center"
32
- }, "..."));
33
- if (m)
34
- return e.push(t(a)), e;
35
- if (a <= 3) {
36
- for (let s = 1; s <= Math.min(3, o); s++)
37
- e.push(t(s));
38
- o > 3 && (e.push(r("ellipsis-end")), e.push(t(o)));
39
- } else a >= o - 2 ? (e.push(t(d)), e.push(r("ellipsis-start")), e.push(t(o - 2)), e.push(t(o - 1)), e.push(t(o))) : (e.push(t(d)), e.push(r("ellipsis-start")), e.push(t(a - 1)), e.push(t(a)), e.push(t(a + 1)), e.push(r("ellipsis-end")), e.push(t(b)));
40
- return e;
41
- };
42
- return /* @__PURE__ */ n.createElement("nav", {
43
- "aria-label": x,
44
- "data-automation-id": "pagination-container",
45
- className: "flex items-center gap-1 font-normal"
46
- }, /* @__PURE__ */ n.createElement("span", {
47
- className: "text-sm text-[var(--color-gray-700)] mr-1",
48
- "data-automation-id": "pagination-items-info"
49
- }, `${m ? "" : "Showing "}${g}-${u} of ${i}`), /* @__PURE__ */ n.createElement(f, {
50
- name: "next",
51
- size: 12,
52
- ariaLabel: "Previous page",
53
- rotation: "180",
54
- disabled: !y,
55
- onClick: () => p(a - 1),
56
- className: `stroke-[var(--color-gray-600)] ${c.pageNavigation}`,
57
- automationId: "pagination-previous-button"
58
- }), /* @__PURE__ */ n.createElement("ul", {
59
- className: "flex items-center gap-1"
60
- }, E()), /* @__PURE__ */ n.createElement(f, {
61
- name: "next",
62
- size: 12,
63
- ariaLabel: "Next page",
64
- disabled: !v,
65
- onClick: () => p(a + 1),
66
- className: c.pageNavigation,
67
- automationId: "pagination-next-button"
1
+ import e, { forwardRef as H } from "react";
2
+ import { Icon as J } from "./index6.js";
3
+ import { Button as b } from "./index4.js";
4
+ import { useStableId as I } from "./index199.js";
5
+ import { getRegionAttributes as K } from "./index66.js";
6
+ import { useAccessiblePress as M } from "./index67.js";
7
+ import "./index72.js";
8
+ /* empty css */
9
+ function d() {
10
+ return d = Object.assign ? Object.assign.bind() : function(n) {
11
+ for (var t = 1; t < arguments.length; t++) {
12
+ var r = arguments[t];
13
+ for (var o in r) ({}).hasOwnProperty.call(r, o) && (n[o] = r[o]);
14
+ }
15
+ return n;
16
+ }, d.apply(null, arguments);
17
+ }
18
+ const a = {
19
+ bannerCtn: "relative rounded-[12px] flex pr-3.5",
20
+ bannerContentCtn: "pt-5 pl-6 pb-5 pr-2 flex flex-col gap-2",
21
+ bannerLinkCta: "text-[#1088e7] cursor-pointer text-base leading-6 hover: text-[#0078d4]",
22
+ bannerImageCtn: "flex",
23
+ bannerCloseIconCtn: "absolute top-[12px] right-[12px] cursor-pointer hover:bg-[var(--color-gray-100)] rounded-full p-1 inline-flex items-center justify-center",
24
+ bannerButton: "self-start"
25
+ }, ne = /* @__PURE__ */ H((n, t) => {
26
+ const {
27
+ bannerClassName: r,
28
+ bannerBgColor: o,
29
+ title: h,
30
+ titleTag: k = "span",
31
+ description: m,
32
+ hasImage: v,
33
+ imagePosition: s = "right",
34
+ imageWidth: N = "30%",
35
+ imageAlt: B = "",
36
+ hasCloseIcon: E,
37
+ closeIconName: P,
38
+ onClose: L,
39
+ onBannerClick: i,
40
+ hasLinkCta: T,
41
+ onCtaClick: p,
42
+ onSecondaryCtaClick: $,
43
+ hasButtonCta: j,
44
+ buttonType: A = "secondary",
45
+ ctaText: C,
46
+ ctaAriaLabel: u,
47
+ hasSecondaryButtonCta: w = !1,
48
+ secondaryButtonType: R = "secondary",
49
+ secondaryCtaText: S,
50
+ secondaryCtaAriaLabel: O,
51
+ automationId: _ = "",
52
+ titleId: c,
53
+ disabledPrimaryButton: z = !1
54
+ } = n, g = i ? "cursor-pointer" : "", f = I(c, "banner-title"), y = I(void 0, "banner-description"), l = K({
55
+ titleId: f,
56
+ descriptionId: m ? y : void 0,
57
+ isFocusable: !!c
58
+ }), {
59
+ pressProps: F,
60
+ role: W,
61
+ tabIndex: q
62
+ } = M({
63
+ isNative: !1,
64
+ onClick: i ? () => i() : void 0
65
+ }), D = i ? {
66
+ ...F,
67
+ role: W,
68
+ tabIndex: q
69
+ } : {}, x = () => v && /* @__PURE__ */ e.createElement("div", {
70
+ className: `${a.bannerImageCtn} ${g} banner-image-ctn ${s === "right" ? "mr-5 ml-0 justify-end" : "ml-5 mr-0 justify-start"} min-h-full`,
71
+ style: {
72
+ width: N
73
+ },
74
+ onClick: i
75
+ }, /* @__PURE__ */ e.createElement("img", {
76
+ src: n.bannerImage,
77
+ alt: B,
78
+ className: "max-w-[initial] h-[initial] max-h-[150px] object-contain"
68
79
  }));
69
- };
80
+ return /* @__PURE__ */ e.createElement("div", {
81
+ ref: t,
82
+ className: `${a.bannerCtn} ${g} ${r} banner-ctn`,
83
+ style: {
84
+ backgroundColor: o
85
+ },
86
+ "data-automation-id": _,
87
+ role: l.role,
88
+ "aria-labelledby": l["aria-labelledby"],
89
+ "aria-describedby": l["aria-describedby"],
90
+ tabIndex: l.tabIndex
91
+ }, s === "left" && x(), /* @__PURE__ */ e.createElement("div", d({
92
+ className: `${a.bannerContentCtn} w-[100%] banner-content-ctn`
93
+ }, D), /* @__PURE__ */ e.createElement(k, {
94
+ id: f,
95
+ className: "banner-title",
96
+ tabIndex: c ? -1 : void 0
97
+ }, h), /* @__PURE__ */ e.createElement("span", {
98
+ id: y,
99
+ className: "banner-description"
100
+ }, m), /* @__PURE__ */ e.createElement("div", {
101
+ className: "flex gap-3",
102
+ onClick: (G) => G.stopPropagation()
103
+ }, T && /* @__PURE__ */ e.createElement(b, {
104
+ type: "link",
105
+ className: a.bannerLinkCta,
106
+ onClick: p,
107
+ label: C,
108
+ ariaLabel: u
109
+ }), j && /* @__PURE__ */ e.createElement(b, {
110
+ type: A,
111
+ size: "sm",
112
+ label: C,
113
+ onClick: p,
114
+ className: a?.bannerButton,
115
+ "data-automation-id": "banner-main-cta",
116
+ ariaLabel: u,
117
+ disabled: z
118
+ }), w && /* @__PURE__ */ e.createElement(b, {
119
+ type: R,
120
+ size: "sm",
121
+ label: S,
122
+ onClick: $,
123
+ className: a?.secondaryBannerButton,
124
+ "data-automation-id": "banner-secondary-cta",
125
+ ariaLabel: O
126
+ }))), s === "right" && x(), E && /* @__PURE__ */ e.createElement(J, {
127
+ name: P,
128
+ className: a.bannerCloseIconCtn,
129
+ onClick: L,
130
+ ariaLabel: "Close banner",
131
+ shouldStopPropagation: !0
132
+ }));
133
+ });
70
134
  export {
71
- k as Pagination
135
+ ne as Banner
72
136
  };
73
137
  //# sourceMappingURL=index30.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index30.js","sources":["../src/components/Pagination/index.tsx"],"sourcesContent":["import React from 'react';\n\nimport { Icon } from 'components/Icon';\n\ninterface PaginationProps {\n currentPage: number;\n itemsPerPage: number;\n totalItems: number;\n onPageChange: (page: number) => void;\n mobileView?: boolean;\n ariaLabel?: string;\n}\n\nconst paginationClassNames = {\n pageNavigation: \"px-[6px] py-[6px] flex items-center justify-center\",\n pageItem: \"px-[7px] py-[1px] min-w-[24px] text-sm flex items-center justify-center rounded border hover:cursor-pointer appearance-none focus-outline\"\n}\n\nexport const Pagination: React.FC<PaginationProps> = ({ currentPage, itemsPerPage, totalItems, onPageChange, mobileView = false, ariaLabel = 'Pagination Controls' }) => {\n const totalPages = Math.ceil(totalItems / itemsPerPage);\n const firstPage = 1;\n const lastPage = totalPages;\n const startItem = (currentPage - 1) * itemsPerPage + 1;\n const endItem = Math.min(currentPage * itemsPerPage, totalItems);\n const hasNextPage = endItem < totalItems;\n const hasPrevPage = currentPage > 1;\n\n const renderPageNumbers = () => {\n const pages: React.ReactNode[] = [];\n\n const renderPageNumber = (pageNum: number) => {\n const isActive = currentPage === pageNum;\n return (\n <li key={pageNum}>\n <button\n type=\"button\"\n onClick={() => onPageChange(pageNum)}\n className={`${paginationClassNames.pageItem} ${isActive ? 'bg-[var(--color-gray-100)] border-[var(--color-gray-300)]' : 'border-[var(--color-gray-200)] hover:bg-[var(--color-gray-50)]'}`}\n aria-label={`Page ${pageNum}`}\n aria-current={isActive ? 'page' : undefined}\n data-automation-id={`page-number-${pageNum}`}\n >\n {pageNum}\n </button>\n </li>\n );\n };\n\n const renderEllipsis = (key: string) => {\n return (\n <li key={key} aria-hidden=\"true\">\n <span className=\"w-5 h-5 text-sm rounded border border-[var(--color-gray-200)] flex items-end justify-center\">\n ...\n </span>\n </li>\n );\n };\n\n if (mobileView) {\n pages.push(renderPageNumber(currentPage));\n return pages;\n }\n if (currentPage <= 3) {\n for (let i = 1; i <= Math.min(3, totalPages); i++) {\n pages.push(renderPageNumber(i));\n }\n\n if (totalPages > 3) {\n pages.push(renderEllipsis(\"ellipsis-end\"));\n pages.push(renderPageNumber(totalPages));\n }\n } else if (currentPage >= totalPages - 2) {\n pages.push(renderPageNumber(firstPage));\n pages.push(renderEllipsis(\"ellipsis-start\"));\n pages.push(renderPageNumber(totalPages - 2));\n pages.push(renderPageNumber(totalPages - 1));\n pages.push(renderPageNumber(totalPages));\n } else {\n pages.push(renderPageNumber(firstPage));\n pages.push(renderEllipsis(\"ellipsis-start\"));\n pages.push(renderPageNumber(currentPage - 1));\n pages.push(renderPageNumber(currentPage));\n pages.push(renderPageNumber(currentPage + 1));\n pages.push(renderEllipsis(\"ellipsis-end\"));\n pages.push(renderPageNumber(lastPage));\n }\n\n return pages;\n };\n\n return (\n <nav aria-label={ariaLabel} data-automation-id=\"pagination-container\" className=\"flex items-center gap-1 font-normal\">\n <span\n className=\"text-sm text-[var(--color-gray-700)] mr-1\"\n data-automation-id=\"pagination-items-info\"\n >\n {`${mobileView ? \"\" : \"Showing \"}${startItem}-${endItem} of ${totalItems}`}\n </span>\n <Icon\n name=\"next\"\n size={12}\n ariaLabel=\"Previous page\"\n rotation=\"180\"\n disabled={!hasPrevPage}\n onClick={() => onPageChange(currentPage - 1)}\n className={`stroke-[var(--color-gray-600)] ${paginationClassNames.pageNavigation}`}\n automationId=\"pagination-previous-button\"\n />\n <ul className=\"flex items-center gap-1\">\n {renderPageNumbers()}\n </ul>\n <Icon\n name=\"next\"\n size={12}\n ariaLabel=\"Next page\"\n disabled={!hasNextPage}\n onClick={() => onPageChange(currentPage + 1)}\n className={paginationClassNames.pageNavigation}\n automationId=\"pagination-next-button\"\n />\n </nav>\n );\n};\n"],"names":["React__default","Icon","paginationClassNames","pageNavigation","pageItem","Pagination","currentPage","itemsPerPage","totalItems","onPageChange","mobileView","ariaLabel","totalPages","Math","ceil","firstPage","lastPage","startItem","endItem","min","hasNextPage","hasPrevPage","renderPageNumbers","pages","renderPageNumber","pageNum","isActive","React","createElement","key","type","onClick","className","undefined","renderEllipsis","push","i","name","size","rotation","disabled","automationId"],"mappings":"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"}
1
+ {"version":3,"file":"index30.js","sources":["../src/components/Banner/index.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\nimport { Map } from '../../utils/common.types';\nimport { Icon } from 'components/Icon';\nimport { Button } from 'components/Button';\nimport { useStableId } from '../../utils/useStableId';\nimport { useAccessiblePress } from '../../utils/a11y';\nimport { getRegionAttributes } from '../../utils/a11y/regionAttributes';\nimport './style.scss';\n\nexport interface BannerProps {\n bannerClassName?: string | '';\n bannerBgColor?: string | '';\n title: string | '';\n titleTag?: 'span' | 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n description: string | '';\n hasImage?: boolean | false;\n imagePosition?: 'left' | 'right' | '';\n imageWidth?: string | '30%';\n imageAlt?: string | '';\n bannerImage: string | '';\n hasCloseIcon?: boolean | false;\n closeIconName: string | '';\n onClose: () => void | (() => {});\n onBannerClick?: () => void | (() => {});\n hasButtonCta?: boolean | false;\n hasSecondaryButtonCta?: boolean | false;\n buttonType?: 'primary' | 'secondary' | 'link';\n secondaryButtonType?: 'primary' | 'secondary' | 'ghost' | 'link';\n hasLinkCta?: boolean | false;\n ctaText: string | '';\n secondaryCtaText: string | '';\n onCtaClick: () => void | (() => {});\n onSecondaryCtaClick: () => void | (() => {});\n /**\n * Accessible name for primary CTA button (screen reader only, if different from visible label).\n */\n ctaAriaLabel?: string;\n /**\n * Accessible name for secondary CTA button (screen reader only, if different from visible label).\n */\n secondaryCtaAriaLabel?: string;\n automationId?: string;\n // Optional title ID for external control (e.g., focus management)\n titleId?: string;\n disabledPrimaryButton?: boolean;\n}\n\nconst classNames: Map = {\n bannerCtn: `relative rounded-[12px] flex pr-3.5`,\n bannerContentCtn: 'pt-5 pl-6 pb-5 pr-2 flex flex-col gap-2',\n bannerLinkCta: 'text-[#1088e7] cursor-pointer text-base leading-6 hover: text-[#0078d4]',\n bannerImageCtn: 'flex',\n bannerCloseIconCtn:\n 'absolute top-[12px] right-[12px] cursor-pointer hover:bg-[var(--color-gray-100)] rounded-full p-1 inline-flex items-center justify-center',\n bannerButton: 'self-start'\n};\n\nexport const Banner = forwardRef<HTMLDivElement, BannerProps>((props, ref) => {\n const {\n bannerClassName,\n bannerBgColor,\n title,\n titleTag: TitleTag = 'span',\n description,\n hasImage,\n imagePosition = 'right',\n imageWidth = '30%',\n imageAlt = '',\n hasCloseIcon,\n closeIconName,\n onClose,\n onBannerClick,\n hasLinkCta,\n onCtaClick,\n onSecondaryCtaClick,\n hasButtonCta,\n buttonType = 'secondary',\n ctaText,\n ctaAriaLabel,\n hasSecondaryButtonCta = false,\n secondaryButtonType = 'secondary',\n secondaryCtaText,\n secondaryCtaAriaLabel,\n automationId = '',\n titleId: providedTitleId,\n disabledPrimaryButton = false\n } = props;\n\n const isClickableClass = onBannerClick ? 'cursor-pointer' : '';\n const titleId = useStableId(providedTitleId, 'banner-title');\n const descriptionId = useStableId(undefined, 'banner-description');\n\n const regionAttributes = getRegionAttributes({\n titleId,\n descriptionId: description ? descriptionId : undefined,\n isFocusable: !!providedTitleId\n });\n\n // When banner is clickable, make the content area keyboard-activatable (Enter/Space).\n // We intentionally keep this as an extra tab stop (per dashboard banner behavior).\n const { pressProps: bannerContentPressProps, role: bannerContentRole, tabIndex: bannerContentTabIndex } =\n useAccessiblePress({\n isNative: false,\n onClick: onBannerClick ? () => onBannerClick() : undefined\n });\n\n const bannerContentClickableProps = onBannerClick\n ? {\n ...bannerContentPressProps,\n role: bannerContentRole,\n tabIndex: bannerContentTabIndex\n }\n : {};\n\n const renderImage = () =>\n hasImage && (\n <div\n className={`${classNames.bannerImageCtn} ${isClickableClass} banner-image-ctn ${imagePosition === 'right' ? 'mr-5 ml-0 justify-end' : 'ml-5 mr-0 justify-start'} min-h-full`}\n style={{ width: imageWidth }}\n onClick={onBannerClick}\n >\n <img src={props.bannerImage} alt={imageAlt} className=\"max-w-[initial] h-[initial] max-h-[150px] object-contain\" />\n </div>\n );\n\n return (\n <div \n ref={ref}\n className={`${classNames.bannerCtn} ${isClickableClass} ${bannerClassName} banner-ctn`} \n style={{ backgroundColor: bannerBgColor }} \n data-automation-id={automationId}\n role={regionAttributes.role}\n aria-labelledby={regionAttributes['aria-labelledby']}\n aria-describedby={regionAttributes['aria-describedby']}\n tabIndex={regionAttributes.tabIndex}\n >\n {imagePosition === 'left' && renderImage()}\n <div \n className={`${classNames.bannerContentCtn} w-[100%] banner-content-ctn`} \n {...bannerContentClickableProps}\n >\n <TitleTag id={titleId} className=\"banner-title\" tabIndex={providedTitleId ? -1 : undefined}>{title}</TitleTag>\n <span id={descriptionId} className=\"banner-description\">{description}</span>\n <div className=\"flex gap-3\" onClick={(e) => e.stopPropagation()}>\n {hasLinkCta && (\n <Button \n type=\"link\" \n className={classNames.bannerLinkCta} \n onClick={onCtaClick} \n label={ctaText}\n ariaLabel={ctaAriaLabel}\n />\n )}\n {hasButtonCta && (\n <Button\n type={buttonType}\n size=\"sm\"\n label={ctaText}\n onClick={onCtaClick}\n className={classNames?.bannerButton}\n data-automation-id=\"banner-main-cta\"\n ariaLabel={ctaAriaLabel}\n disabled={disabledPrimaryButton}\n />\n )}\n {hasSecondaryButtonCta && (\n <Button\n type={secondaryButtonType}\n size=\"sm\"\n label={secondaryCtaText}\n onClick={onSecondaryCtaClick}\n className={classNames?.secondaryBannerButton}\n data-automation-id=\"banner-secondary-cta\"\n ariaLabel={secondaryCtaAriaLabel}\n />\n )}\n </div>\n </div>\n {imagePosition === 'right' && renderImage()}\n {hasCloseIcon && (\n <Icon\n name={closeIconName}\n className={classNames.bannerCloseIconCtn}\n onClick={onClose}\n ariaLabel=\"Close banner\"\n shouldStopPropagation\n />\n )}\n </div>\n );\n});\n"],"names":["classNames","bannerCtn","bannerContentCtn","bannerLinkCta","bannerImageCtn","bannerCloseIconCtn","bannerButton","Banner","forwardRef","props","ref","bannerClassName","bannerBgColor","title","titleTag","TitleTag","description","hasImage","imagePosition","imageWidth","imageAlt","hasCloseIcon","closeIconName","onClose","onBannerClick","hasLinkCta","onCtaClick","onSecondaryCtaClick","hasButtonCta","buttonType","ctaText","ctaAriaLabel","hasSecondaryButtonCta","secondaryButtonType","secondaryCtaText","secondaryCtaAriaLabel","automationId","titleId","providedTitleId","disabledPrimaryButton","isClickableClass","useStableId","descriptionId","undefined","regionAttributes","getRegionAttributes","isFocusable","pressProps","bannerContentPressProps","role","bannerContentRole","tabIndex","bannerContentTabIndex","useAccessiblePress","isNative","onClick","bannerContentClickableProps","renderImage","React","createElement","className","style","width","src","bannerImage","alt","backgroundColor","_extends","id","e","stopPropagation","Button","type","label","ariaLabel","size","disabled","secondaryBannerButton","Icon","name","shouldStopPropagation"],"mappings":"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"}
package/dist/index31.js CHANGED
@@ -1,102 +1,73 @@
1
- import e from "react";
2
- import { Button as N } from "./index3.js";
3
- import { Badge as I } from "./index9.js";
4
- import { Icon as d } from "./index5.js";
5
- /* empty css */
6
- const t = {
7
- widgetCtn: "flex flex-col gap-[2px] align-center border border-[var(--color-gray-200)] rounded-[12px] w-[385px]",
8
- widgetImageCtn: "cursor-pointer",
9
- descriptionCtn: "p-4 flex flex-col",
10
- widgetTitle: "text-[var(--color-gray-900)] mt-[4px] mb-[8px]",
11
- widgetDescription: "text-[var(--color-gray-700)] mb-[4px]",
12
- widgetLinkCta: "text-[var(--color-blue-500)] cursor-pointer hover:text-[var(--color-blue-600)]",
13
- widgetButtonCta: "self-start",
14
- widgetBadge: "w-fit",
15
- webinarInfoCtn: "flex flex-col gap-2",
16
- webinarSpeaker: "text-[var(--color-gray-700)]",
17
- webinarDate: "text-[var(--color-gray-700)]",
18
- webinarDescriptionInfo: "flex gap-2",
19
- webinarTimeInfo: "flex gap-2",
20
- requestFeatureCtn: "flex gap-[12px]",
21
- requestFeatureImageCtn: "w-[48px] h-[48px] border border-[var(--color-gray-200)] rounded-[50%] flex items-center flex-shrink-0 bg-[var(--color-red-50)]",
22
- requestFeatureDescriptionCtn: "flex flex-col"
23
- }, B = ({
24
- widgetClassName: g = "",
25
- widgetType: a = "general",
26
- widgetTitle: r = "",
27
- widgetDescription: l = "",
28
- widgetImage: p,
29
- hasImage: f = !1,
30
- hasButtonCta: n = !1,
31
- hasLinkCta: i = !1,
32
- ctaText: o = "",
33
- hasBadge: x = !1,
34
- badgeText: w = "",
35
- buttonBgColor: u = "secondary",
36
- onCtaClick: b,
37
- onWidgetClick: v,
38
- webinarDateInfo: c,
39
- webinarSpeaker: s
1
+ import n from "react";
2
+ import { Icon as f } from "./index6.js";
3
+ const c = {
4
+ pageNavigation: "px-[6px] py-[6px] flex items-center justify-center",
5
+ pageItem: "px-[7px] py-[1px] min-w-[24px] text-sm flex items-center justify-center rounded border hover:cursor-pointer appearance-none focus-outline"
6
+ }, k = ({
7
+ currentPage: a,
8
+ itemsPerPage: l,
9
+ totalItems: i,
10
+ onPageChange: p,
11
+ mobileView: m = !1,
12
+ ariaLabel: x = "Pagination Controls"
40
13
  }) => {
41
- const E = x && /* @__PURE__ */ e.createElement(I, {
42
- label: w,
43
- className: t.widgetBadge,
44
- bgColor: "var(--color-yellow-50)",
45
- textColor: "var(--color-yellow-400)",
46
- fontWeight: "normal"
47
- }), m = (i || n) && /* @__PURE__ */ e.createElement(e.Fragment, null, i && /* @__PURE__ */ e.createElement("span", {
48
- className: t.widgetLinkCta
49
- }, o), n && /* @__PURE__ */ e.createElement(N, {
50
- type: u,
51
- size: "md",
52
- label: o,
53
- className: `${t.widgetButtonCta} mt-[4px]`,
54
- onClick: b
55
- })), C = f && /* @__PURE__ */ e.createElement("div", {
56
- className: `${t.widgetImageCtn} widget-image-ctn`
57
- }, /* @__PURE__ */ e.createElement("img", {
58
- src: p,
59
- alt: "widget-image"
14
+ const o = Math.ceil(i / l), d = 1, b = o, g = (a - 1) * l + 1, u = Math.min(a * l, i), v = u < i, y = a > 1, E = () => {
15
+ const e = [], t = (s) => {
16
+ const h = a === s;
17
+ return /* @__PURE__ */ n.createElement("li", {
18
+ key: s
19
+ }, /* @__PURE__ */ n.createElement("button", {
20
+ type: "button",
21
+ onClick: () => p(s),
22
+ className: `${c.pageItem} ${h ? "bg-[var(--color-gray-100)] border-[var(--color-gray-300)]" : "border-[var(--color-gray-200)] hover:bg-[var(--color-gray-50)]"}`,
23
+ "aria-label": `Page ${s}`,
24
+ "aria-current": h ? "page" : void 0,
25
+ "data-automation-id": `page-number-${s}`
26
+ }, s));
27
+ }, r = (s) => /* @__PURE__ */ n.createElement("li", {
28
+ key: s,
29
+ "aria-hidden": "true"
30
+ }, /* @__PURE__ */ n.createElement("span", {
31
+ className: "w-5 h-5 text-sm rounded border border-[var(--color-gray-200)] flex items-end justify-center"
32
+ }, "..."));
33
+ if (m)
34
+ return e.push(t(a)), e;
35
+ if (a <= 3) {
36
+ for (let s = 1; s <= Math.min(3, o); s++)
37
+ e.push(t(s));
38
+ o > 3 && (e.push(r("ellipsis-end")), e.push(t(o)));
39
+ } else a >= o - 2 ? (e.push(t(d)), e.push(r("ellipsis-start")), e.push(t(o - 2)), e.push(t(o - 1)), e.push(t(o))) : (e.push(t(d)), e.push(r("ellipsis-start")), e.push(t(a - 1)), e.push(t(a)), e.push(t(a + 1)), e.push(r("ellipsis-end")), e.push(t(b)));
40
+ return e;
41
+ };
42
+ return /* @__PURE__ */ n.createElement("nav", {
43
+ "aria-label": x,
44
+ "data-automation-id": "pagination-container",
45
+ className: "flex items-center gap-1 font-normal"
46
+ }, /* @__PURE__ */ n.createElement("span", {
47
+ className: "text-sm text-[var(--color-gray-700)] mr-1",
48
+ "data-automation-id": "pagination-items-info"
49
+ }, `${m ? "" : "Showing "}${g}-${u} of ${i}`), /* @__PURE__ */ n.createElement(f, {
50
+ name: "next",
51
+ size: 12,
52
+ ariaLabel: "Previous page",
53
+ rotation: "180",
54
+ disabled: !y,
55
+ onClick: () => p(a - 1),
56
+ className: `stroke-[var(--color-gray-600)] ${c.pageNavigation}`,
57
+ automationId: "pagination-previous-button"
58
+ }), /* @__PURE__ */ n.createElement("ul", {
59
+ className: "flex items-center gap-1"
60
+ }, E()), /* @__PURE__ */ n.createElement(f, {
61
+ name: "next",
62
+ size: 12,
63
+ ariaLabel: "Next page",
64
+ disabled: !v,
65
+ onClick: () => p(a + 1),
66
+ className: c.pageNavigation,
67
+ automationId: "pagination-next-button"
60
68
  }));
61
- return /* @__PURE__ */ e.createElement("div", {
62
- className: `${t.widgetCtn} ${g} widget-ctn`,
63
- onClick: v
64
- }, a !== "general" && C, /* @__PURE__ */ e.createElement("div", {
65
- className: t.descriptionCtn
66
- }, a !== "general" && E, a !== "request-feature" && /* @__PURE__ */ e.createElement("span", {
67
- className: `${t.widgetTitle} widget-title`
68
- }, r), ["promotion", "general"].includes(a) && /* @__PURE__ */ e.createElement("span", {
69
- className: `${t.widgetDescription} widget-description`
70
- }, l), a === "webinar" && /* @__PURE__ */ e.createElement("div", {
71
- className: t.webinarInfoCtn
72
- }, s && /* @__PURE__ */ e.createElement("div", {
73
- className: `${t.webinarDescriptionInfo} align-baseline`
74
- }, /* @__PURE__ */ e.createElement(d, {
75
- name: "people",
76
- className: "relative top-[2px]"
77
- }), /* @__PURE__ */ e.createElement("span", {
78
- className: t.webinarSpeaker
79
- }, s)), c && /* @__PURE__ */ e.createElement("div", {
80
- className: `${t.webinarTimeInfo} align-baseline mb-[4px]`
81
- }, /* @__PURE__ */ e.createElement(d, {
82
- name: "clock",
83
- className: "relative top-[2px]"
84
- }), /* @__PURE__ */ e.createElement("span", {
85
- className: t.webinarDate
86
- }, c))), a === "request-feature" ? /* @__PURE__ */ e.createElement("div", {
87
- className: t.requestFeatureCtn
88
- }, /* @__PURE__ */ e.createElement("div", {
89
- className: t.requestFeatureImageCtn
90
- }), /* @__PURE__ */ e.createElement("div", {
91
- className: t.requestFeatureDescriptionCtn
92
- }, /* @__PURE__ */ e.createElement("span", {
93
- className: `${t.widgetTitle} widget-title`
94
- }, r), /* @__PURE__ */ e.createElement("span", {
95
- className: `${t.widgetDescription} widget-description`
96
- }, l), m)) : m));
97
69
  };
98
70
  export {
99
- B as Widget,
100
- B as default
71
+ k as Pagination
101
72
  };
102
73
  //# sourceMappingURL=index31.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index31.js","sources":["../src/components/Widget/index.tsx"],"sourcesContent":["import React, { FC } from \"react\";\nimport { Map } from \"../../utils/common.types\";\nimport { Button } from \"../Button\";\nimport { Badge } from \"../Badge\";\nimport { Icon } from \"../Icon\";\nimport \"./style.scss\";\n\nexport interface WidgetProps {\n widgetClassName?: string;\n widgetType?: \"promotion\" | \"webinar\" | \"request-feature\" | \"general\";\n widgetTitle?: string;\n hasBadge?: boolean;\n webinarSpeaker?: string;\n badgeText?: string;\n widgetDescription?: string;\n webinarDateInfo?: string;\n hasImage?: boolean;\n widgetImage?: string;\n hasButtonCta?: boolean;\n buttonBgColor?: 'primary' | 'secondary';\n hasLinkCta?: boolean;\n ctaText?: string;\n onCtaClick?: () => void;\n onWidgetClick?: () => void;\n}\n\nconst className: Map = {\n widgetCtn: 'flex flex-col gap-[2px] align-center border border-[var(--color-gray-200)] rounded-[12px] w-[385px]',\n widgetImageCtn: 'cursor-pointer',\n descriptionCtn: 'p-4 flex flex-col',\n widgetTitle: 'text-[var(--color-gray-900)] mt-[4px] mb-[8px]',\n widgetDescription: 'text-[var(--color-gray-700)] mb-[4px]',\n widgetLinkCta: 'text-[var(--color-blue-500)] cursor-pointer hover:text-[var(--color-blue-600)]',\n widgetButtonCta: 'self-start',\n widgetBadge: 'w-fit',\n webinarInfoCtn: 'flex flex-col gap-2',\n webinarSpeaker: 'text-[var(--color-gray-700)]',\n webinarDate: 'text-[var(--color-gray-700)]',\n webinarDescriptionInfo: 'flex gap-2',\n webinarTimeInfo: 'flex gap-2',\n requestFeatureCtn: 'flex gap-[12px]',\n requestFeatureImageCtn: 'w-[48px] h-[48px] border border-[var(--color-gray-200)] rounded-[50%] flex items-center flex-shrink-0 bg-[var(--color-red-50)]',\n requestFeatureDescriptionCtn: 'flex flex-col',\n};\n\nexport const Widget: FC<WidgetProps> = ({\n widgetClassName = \"\",\n widgetType = 'general',\n widgetTitle = \"\",\n widgetDescription = \"\",\n widgetImage,\n hasImage = false,\n hasButtonCta = false,\n hasLinkCta = false,\n ctaText = \"\",\n hasBadge = false,\n badgeText = \"\",\n buttonBgColor = 'secondary',\n onCtaClick,\n onWidgetClick,\n webinarDateInfo,\n webinarSpeaker,\n}) => {\n\n const renderBadge = hasBadge && (\n <Badge\n label={badgeText}\n className={className.widgetBadge}\n bgColor=\"var(--color-yellow-50)\"\n textColor=\"var(--color-yellow-400)\"\n fontWeight=\"normal\"\n />\n );\n\n const renderCTA = (hasLinkCta || hasButtonCta) && (\n <React.Fragment>\n {hasLinkCta && <span className={className.widgetLinkCta}>{ctaText}</span>}\n {hasButtonCta && <Button type={buttonBgColor} size=\"md\" label={ctaText} className={`${className.widgetButtonCta} mt-[4px]`} onClick={onCtaClick} />}\n </React.Fragment>\n );\n\n const renderImage = hasImage && (\n <div className={`${className.widgetImageCtn} widget-image-ctn`}>\n <img src={widgetImage} alt=\"widget-image\"/>\n </div>\n );\n\n return (\n <div className={`${className.widgetCtn} ${widgetClassName} widget-ctn`} onClick={onWidgetClick}>\n {widgetType !== \"general\" && renderImage}\n <div className={className.descriptionCtn}>\n {widgetType !== \"general\" && renderBadge}\n {widgetType !== \"request-feature\" && <span className={`${className.widgetTitle} widget-title`}>{widgetTitle}</span>}\n\n {([\"promotion\", \"general\"].includes(widgetType)) && (\n <span className={`${className.widgetDescription} widget-description`}>{widgetDescription}</span>\n )}\n\n {widgetType === \"webinar\" && (\n <div className={className.webinarInfoCtn}>\n {webinarSpeaker && (\n <div className={`${className.webinarDescriptionInfo} align-baseline`}>\n <Icon name=\"people\" className=\"relative top-[2px]\" />\n <span className={className.webinarSpeaker}>{webinarSpeaker}</span>\n </div>\n )}\n {webinarDateInfo && (\n <div className={`${className.webinarTimeInfo} align-baseline mb-[4px]`}>\n <Icon name=\"clock\" className=\"relative top-[2px]\" />\n <span className={className.webinarDate}>{webinarDateInfo}</span>\n </div>\n )}\n </div>\n )}\n\n {widgetType === \"request-feature\" ? (\n <div className={className.requestFeatureCtn}>\n <div className={className.requestFeatureImageCtn} />\n <div className={className.requestFeatureDescriptionCtn}>\n <span className={`${className.widgetTitle} widget-title`}>{widgetTitle}</span>\n <span className={`${className.widgetDescription} widget-description`}>{widgetDescription}</span>\n {renderCTA}\n </div>\n </div>\n ) : (\n renderCTA\n )}\n </div>\n </div>\n );\n};\n\nexport default Widget;"],"names":["React__default","Button","Badge","Icon","className","widgetCtn","widgetImageCtn","descriptionCtn","widgetTitle","widgetDescription","widgetLinkCta","widgetButtonCta","widgetBadge","webinarInfoCtn","webinarSpeaker","webinarDate","webinarDescriptionInfo","webinarTimeInfo","requestFeatureCtn","requestFeatureImageCtn","requestFeatureDescriptionCtn","Widget","widgetClassName","widgetType","widgetImage","hasImage","hasButtonCta","hasLinkCta","ctaText","hasBadge","badgeText","buttonBgColor","onCtaClick","onWidgetClick","webinarDateInfo","renderBadge","createElement","label","bgColor","textColor","fontWeight","renderCTA","React","Fragment","type","size","onClick","renderImage","src","alt","includes","name"],"mappings":"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"}
1
+ {"version":3,"file":"index31.js","sources":["../src/components/Pagination/index.tsx"],"sourcesContent":["import React from 'react';\n\nimport { Icon } from 'components/Icon';\n\ninterface PaginationProps {\n currentPage: number;\n itemsPerPage: number;\n totalItems: number;\n onPageChange: (page: number) => void;\n mobileView?: boolean;\n ariaLabel?: string;\n}\n\nconst paginationClassNames = {\n pageNavigation: \"px-[6px] py-[6px] flex items-center justify-center\",\n pageItem: \"px-[7px] py-[1px] min-w-[24px] text-sm flex items-center justify-center rounded border hover:cursor-pointer appearance-none focus-outline\"\n}\n\nexport const Pagination: React.FC<PaginationProps> = ({ currentPage, itemsPerPage, totalItems, onPageChange, mobileView = false, ariaLabel = 'Pagination Controls' }) => {\n const totalPages = Math.ceil(totalItems / itemsPerPage);\n const firstPage = 1;\n const lastPage = totalPages;\n const startItem = (currentPage - 1) * itemsPerPage + 1;\n const endItem = Math.min(currentPage * itemsPerPage, totalItems);\n const hasNextPage = endItem < totalItems;\n const hasPrevPage = currentPage > 1;\n\n const renderPageNumbers = () => {\n const pages: React.ReactNode[] = [];\n\n const renderPageNumber = (pageNum: number) => {\n const isActive = currentPage === pageNum;\n return (\n <li key={pageNum}>\n <button\n type=\"button\"\n onClick={() => onPageChange(pageNum)}\n className={`${paginationClassNames.pageItem} ${isActive ? 'bg-[var(--color-gray-100)] border-[var(--color-gray-300)]' : 'border-[var(--color-gray-200)] hover:bg-[var(--color-gray-50)]'}`}\n aria-label={`Page ${pageNum}`}\n aria-current={isActive ? 'page' : undefined}\n data-automation-id={`page-number-${pageNum}`}\n >\n {pageNum}\n </button>\n </li>\n );\n };\n\n const renderEllipsis = (key: string) => {\n return (\n <li key={key} aria-hidden=\"true\">\n <span className=\"w-5 h-5 text-sm rounded border border-[var(--color-gray-200)] flex items-end justify-center\">\n ...\n </span>\n </li>\n );\n };\n\n if (mobileView) {\n pages.push(renderPageNumber(currentPage));\n return pages;\n }\n if (currentPage <= 3) {\n for (let i = 1; i <= Math.min(3, totalPages); i++) {\n pages.push(renderPageNumber(i));\n }\n\n if (totalPages > 3) {\n pages.push(renderEllipsis(\"ellipsis-end\"));\n pages.push(renderPageNumber(totalPages));\n }\n } else if (currentPage >= totalPages - 2) {\n pages.push(renderPageNumber(firstPage));\n pages.push(renderEllipsis(\"ellipsis-start\"));\n pages.push(renderPageNumber(totalPages - 2));\n pages.push(renderPageNumber(totalPages - 1));\n pages.push(renderPageNumber(totalPages));\n } else {\n pages.push(renderPageNumber(firstPage));\n pages.push(renderEllipsis(\"ellipsis-start\"));\n pages.push(renderPageNumber(currentPage - 1));\n pages.push(renderPageNumber(currentPage));\n pages.push(renderPageNumber(currentPage + 1));\n pages.push(renderEllipsis(\"ellipsis-end\"));\n pages.push(renderPageNumber(lastPage));\n }\n\n return pages;\n };\n\n return (\n <nav aria-label={ariaLabel} data-automation-id=\"pagination-container\" className=\"flex items-center gap-1 font-normal\">\n <span\n className=\"text-sm text-[var(--color-gray-700)] mr-1\"\n data-automation-id=\"pagination-items-info\"\n >\n {`${mobileView ? \"\" : \"Showing \"}${startItem}-${endItem} of ${totalItems}`}\n </span>\n <Icon\n name=\"next\"\n size={12}\n ariaLabel=\"Previous page\"\n rotation=\"180\"\n disabled={!hasPrevPage}\n onClick={() => onPageChange(currentPage - 1)}\n className={`stroke-[var(--color-gray-600)] ${paginationClassNames.pageNavigation}`}\n automationId=\"pagination-previous-button\"\n />\n <ul className=\"flex items-center gap-1\">\n {renderPageNumbers()}\n </ul>\n <Icon\n name=\"next\"\n size={12}\n ariaLabel=\"Next page\"\n disabled={!hasNextPage}\n onClick={() => onPageChange(currentPage + 1)}\n className={paginationClassNames.pageNavigation}\n automationId=\"pagination-next-button\"\n />\n </nav>\n );\n};\n"],"names":["React__default","Icon","paginationClassNames","pageNavigation","pageItem","Pagination","currentPage","itemsPerPage","totalItems","onPageChange","mobileView","ariaLabel","totalPages","Math","ceil","firstPage","lastPage","startItem","endItem","min","hasNextPage","hasPrevPage","renderPageNumbers","pages","renderPageNumber","pageNum","isActive","React","createElement","key","type","onClick","className","undefined","renderEllipsis","push","i","name","size","rotation","disabled","automationId"],"mappings":"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"}