se-design 1.0.81 → 1.0.83-dev.0

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 (429) hide show
  1. package/dist/assets/style.css +1 -1
  2. package/dist/components/MessageBar/index.d.ts +20 -1
  3. package/dist/components/NLSearch/ClearAiFiltersBar.d.ts +21 -0
  4. package/dist/components/NLSearch/NLDynamicChip.d.ts +18 -0
  5. package/dist/components/NLSearch/NLSearchInput.d.ts +21 -0
  6. package/dist/components/NLSearch/index.d.ts +6 -0
  7. package/dist/components/index.d.ts +2 -0
  8. package/dist/index.js +131 -124
  9. package/dist/index.js.map +1 -1
  10. package/dist/index100.js +1 -1
  11. package/dist/index100.js.map +1 -1
  12. package/dist/index101.js +1 -1
  13. package/dist/index101.js.map +1 -1
  14. package/dist/index102.js +1 -1
  15. package/dist/index102.js.map +1 -1
  16. package/dist/index103.js +1 -1
  17. package/dist/index103.js.map +1 -1
  18. package/dist/index104.js +1 -1
  19. package/dist/index104.js.map +1 -1
  20. package/dist/index105.js +1 -1
  21. package/dist/index105.js.map +1 -1
  22. package/dist/index106.js +1 -1
  23. package/dist/index106.js.map +1 -1
  24. package/dist/index107.js +1 -1
  25. package/dist/index107.js.map +1 -1
  26. package/dist/index108.js +1 -1
  27. package/dist/index108.js.map +1 -1
  28. package/dist/index109.js +1 -1
  29. package/dist/index109.js.map +1 -1
  30. package/dist/index11.js +1 -1
  31. package/dist/index110.js +1 -1
  32. package/dist/index110.js.map +1 -1
  33. package/dist/index111.js +1 -1
  34. package/dist/index111.js.map +1 -1
  35. package/dist/index112.js +1 -1
  36. package/dist/index112.js.map +1 -1
  37. package/dist/index113.js +2 -2
  38. package/dist/index113.js.map +1 -1
  39. package/dist/index114.js +2 -2
  40. package/dist/index114.js.map +1 -1
  41. package/dist/index115.js +1 -1
  42. package/dist/index115.js.map +1 -1
  43. package/dist/index116.js +2 -2
  44. package/dist/index116.js.map +1 -1
  45. package/dist/index117.js +2 -2
  46. package/dist/index117.js.map +1 -1
  47. package/dist/index118.js +2 -2
  48. package/dist/index118.js.map +1 -1
  49. package/dist/index119.js +2 -2
  50. package/dist/index119.js.map +1 -1
  51. package/dist/index12.js +3 -3
  52. package/dist/index120.js +1 -1
  53. package/dist/index120.js.map +1 -1
  54. package/dist/index121.js +2 -2
  55. package/dist/index121.js.map +1 -1
  56. package/dist/index122.js +2 -2
  57. package/dist/index122.js.map +1 -1
  58. package/dist/index123.js +1 -1
  59. package/dist/index123.js.map +1 -1
  60. package/dist/index124.js +1 -1
  61. package/dist/index124.js.map +1 -1
  62. package/dist/index125.js +2 -2
  63. package/dist/index125.js.map +1 -1
  64. package/dist/index126.js +2 -2
  65. package/dist/index126.js.map +1 -1
  66. package/dist/index127.js +2 -2
  67. package/dist/index127.js.map +1 -1
  68. package/dist/index128.js +2 -2
  69. package/dist/index128.js.map +1 -1
  70. package/dist/index129.js +2 -2
  71. package/dist/index129.js.map +1 -1
  72. package/dist/index13.js +2 -2
  73. package/dist/index130.js +1 -1
  74. package/dist/index130.js.map +1 -1
  75. package/dist/index131.js +1 -1
  76. package/dist/index131.js.map +1 -1
  77. package/dist/index132.js +1 -1
  78. package/dist/index132.js.map +1 -1
  79. package/dist/index133.js +2 -2
  80. package/dist/index133.js.map +1 -1
  81. package/dist/index134.js +1 -1
  82. package/dist/index134.js.map +1 -1
  83. package/dist/index135.js +2 -2
  84. package/dist/index135.js.map +1 -1
  85. package/dist/index136.js +2 -2
  86. package/dist/index136.js.map +1 -1
  87. package/dist/index137.js +1 -1
  88. package/dist/index137.js.map +1 -1
  89. package/dist/index138.js +2 -2
  90. package/dist/index138.js.map +1 -1
  91. package/dist/index139.js +2 -2
  92. package/dist/index139.js.map +1 -1
  93. package/dist/index140.js +1 -1
  94. package/dist/index140.js.map +1 -1
  95. package/dist/index141.js +1 -1
  96. package/dist/index141.js.map +1 -1
  97. package/dist/index142.js +1 -1
  98. package/dist/index142.js.map +1 -1
  99. package/dist/index143.js +1 -1
  100. package/dist/index143.js.map +1 -1
  101. package/dist/index144.js +1 -1
  102. package/dist/index144.js.map +1 -1
  103. package/dist/index145.js +1 -1
  104. package/dist/index145.js.map +1 -1
  105. package/dist/index146.js +2 -2
  106. package/dist/index146.js.map +1 -1
  107. package/dist/index147.js +1 -1
  108. package/dist/index147.js.map +1 -1
  109. package/dist/index148.js +1 -1
  110. package/dist/index148.js.map +1 -1
  111. package/dist/index149.js +2 -2
  112. package/dist/index149.js.map +1 -1
  113. package/dist/index150.js +1 -1
  114. package/dist/index150.js.map +1 -1
  115. package/dist/index151.js +1 -1
  116. package/dist/index151.js.map +1 -1
  117. package/dist/index152.js +1 -1
  118. package/dist/index152.js.map +1 -1
  119. package/dist/index153.js +1 -1
  120. package/dist/index153.js.map +1 -1
  121. package/dist/index154.js +1 -1
  122. package/dist/index154.js.map +1 -1
  123. package/dist/index155.js +2 -2
  124. package/dist/index155.js.map +1 -1
  125. package/dist/index156.js +2 -2
  126. package/dist/index156.js.map +1 -1
  127. package/dist/index157.js +1 -1
  128. package/dist/index157.js.map +1 -1
  129. package/dist/index158.js +2 -2
  130. package/dist/index158.js.map +1 -1
  131. package/dist/index159.js +1 -1
  132. package/dist/index159.js.map +1 -1
  133. package/dist/index16.js +3 -3
  134. package/dist/index160.js +1 -1
  135. package/dist/index160.js.map +1 -1
  136. package/dist/index161.js +2 -2
  137. package/dist/index161.js.map +1 -1
  138. package/dist/index162.js +2 -2
  139. package/dist/index162.js.map +1 -1
  140. package/dist/index163.js +1 -1
  141. package/dist/index163.js.map +1 -1
  142. package/dist/index164.js +1 -1
  143. package/dist/index164.js.map +1 -1
  144. package/dist/index165.js +1 -1
  145. package/dist/index165.js.map +1 -1
  146. package/dist/index166.js +1 -1
  147. package/dist/index166.js.map +1 -1
  148. package/dist/index167.js +1 -1
  149. package/dist/index167.js.map +1 -1
  150. package/dist/index168.js +1 -1
  151. package/dist/index168.js.map +1 -1
  152. package/dist/index169.js +1 -1
  153. package/dist/index169.js.map +1 -1
  154. package/dist/index170.js +1 -1
  155. package/dist/index170.js.map +1 -1
  156. package/dist/index171.js +1 -1
  157. package/dist/index171.js.map +1 -1
  158. package/dist/index172.js +1 -1
  159. package/dist/index172.js.map +1 -1
  160. package/dist/index173.js +1 -1
  161. package/dist/index173.js.map +1 -1
  162. package/dist/index174.js +1 -1
  163. package/dist/index174.js.map +1 -1
  164. package/dist/index175.js +1 -1
  165. package/dist/index175.js.map +1 -1
  166. package/dist/index176.js +1 -1
  167. package/dist/index176.js.map +1 -1
  168. package/dist/index177.js +1 -1
  169. package/dist/index177.js.map +1 -1
  170. package/dist/index178.js +1 -1
  171. package/dist/index178.js.map +1 -1
  172. package/dist/index179.js +1 -1
  173. package/dist/index179.js.map +1 -1
  174. package/dist/index18.js +2 -2
  175. package/dist/index180.js +1 -1
  176. package/dist/index180.js.map +1 -1
  177. package/dist/index181.js +1 -1
  178. package/dist/index181.js.map +1 -1
  179. package/dist/index182.js +1 -1
  180. package/dist/index182.js.map +1 -1
  181. package/dist/index183.js +1 -1
  182. package/dist/index183.js.map +1 -1
  183. package/dist/index184.js +1 -1
  184. package/dist/index184.js.map +1 -1
  185. package/dist/index185.js +2 -2
  186. package/dist/index185.js.map +1 -1
  187. package/dist/index186.js +1 -1
  188. package/dist/index186.js.map +1 -1
  189. package/dist/index187.js +1 -1
  190. package/dist/index187.js.map +1 -1
  191. package/dist/index188.js +2 -2
  192. package/dist/index188.js.map +1 -1
  193. package/dist/index189.js +2 -2
  194. package/dist/index189.js.map +1 -1
  195. package/dist/index19.js +5 -5
  196. package/dist/index190.js +1 -1
  197. package/dist/index190.js.map +1 -1
  198. package/dist/index191.js +1 -1
  199. package/dist/index191.js.map +1 -1
  200. package/dist/index192.js +2 -2
  201. package/dist/index192.js.map +1 -1
  202. package/dist/index193.js +1 -1
  203. package/dist/index193.js.map +1 -1
  204. package/dist/index194.js +1 -1
  205. package/dist/index194.js.map +1 -1
  206. package/dist/index195.js +1 -1
  207. package/dist/index195.js.map +1 -1
  208. package/dist/index196.js +1 -1
  209. package/dist/index196.js.map +1 -1
  210. package/dist/index197.js +1 -1
  211. package/dist/index197.js.map +1 -1
  212. package/dist/index198.js +1 -1
  213. package/dist/index198.js.map +1 -1
  214. package/dist/index199.js +1 -1
  215. package/dist/index199.js.map +1 -1
  216. package/dist/index200.js +2 -2
  217. package/dist/index200.js.map +1 -1
  218. package/dist/index201.js +1 -1
  219. package/dist/index201.js.map +1 -1
  220. package/dist/index202.js +2 -2
  221. package/dist/index202.js.map +1 -1
  222. package/dist/index203.js +149 -2
  223. package/dist/index203.js.map +1 -1
  224. package/dist/index204.js +9 -2
  225. package/dist/index204.js.map +1 -1
  226. package/dist/index205.js +6 -2
  227. package/dist/index205.js.map +1 -1
  228. package/dist/index206.js +5 -149
  229. package/dist/index206.js.map +1 -1
  230. package/dist/index207.js +41 -4
  231. package/dist/index207.js.map +1 -1
  232. package/dist/index208.js +24 -0
  233. package/dist/index208.js.map +1 -0
  234. package/dist/index215.js +26 -0
  235. package/dist/index215.js.map +1 -0
  236. package/dist/index216.js +71 -0
  237. package/dist/index216.js.map +1 -0
  238. package/dist/{index221.js → index224.js} +1 -1
  239. package/dist/{index221.js.map → index224.js.map} +1 -1
  240. package/dist/index23.js +4 -4
  241. package/dist/index232.js +1233 -43
  242. package/dist/index232.js.map +1 -1
  243. package/dist/index235.js +46 -0
  244. package/dist/index235.js.map +1 -0
  245. package/dist/index244.js +168 -8
  246. package/dist/index244.js.map +1 -1
  247. package/dist/index245.js +3 -9
  248. package/dist/index245.js.map +1 -1
  249. package/dist/index247.js +18 -169
  250. package/dist/index247.js.map +1 -1
  251. package/dist/index248.js +10 -11
  252. package/dist/index248.js.map +1 -1
  253. package/dist/index249.js +8 -4
  254. package/dist/index249.js.map +1 -1
  255. package/dist/index25.js +3 -3
  256. package/dist/index250.js +4 -5
  257. package/dist/index250.js.map +1 -1
  258. package/dist/index251.js +168 -36
  259. package/dist/index251.js.map +1 -1
  260. package/dist/index252.js +11 -2
  261. package/dist/index252.js.map +1 -1
  262. package/dist/index253.js +5 -7
  263. package/dist/index253.js.map +1 -1
  264. package/dist/index254.js +5 -326
  265. package/dist/index254.js.map +1 -1
  266. package/dist/index255.js +36 -48
  267. package/dist/index255.js.map +1 -1
  268. package/dist/index256.js +2 -2
  269. package/dist/index257.js +7 -75
  270. package/dist/index257.js.map +1 -1
  271. package/dist/index258.js +308 -74
  272. package/dist/index258.js.map +1 -1
  273. package/dist/index259.js +45 -47
  274. package/dist/index259.js.map +1 -1
  275. package/dist/index260.js +2 -8
  276. package/dist/index260.js.map +1 -1
  277. package/dist/index261.js +75 -4
  278. package/dist/index261.js.map +1 -1
  279. package/dist/index262.js +89 -48
  280. package/dist/index262.js.map +1 -1
  281. package/dist/index263.js +52 -2
  282. package/dist/index263.js.map +1 -1
  283. package/dist/index264.js +8 -2
  284. package/dist/index264.js.map +1 -1
  285. package/dist/index265.js +8 -0
  286. package/dist/index265.js.map +1 -0
  287. package/dist/index266.js +55 -0
  288. package/dist/index266.js.map +1 -0
  289. package/dist/index267.js +5 -0
  290. package/dist/index267.js.map +1 -0
  291. package/dist/index268.js +5 -0
  292. package/dist/index268.js.map +1 -0
  293. package/dist/index27.js +1 -1
  294. package/dist/index28.js +4 -4
  295. package/dist/index29.js +3 -3
  296. package/dist/index3.js +3 -3
  297. package/dist/index30.js +4 -4
  298. package/dist/index32.js +10 -11
  299. package/dist/index33.js +1 -1
  300. package/dist/index35.js +4 -4
  301. package/dist/index36.js +5 -5
  302. package/dist/index38.js +3 -3
  303. package/dist/index39.js +4 -4
  304. package/dist/index4.js +3 -3
  305. package/dist/index40.js +1 -1
  306. package/dist/index42.js +7 -8
  307. package/dist/index43.js +95 -57
  308. package/dist/index43.js.map +1 -1
  309. package/dist/index45.js +4 -4
  310. package/dist/index46.js +142 -193
  311. package/dist/index46.js.map +1 -1
  312. package/dist/index47.js +21 -38
  313. package/dist/index47.js.map +1 -1
  314. package/dist/index48.js +36 -33
  315. package/dist/index48.js.map +1 -1
  316. package/dist/index50.js +189 -78
  317. package/dist/index50.js.map +1 -1
  318. package/dist/index51.js +36 -459
  319. package/dist/index51.js.map +1 -1
  320. package/dist/index52.js +33 -98
  321. package/dist/index52.js.map +1 -1
  322. package/dist/index53.js +151 -36
  323. package/dist/index53.js.map +1 -1
  324. package/dist/index54.js +84 -36
  325. package/dist/index54.js.map +1 -1
  326. package/dist/index55.js +456 -88
  327. package/dist/index55.js.map +1 -1
  328. package/dist/index56.js +96 -161
  329. package/dist/index56.js.map +1 -1
  330. package/dist/index57.js +35 -146
  331. package/dist/index57.js.map +1 -1
  332. package/dist/index58.js +38 -33
  333. package/dist/index58.js.map +1 -1
  334. package/dist/index59.js +89 -83
  335. package/dist/index59.js.map +1 -1
  336. package/dist/index6.js +123 -123
  337. package/dist/index60.js +157 -113
  338. package/dist/index60.js.map +1 -1
  339. package/dist/index61.js +143 -61
  340. package/dist/index61.js.map +1 -1
  341. package/dist/index62.js +33 -152
  342. package/dist/index62.js.map +1 -1
  343. package/dist/index63.js +80 -312
  344. package/dist/index63.js.map +1 -1
  345. package/dist/index64.js +118 -45
  346. package/dist/index64.js.map +1 -1
  347. package/dist/index65.js +62 -140
  348. package/dist/index65.js.map +1 -1
  349. package/dist/index66.js +152 -12
  350. package/dist/index66.js.map +1 -1
  351. package/dist/index67.js +316 -44
  352. package/dist/index67.js.map +1 -1
  353. package/dist/index68.js +44 -82
  354. package/dist/index68.js.map +1 -1
  355. package/dist/index69.js +143 -18
  356. package/dist/index69.js.map +1 -1
  357. package/dist/index7.js +9 -10
  358. package/dist/index70.js +9 -63
  359. package/dist/index70.js.map +1 -1
  360. package/dist/index71.js +45 -26
  361. package/dist/index71.js.map +1 -1
  362. package/dist/index72.js +78 -102
  363. package/dist/index72.js.map +1 -1
  364. package/dist/index73.js +18 -61
  365. package/dist/index73.js.map +1 -1
  366. package/dist/index74.js +63 -18
  367. package/dist/index74.js.map +1 -1
  368. package/dist/index75.js +27 -5
  369. package/dist/index75.js.map +1 -1
  370. package/dist/index76.js +102 -48
  371. package/dist/index76.js.map +1 -1
  372. package/dist/index77.js +58 -20
  373. package/dist/index77.js.map +1 -1
  374. package/dist/index78.js +19 -7
  375. package/dist/index78.js.map +1 -1
  376. package/dist/index79.js +5 -23
  377. package/dist/index79.js.map +1 -1
  378. package/dist/index80.js +51 -16
  379. package/dist/index80.js.map +1 -1
  380. package/dist/index81.js +23 -8
  381. package/dist/index81.js.map +1 -1
  382. package/dist/index82.js +7 -40
  383. package/dist/index82.js.map +1 -1
  384. package/dist/index84.js +2 -68
  385. package/dist/index84.js.map +1 -1
  386. package/dist/index85.js +2 -21
  387. package/dist/index85.js.map +1 -1
  388. package/dist/index86.js +5 -0
  389. package/dist/index86.js.map +1 -0
  390. package/dist/index87.js +1 -1
  391. package/dist/index87.js.map +1 -1
  392. package/dist/index88.js +2 -2
  393. package/dist/index88.js.map +1 -1
  394. package/dist/index89.js +1 -1
  395. package/dist/index89.js.map +1 -1
  396. package/dist/index9.js +5 -5
  397. package/dist/index90.js +2 -2
  398. package/dist/index90.js.map +1 -1
  399. package/dist/index91.js +1 -1
  400. package/dist/index91.js.map +1 -1
  401. package/dist/index92.js +1 -1
  402. package/dist/index92.js.map +1 -1
  403. package/dist/index93.js +1 -1
  404. package/dist/index93.js.map +1 -1
  405. package/dist/index94.js +1 -1
  406. package/dist/index94.js.map +1 -1
  407. package/dist/index95.js +1 -1
  408. package/dist/index95.js.map +1 -1
  409. package/dist/index96.js +1 -1
  410. package/dist/index96.js.map +1 -1
  411. package/dist/index97.js +1 -1
  412. package/dist/index97.js.map +1 -1
  413. package/dist/index98.js +1 -1
  414. package/dist/index98.js.map +1 -1
  415. package/dist/index99.js +1 -1
  416. package/dist/index99.js.map +1 -1
  417. package/package.json +1 -1
  418. package/dist/index229.js +0 -1236
  419. package/dist/index229.js.map +0 -1
  420. package/dist/index241.js +0 -173
  421. package/dist/index241.js.map +0 -1
  422. package/dist/index242.js +0 -7
  423. package/dist/index242.js.map +0 -1
  424. package/dist/index246.js +0 -8
  425. package/dist/index246.js.map +0 -1
  426. package/dist/index49.js +0 -152
  427. package/dist/index49.js.map +0 -1
  428. package/dist/index83.js +0 -9
  429. package/dist/index83.js.map +0 -1
package/dist/index64.js CHANGED
@@ -1,49 +1,122 @@
1
- import N, { forwardRef as _ } from "react";
2
- import { getA11yNameAttributes as k } from "./index78.js";
3
- import "./index72.js";
4
- /* empty css */
5
- function a() {
6
- return a = Object.assign ? Object.assign.bind() : function(r) {
7
- for (var n = 1; n < arguments.length; n++) {
8
- var e = arguments[n];
9
- for (var t in e) ({}).hasOwnProperty.call(e, t) && (r[t] = e[t]);
1
+ import e, { useState as p, useRef as g, useEffect as I } from "react";
2
+ import { Button as x } from "./index4.js";
3
+ const n = 40, f = 7, y = 3, T = Array.from({
4
+ length: 12
5
+ }, (r, o) => String(o + 1).padStart(2, "0")), w = Array.from({
6
+ length: 60
7
+ }, (r, o) => String(o).padStart(2, "0")), M = ["AM", "PM"], h = ({
8
+ items: r,
9
+ selectedIndex: o,
10
+ onSelect: d,
11
+ automationId: u = ""
12
+ }) => {
13
+ const l = g(null), s = g(null);
14
+ I(() => {
15
+ l.current && l.current.scrollTo({
16
+ top: o * n,
17
+ behavior: "smooth"
18
+ });
19
+ }, [o]);
20
+ const a = () => {
21
+ l.current && (s.current && clearTimeout(s.current), s.current = setTimeout(() => {
22
+ const t = l.current;
23
+ if (!t) return;
24
+ const c = Math.round(t.scrollTop / n), m = Math.max(0, Math.min(r.length - 1, c));
25
+ t.scrollTo({
26
+ top: m * n,
27
+ behavior: "smooth"
28
+ }), m !== o && d(m);
29
+ }, 100));
30
+ }, i = (t) => {
31
+ d(t), l.current?.scrollTo({
32
+ top: t * n,
33
+ behavior: "smooth"
34
+ });
35
+ };
36
+ return /* @__PURE__ */ e.createElement("div", {
37
+ className: "w-14"
38
+ }, /* @__PURE__ */ e.createElement("div", {
39
+ ref: l,
40
+ className: "overflow-y-auto [&::-webkit-scrollbar]:hidden",
41
+ onScroll: a,
42
+ style: {
43
+ height: f * n,
44
+ paddingTop: y * n,
45
+ paddingBottom: y * n,
46
+ scrollSnapType: "y mandatory",
47
+ scrollbarWidth: "none"
10
48
  }
11
- return r;
12
- }, a.apply(null, arguments);
13
- }
14
- const v = " (opens in a new tab)", y = /* @__PURE__ */ _(({
15
- href: r,
16
- label: n,
17
- external: e = !1,
18
- className: t = "",
19
- automationId: c = "",
20
- ariaLabel: o,
21
- ariaLabelledBy: l,
22
- ariaDescribedBy: m,
23
- onClick: u,
24
- target: s,
25
- rel: i,
26
- ...f
27
- }, p) => {
28
- const d = e ? s ?? "_blank" : s, g = e ? i ?? "noopener noreferrer" : i, b = k({
29
- // External link aria-label enhancement for screen readers:
30
- // When external={true}, always append "(opens in a new tab)"
31
- ariaLabel: e ? `${o ?? n}${v}` : o,
32
- ariaLabelledBy: l,
33
- ariaDescribedBy: m
34
- }), A = ["se-design-link", "focus-outline", "focus-visible:underline", t].filter(Boolean).join(" ");
35
- return /* @__PURE__ */ N.createElement("a", a({
36
- ref: p,
37
- href: r,
38
- target: d,
39
- rel: g,
40
- className: A,
41
- "data-automation-id": c,
42
- onClick: u
43
- }, f, b), n);
44
- });
45
- y.displayName = "Link";
49
+ }, r.map((t, c) => /* @__PURE__ */ e.createElement("div", {
50
+ key: t,
51
+ className: `flex items-center justify-center cursor-pointer select-none transition-colors h-10 ${c === o ? "text-[var(--color-blue-500)] font-semibold" : "text-[var(--color-gray-700)] hover:text-[var(--color-blue-500)]"}`,
52
+ onClick: () => i(c),
53
+ style: {
54
+ scrollSnapAlign: "center"
55
+ },
56
+ "data-automation-id": `${u}-item-${c}`
57
+ }, t))));
58
+ }, $ = ({
59
+ initialHour: r = 12,
60
+ initialMinute: o = 0,
61
+ onApply: d,
62
+ ctaLabel: u = "Apply",
63
+ onClose: l,
64
+ className: s = "",
65
+ automationId: a = "timepicker"
66
+ }) => {
67
+ const [i, t] = p(() => r === 0 ? 11 : r > 12 ? r - 12 - 1 : r - 1), [c, m] = p(Math.max(0, Math.min(59, o ?? 0))), [v, E] = p(
68
+ () => r >= 12 ? 1 : 0
69
+ // 0-11 = AM, 12-23 = PM
70
+ ), b = () => {
71
+ const S = v === 1 ? i + 12 : i;
72
+ d?.({
73
+ hour: S + 1,
74
+ minute: c
75
+ }), l?.();
76
+ };
77
+ return /* @__PURE__ */ e.createElement("div", {
78
+ className: `se-design-timepicker-container w-full min-w-[216px] bg-[var(--color-white)] rounded-xl shadow-md border border-[var(--color-gray-400)] overflow-hidden ${s}`
79
+ }, /* @__PURE__ */ e.createElement("div", {
80
+ className: "se-design-timepicker-content w-full relative p-4"
81
+ }, /* @__PURE__ */ e.createElement("div", {
82
+ className: "absolute left-4 right-4 top-1/2 -translate-y-1/2 h-10 bg-[var(--color-blue-50)] rounded-lg pointer-events-none z-0"
83
+ }), /* @__PURE__ */ e.createElement("div", {
84
+ className: "flex justify-between gap-2 relative z-10"
85
+ }, /* @__PURE__ */ e.createElement(h, {
86
+ items: T,
87
+ selectedIndex: i,
88
+ onSelect: t,
89
+ automationId: `${a}-hours`
90
+ }), /* @__PURE__ */ e.createElement("div", {
91
+ className: "w-px bg-[var(--color-gray-200)]",
92
+ style: {
93
+ height: f * n
94
+ }
95
+ }), /* @__PURE__ */ e.createElement(h, {
96
+ items: w,
97
+ selectedIndex: c,
98
+ onSelect: m,
99
+ automationId: `${a}-minutes`
100
+ }), /* @__PURE__ */ e.createElement("div", {
101
+ className: "w-px bg-[var(--color-gray-200)]",
102
+ style: {
103
+ height: f * n
104
+ }
105
+ }), /* @__PURE__ */ e.createElement(h, {
106
+ items: M,
107
+ selectedIndex: v,
108
+ onSelect: E,
109
+ automationId: `${a}-periods`
110
+ }))), /* @__PURE__ */ e.createElement("div", {
111
+ className: "se-design-timepicker-footer flex justify-end p-3 border-t border-[var(--color-gray-200)]"
112
+ }, /* @__PURE__ */ e.createElement(x, {
113
+ label: u,
114
+ type: "primary",
115
+ onClick: b,
116
+ automationId: `${a}-apply-button`
117
+ })));
118
+ };
46
119
  export {
47
- y as Link
120
+ $ as TimePicker
48
121
  };
49
122
  //# sourceMappingURL=index64.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index64.js","sources":["../src/components/Link/index.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\nimport { getA11yNameAttributes } from '../../utils/a11y';\nimport './style.scss';\n\n/**\n * Allows native anchor attributes (aria-*, data-*, etc.) to be passed through,\n * but keeps our own href/onClick/aria-label/aria-labelledby/aria-describedby typing.\n */\ntype NativeAnchorProps = Omit<\n React.AnchorHTMLAttributes<HTMLAnchorElement>,\n 'href' | 'onClick' | 'target' | 'rel' | 'aria-label' | 'aria-labelledby' | 'aria-describedby'\n>;\n\nexport interface LinkProps extends NativeAnchorProps {\n /**\n * URL to navigate to (required for actual links)\n */\n href: string;\n /**\n * Link text content (string only)\n */\n label: string;\n /**\n * If true, automatically adds target=\"_blank\" and rel=\"noopener noreferrer\"\n * Also appends \" (opens in a new tab)\" to aria-label for screen readers\n */\n external?: boolean;\n /**\n * Accessible name for the link. Use when link text is generic or unclear.\n * Prefer ariaLabelledBy when a visible label exists.\n */\n ariaLabel?: string;\n /**\n * ID(s) of element(s) that label this link.\n * Preferred over ariaLabel when a visible label exists (keeps SR and visual text in sync).\n */\n ariaLabelledBy?: string;\n /**\n * ID(s) of element(s) that describe this link.\n * Provides additional context announced after the accessible name.\n */\n ariaDescribedBy?: string;\n /**\n * Click handler (e.g., for analytics tracking)\n */\n onClick?: (e: React.MouseEvent<HTMLAnchorElement>) => void;\n /**\n * Custom class name\n */\n className?: string;\n /**\n * Automation ID for testing\n */\n automationId?: string;\n /**\n * Override target (if you need something other than \"_blank\" for external links).\n * Note: If external={true} and target is provided, the provided target will be used.\n */\n target?: string;\n /**\n * Override rel (if you need something other than \"noopener noreferrer\" for external links).\n * Note: If external={true} and rel is provided, the provided rel will be used.\n */\n rel?: string;\n}\n\nconst EXTERNAL_LINK_ARIA_SUFFIX = ' (opens in a new tab)';\n\nexport const Link = forwardRef<HTMLAnchorElement, LinkProps>(\n (\n {\n href,\n label,\n external = false,\n className = '',\n automationId = '',\n ariaLabel,\n ariaLabelledBy,\n ariaDescribedBy,\n onClick,\n target,\n rel,\n ...props\n },\n ref\n ) => {\n // Handle external link attributes\n // If external={true}, default to target=\"_blank\" and rel=\"noopener noreferrer\"\n // Explicit target/rel props can override these defaults\n const targetAttr = external ? (target ?? '_blank') : target;\n const relAttr = external ? (rel ?? 'noopener noreferrer') : rel;\n\n // Compute accessible name/description props with correct precedence\n // Precedence: ariaLabelledBy > ariaLabel > visible text content\n const accessibleNameProps = getA11yNameAttributes({\n // External link aria-label enhancement for screen readers:\n // When external={true}, always append \"(opens in a new tab)\"\n ariaLabel:\n external ? `${ariaLabel ?? label}${EXTERNAL_LINK_ARIA_SUFFIX}` : ariaLabel,\n ariaLabelledBy,\n ariaDescribedBy\n });\n\n const linkClassName = ['se-design-link', 'focus-outline', 'focus-visible:underline', className]\n .filter(Boolean)\n .join(' ');\n\n return (\n <a\n ref={ref}\n href={href}\n target={targetAttr}\n rel={relAttr}\n className={linkClassName}\n data-automation-id={automationId}\n onClick={onClick}\n {...props}\n {...accessibleNameProps}\n >\n {label}\n </a>\n );\n }\n);\n\nLink.displayName = 'Link';\n"],"names":["EXTERNAL_LINK_ARIA_SUFFIX","Link","href","label","external","className","automationId","ariaLabel","ariaLabelledBy","ariaDescribedBy","onClick","target","rel","props","ref","targetAttr","relAttr","accessibleNameProps","getA11yNameAttributes","linkClassName","filter","Boolean","join","React","createElement","_extends","displayName"],"mappings":";;;;;;;;;;;;;AAkEA,MAAMA,IAA4B,yBAErBC,sBACX,CACE;AAAA,EACEC,MAAAA;AAAAA,EACAC,OAAAA;AAAAA,EACAC,UAAAA,IAAW;AAAA,EACXC,WAAAA,IAAY;AAAA,EACZC,cAAAA,IAAe;AAAA,EACfC,WAAAA;AAAAA,EACAC,gBAAAA;AAAAA,EACAC,iBAAAA;AAAAA,EACAC,SAAAA;AAAAA,EACAC,QAAAA;AAAAA,EACAC,KAAAA;AAAAA,EACA,GAAGC;AACL,GACAC,MACG;AAIH,QAAMC,IAAaX,IAAYO,KAAU,WAAYA,GAC/CK,IAAUZ,IAAYQ,KAAO,wBAAyBA,GAItDK,IAAsBC,EAAsB;AAAA;AAAA;AAAA,IAGhDX,WACEH,IAAW,GAAGG,KAAaJ,CAAK,GAAGH,CAAyB,KAAKO;AAAAA,IACnEC,gBAAAA;AAAAA,IACAC,iBAAAA;AAAAA,EAAAA,CACD,GAEKU,IAAgB,CAAC,kBAAkB,iBAAiB,2BAA2Bd,CAAS,EAC3Fe,OAAOC,OAAO,EACdC,KAAK,GAAG;AAEX,SACEC,gBAAAA,EAAAC,cAAA,KAAAC,EAAA;AAAA,IACEX,KAAAA;AAAAA,IACAZ,MAAAA;AAAAA,IACAS,QAAQI;AAAAA,IACRH,KAAKI;AAAAA,IACLX,WAAWc;AAAAA,IACX,sBAAoBb;AAAAA,IACpBI,SAAAA;AAAAA,EAAAA,GACIG,GACAI,CAAmB,GAEtBd,CACA;AAEP,CACF;AAEAF,EAAKyB,cAAc;"}
1
+ {"version":3,"file":"index64.js","sources":["../src/components/TimePicker/index.tsx"],"sourcesContent":["import React, { useState, useRef, useEffect } from 'react';\nimport { Button } from '../Button';\n\nexport interface TimePickerProps {\n initialHour?: number;\n initialMinute?: number;\n onApply?: (time: { hour: number; minute: number }) => void;\n ctaLabel?: string;\n onClose?: () => void;\n className?: string;\n automationId?: string;\n}\n\nconst ITEM_HEIGHT = 40;\nconst VISIBLE_ITEMS = 7;\nconst BUFFER_ITEMS = 3;\n\nconst HOURS = Array.from({ length: 12 }, (_, i) => String(i + 1).padStart(2, '0'));\nconst MINUTES = Array.from({ length: 60 }, (_, i) => String(i).padStart(2, '0'));\nconst PERIODS: ('AM' | 'PM')[] = ['AM', 'PM'];\n\ninterface ScrollColumnProps {\n items: readonly string[];\n selectedIndex: number;\n onSelect: (index: number) => void;\n automationId?: string;\n}\n\nconst ScrollColumn: React.FC<ScrollColumnProps> = ({ items, selectedIndex, onSelect, automationId = '' }) => {\n const containerRef = useRef<HTMLDivElement>(null);\n const scrollTimeout = useRef<ReturnType<typeof setTimeout> | null>(null);\n\n useEffect(() => {\n if (containerRef.current) {\n containerRef.current.scrollTo({ top: selectedIndex * ITEM_HEIGHT, behavior: 'smooth' });\n }\n }, [selectedIndex]);\n\n const handleScroll = () => {\n if (!containerRef.current) return;\n\n if (scrollTimeout.current) clearTimeout(scrollTimeout.current);\n\n scrollTimeout.current = setTimeout(() => {\n const container = containerRef.current;\n if (!container) return;\n\n const newIndex = Math.round(container.scrollTop / ITEM_HEIGHT);\n const clampedIndex = Math.max(0, Math.min(items.length - 1, newIndex));\n\n container.scrollTo({ top: clampedIndex * ITEM_HEIGHT, behavior: 'smooth' });\n\n if (clampedIndex !== selectedIndex) onSelect(clampedIndex);\n }, 100);\n };\n\n const handleItemClick = (index: number) => {\n onSelect(index);\n containerRef.current?.scrollTo({ top: index * ITEM_HEIGHT, behavior: 'smooth' });\n };\n\n return (\n <div className=\"w-14\">\n <div\n ref={containerRef}\n className=\"overflow-y-auto [&::-webkit-scrollbar]:hidden\"\n onScroll={handleScroll}\n style={{\n height: VISIBLE_ITEMS * ITEM_HEIGHT,\n paddingTop: BUFFER_ITEMS * ITEM_HEIGHT,\n paddingBottom: BUFFER_ITEMS * ITEM_HEIGHT,\n scrollSnapType: 'y mandatory',\n scrollbarWidth: 'none'\n }}\n >\n {items.map((item, index) => (\n <div\n key={item}\n className={`flex items-center justify-center cursor-pointer select-none transition-colors h-10 ${\n index === selectedIndex\n ? 'text-[var(--color-blue-500)] font-semibold'\n : 'text-[var(--color-gray-700)] hover:text-[var(--color-blue-500)]'\n }`}\n onClick={() => handleItemClick(index)}\n style={{ scrollSnapAlign: 'center' }}\n data-automation-id={`${automationId}-item-${index}`}\n >\n {item}\n </div>\n ))}\n </div>\n </div>\n );\n};\n\nexport const TimePicker: React.FC<TimePickerProps> = ({\n initialHour = 12,\n initialMinute = 0,\n onApply,\n ctaLabel = 'Apply',\n onClose,\n className = '',\n automationId = 'timepicker'\n}) => {\n const [selectedHourIndex, setSelectedHourIndex] = useState(() => {\n if (initialHour === 0) return 11; // 0 = 12 AM\n if (initialHour > 12) return initialHour - 12 - 1; // 13-23 → 1-11 (PM hours)\n return initialHour - 1; // 1-12 → 0-11\n });\n const [selectedMinuteIndex, setSelectedMinuteIndex] = useState(Math.max(0, Math.min(59, initialMinute ?? 0)));\n const [selectedPeriodIndex, setSelectedPeriodIndex] = useState(\n () => (initialHour >= 12 ? 1 : 0) // 0-11 = AM, 12-23 = PM\n );\n\n const handleApply = () => {\n const hourIn24Format = selectedPeriodIndex === 1 ? selectedHourIndex + 12 : selectedHourIndex;\n onApply?.({\n hour: hourIn24Format + 1,\n minute: selectedMinuteIndex\n });\n onClose?.();\n };\n\n return (\n <div\n className={`se-design-timepicker-container w-full min-w-[216px] bg-[var(--color-white)] rounded-xl shadow-md border border-[var(--color-gray-400)] overflow-hidden ${className}`}\n >\n <div className=\"se-design-timepicker-content w-full relative p-4\">\n <div className=\"absolute left-4 right-4 top-1/2 -translate-y-1/2 h-10 bg-[var(--color-blue-50)] rounded-lg pointer-events-none z-0\" />\n <div className=\"flex justify-between gap-2 relative z-10\">\n <ScrollColumn\n items={HOURS}\n selectedIndex={selectedHourIndex}\n onSelect={setSelectedHourIndex}\n automationId={`${automationId}-hours`}\n />\n <div className=\"w-px bg-[var(--color-gray-200)]\" style={{ height: VISIBLE_ITEMS * ITEM_HEIGHT }} />\n <ScrollColumn\n items={MINUTES}\n selectedIndex={selectedMinuteIndex}\n onSelect={setSelectedMinuteIndex}\n automationId={`${automationId}-minutes`}\n />\n <div className=\"w-px bg-[var(--color-gray-200)]\" style={{ height: VISIBLE_ITEMS * ITEM_HEIGHT }} />\n <ScrollColumn\n items={PERIODS}\n selectedIndex={selectedPeriodIndex}\n onSelect={setSelectedPeriodIndex}\n automationId={`${automationId}-periods`}\n />\n </div>\n </div>\n <div className=\"se-design-timepicker-footer flex justify-end p-3 border-t border-[var(--color-gray-200)]\">\n <Button label={ctaLabel} type=\"primary\" onClick={handleApply} automationId={`${automationId}-apply-button`} />\n </div>\n </div>\n );\n};\n"],"names":["ITEM_HEIGHT","VISIBLE_ITEMS","BUFFER_ITEMS","HOURS","Array","from","length","_","i","String","padStart","MINUTES","PERIODS","ScrollColumn","items","selectedIndex","onSelect","automationId","containerRef","useRef","scrollTimeout","useEffect","current","scrollTo","top","behavior","handleScroll","clearTimeout","setTimeout","container","newIndex","Math","round","scrollTop","clampedIndex","max","min","handleItemClick","index","React","createElement","className","ref","onScroll","style","height","paddingTop","paddingBottom","scrollSnapType","scrollbarWidth","map","item","key","onClick","scrollSnapAlign","TimePicker","initialHour","initialMinute","onApply","ctaLabel","onClose","selectedHourIndex","setSelectedHourIndex","useState","selectedMinuteIndex","setSelectedMinuteIndex","selectedPeriodIndex","setSelectedPeriodIndex","handleApply","hourIn24Format","hour","minute","Button","label","type"],"mappings":"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"}
package/dist/index65.js CHANGED
@@ -1,148 +1,70 @@
1
- import a from "react";
2
- import { Button as f } from "./index4.js";
3
- import { Badge as j } from "./index10.js";
4
- import { Icon as q } from "./index6.js";
5
- import { Link as N } from "./index64.js";
6
- import { CustomModal as G } from "./index13.js";
7
- import { useStableId as J } from "./index83.js";
1
+ import l, { useState as p, useCallback as E, useEffect as y } from "react";
2
+ import { Popover as P } from "./index19.js";
8
3
  /* empty css */
9
- const K = {
10
- lg: {
11
- width: "768px",
12
- height: "500px"
13
- },
14
- sm: {
15
- width: "656px",
16
- height: "384px"
17
- }
18
- }, ea = ({
19
- isOpen: u,
20
- onClose: n,
21
- trigger: c,
22
- modalWidth: b,
23
- modalHeight: g,
24
- variant: x,
25
- size: t = "lg",
26
- availabilityLabel: k = "Available on ",
27
- availabilityBadgeText: r,
28
- title: C,
29
- description: v,
30
- learnMoreLinkText: o,
31
- learnMoreHref: l,
32
- onLearnMoreClick: s,
33
- featureListDesc: m,
34
- featuresList: I = [],
35
- featureItemIcon: L,
36
- mediaContent: S,
37
- laterButtonText: _,
38
- purchaseButtonText: A,
39
- onLaterClick: F,
40
- onPurchaseClick: P,
41
- className: $ = "",
42
- modalContentClassName: D = "",
43
- automationId: i = "",
44
- id: z
45
- }) => {
46
- const p = J(z, "paywall-title"), B = () => {
47
- F?.(), n();
48
- }, d = K[t], O = b ?? d.width, w = g ?? d.height, y = x === "with-points" && t === "lg", h = I.map((e) => typeof e == "string" ? {
49
- text: e
50
- } : {
51
- text: e.text,
52
- icon: e.icon,
53
- href: e.href,
54
- external: e.external,
55
- onLinkClick: e.onLinkClick
56
- }), R = y && h.length > 0, W = L ?? /* @__PURE__ */ a.createElement(q, {
57
- name: "info",
58
- rotation: "180"
59
- }), Y = /* @__PURE__ */ a.createElement("section", {
60
- className: `paywall paywall-ctn paywall-ctn--${t} ${$}`,
61
- "data-automation-id": i
62
- }, /* @__PURE__ */ a.createElement("div", {
63
- className: "paywall-card"
64
- }, /* @__PURE__ */ a.createElement("div", {
65
- className: "paywall-card-content"
66
- }, r && /* @__PURE__ */ a.createElement("span", {
67
- className: "paywall-card-availability"
68
- }, /* @__PURE__ */ a.createElement("span", {
69
- className: "paywall-card-availability-label"
70
- }, k), /* @__PURE__ */ a.createElement(j, {
71
- label: r,
72
- className: "paywall-card-badge",
73
- bgColor: "var(--color-yellow-100)",
74
- textColor: "var(--color-yellow-700)"
75
- })), /* @__PURE__ */ a.createElement("h3", {
76
- id: p,
77
- className: "paywall-card-title"
78
- }, C), /* @__PURE__ */ a.createElement("p", {
79
- className: "paywall-card-description"
80
- }, v, o && (l || s) && /* @__PURE__ */ a.createElement(N, {
81
- href: l ?? "#",
82
- label: o,
83
- external: !!l,
84
- className: "paywall-card-learn-more",
85
- onClick: (e) => {
86
- l || e.preventDefault(), s?.(e);
87
- }
88
- })), y && m && /* @__PURE__ */ a.createElement("p", {
89
- className: "paywall-card-features-intro"
90
- }, m), R && /* @__PURE__ */ a.createElement("ul", {
91
- className: "paywall-card-features-list"
92
- }, h.map((e) => /* @__PURE__ */ a.createElement("li", {
93
- key: e.text,
94
- className: "paywall-card-feature-item"
95
- }, /* @__PURE__ */ a.createElement("span", {
96
- className: "paywall-card-feature-icon",
97
- "aria-hidden": !0
98
- }, e.icon ?? W), /* @__PURE__ */ a.createElement("span", null, e.href || e.onLinkClick ? /* @__PURE__ */ a.createElement(N, {
99
- href: e.href ?? "#",
100
- label: e.text,
101
- external: e.external,
102
- onClick: (E) => {
103
- e.href || E.preventDefault(), e.onLinkClick?.(E);
104
- }
105
- }) : e.text)))), /* @__PURE__ */ a.createElement("div", {
106
- className: "paywall-card-actions"
107
- }, /* @__PURE__ */ a.createElement(f, {
108
- type: "ghost",
109
- size: "md",
110
- label: _,
111
- onClick: B,
112
- className: "paywall-card-btn-later"
113
- }), /* @__PURE__ */ a.createElement(f, {
114
- type: "primary",
115
- size: "md",
116
- label: A,
117
- onClick: P,
118
- className: "paywall-card-btn-purchase"
119
- }))), /* @__PURE__ */ a.createElement("div", {
120
- className: "paywall-card-media"
121
- }, S))), Z = /* @__PURE__ */ a.createElement("div", {
122
- role: "dialog",
123
- "aria-modal": "true",
124
- "aria-labelledby": p,
125
- className: `paywall-modal-content ${D}`,
126
- style: {
127
- height: w,
128
- minHeight: w
4
+ function f() {
5
+ return f = Object.assign ? Object.assign.bind() : function(s) {
6
+ for (var t = 1; t < arguments.length; t++) {
7
+ var n = arguments[t];
8
+ for (var e in n) ({}).hasOwnProperty.call(n, e) && (s[e] = n[e]);
129
9
  }
130
- }, Y);
131
- return /* @__PURE__ */ a.createElement(a.Fragment, null, c && /* @__PURE__ */ a.createElement("span", {
132
- className: "paywall-trigger"
133
- }, c), /* @__PURE__ */ a.createElement(G, {
134
- isOpen: u,
135
- onClose: n,
136
- onModalClick: () => {
10
+ return s;
11
+ }, f.apply(null, arguments);
12
+ }
13
+ const I = ({
14
+ label: s,
15
+ children: t,
16
+ iconColor: n = "",
17
+ hoverBackgroundColor: e,
18
+ isDisabled: r = !1,
19
+ noPadding: u = !1
20
+ }) => {
21
+ const [m, a] = p(!1), [g, i] = p(!1), c = m || g, d = E((o) => {
22
+ o.key === "Escape" && (a(!1), i(!1), o.stopImmediatePropagation());
23
+ }, []);
24
+ y(() => {
25
+ if (c)
26
+ return document.addEventListener("keydown", d), () => document.removeEventListener("keydown", d);
27
+ }, [c, d]);
28
+ const v = {
29
+ onMouseEnter: () => a(!0),
30
+ onMouseLeave: () => a(!1),
31
+ onFocus: (o) => {
32
+ o.target.matches(":focus-visible") && i(!0);
33
+ },
34
+ onBlur: () => i(!1)
35
+ };
36
+ return /* @__PURE__ */ l.createElement("div", f({
37
+ className: r ? "se-design-info-tooltip-wrapper-disabled" : ""
38
+ }, r ? {} : v), /* @__PURE__ */ l.createElement(P, {
39
+ position: "bottom-center",
40
+ isPopoverOpen: c,
41
+ onPopoverToggle: (o) => {
42
+ o || (a(!1), i(!1));
137
43
  },
138
- renderModalContent: () => Z,
139
- width: O,
140
- contentClassName: "paywall-modal-content-wrapper",
141
- automationId: i
44
+ renderPopoverSrcElement: () => /* @__PURE__ */ l.createElement("div", {
45
+ className: `se-design-info-tooltip-src ${u ? "no-padding" : ""} ${r ? "se-design-info-tooltip-disabled" : ""}`,
46
+ style: {
47
+ "--info-tooltip-icon-color": n,
48
+ ...e ? {
49
+ "--info-tooltip-hover-bg": e
50
+ } : {},
51
+ cursor: r ? "not-allowed" : "pointer"
52
+ }
53
+ }, t),
54
+ renderPopoverContents: () => /* @__PURE__ */ l.createElement("div", {
55
+ className: "se-design-info-tooltip-content",
56
+ "data-automation-id": "se-design-info-tooltip-content"
57
+ }, s),
58
+ isWithPortal: !0,
59
+ noBorder: !0,
60
+ disableClickToggle: !0,
61
+ popoverContentStyleProperty: {
62
+ zIndex: 2e3,
63
+ backgroundColor: ""
64
+ }
142
65
  }));
143
66
  };
144
67
  export {
145
- ea as Paywall,
146
- ea as default
68
+ I as InfoTooltip
147
69
  };
148
70
  //# sourceMappingURL=index65.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index65.js","sources":["../src/components/Paywall/index.tsx"],"sourcesContent":["import React, { FC, ReactNode } from 'react';\nimport { Button } from 'src/components/Button';\nimport { Badge } from 'src/components/Badge';\nimport { Icon } from 'src/components/Icon';\nimport { Link } from 'src/components/Link';\nimport { CustomModal } from 'src/components/CustomModal';\nimport { useStableId } from 'src/utils/useStableId';\nimport './style.scss';\n\n/** Variant: with bullet points list, or description only */\nexport type PaywallVariant = 'with-points' | 'description-only';\n\n/** Size: small (656×384) or large (768×500) – sets modal dimensions and media panel proportion */\nexport type PaywallSize = 'sm' | 'lg';\n\n/** Feature list item: plain string (uses default/list icon) or object with text, optional per-item icon, and optional link/action */\nexport type PaywallFeatureItem =\n | string\n | {\n text: string;\n icon?: ReactNode;\n /** If provided, the feature text becomes a hyperlink navigating to this URL */\n href?: string;\n /** If true, opens the href in a new tab (only applicable when href is set) */\n external?: boolean;\n /** Click handler — use with href for analytics, or alone for SPA actions */\n onLinkClick?: (e: React.MouseEvent<HTMLAnchorElement>) => void;\n };\n\nconst PAYWALL_SIZE_DIMENSIONS: Record<PaywallSize, { width: string; height: string }> = {\n lg: { width: '768px', height: '500px' },\n sm: { width: '656px', height: '384px' },\n};\n\nexport interface PaywallProps {\n isOpen: boolean;\n onClose: () => void;\n trigger?: ReactNode;\n modalWidth?: string;\n modalHeight?: string;\n variant: PaywallVariant;\n size?: PaywallSize;\n availabilityLabel?: string;\n availabilityBadgeText?: string;\n title: string;\n description: string;\n learnMoreLinkText?: string;\n learnMoreHref?: string;\n onLearnMoreClick?: (e: React.MouseEvent<HTMLAnchorElement>) => void;\n featureListDesc?: string;\n featuresList?: PaywallFeatureItem[];\n featureItemIcon?: ReactNode;\n mediaContent?: ReactNode;\n laterButtonText: string;\n purchaseButtonText: string;\n onLaterClick?: () => void;\n onPurchaseClick?: () => void;\n className?: string;\n modalContentClassName?: string;\n automationId?: string;\n id?: string;\n}\n\n/** Paywall – always shown in a modal. Pass isOpen/onClose and optionally a trigger. */\nexport const Paywall: FC<PaywallProps> = ({\n isOpen,\n onClose,\n trigger,\n modalWidth,\n modalHeight,\n variant,\n size = 'lg',\n availabilityLabel = 'Available on ',\n availabilityBadgeText,\n title,\n description,\n learnMoreLinkText,\n learnMoreHref,\n onLearnMoreClick,\n featureListDesc,\n featuresList = [],\n featureItemIcon,\n mediaContent,\n laterButtonText,\n purchaseButtonText,\n onLaterClick,\n onPurchaseClick,\n className = '',\n modalContentClassName = '',\n automationId = '',\n id: providedId,\n}) => {\n const titleId = useStableId(providedId, 'paywall-title');\n\n const handleLaterClick = () => {\n onLaterClick?.();\n onClose();\n };\n\n const dimensions = PAYWALL_SIZE_DIMENSIONS[size];\n const width = modalWidth ?? dimensions.width;\n const height = modalHeight ?? dimensions.height;\n\n const withPoints = variant === 'with-points' && size === 'lg';\n const normalizedFeatures = featuresList.map((item): { text: string; icon?: ReactNode; href?: string; external?: boolean; onLinkClick?: (e: React.MouseEvent<HTMLAnchorElement>) => void } =>\n typeof item === 'string'\n ? { text: item }\n : { text: item.text, icon: item.icon, href: item.href, external: item.external, onLinkClick: item.onLinkClick }\n );\n const showFeatures = withPoints && normalizedFeatures.length > 0;\n const defaultIcon = featureItemIcon ?? <Icon name=\"info\" rotation='180'/>;\n\n const content = (\n <section\n className={`paywall paywall-ctn paywall-ctn--${size} ${className}`}\n data-automation-id={automationId}\n >\n <div className=\"paywall-card\">\n <div className=\"paywall-card-content\">\n {availabilityBadgeText && (\n <span className=\"paywall-card-availability\">\n <span className=\"paywall-card-availability-label\">{availabilityLabel}</span>\n <Badge\n label={availabilityBadgeText}\n className=\"paywall-card-badge\"\n bgColor=\"var(--color-yellow-100)\"\n textColor=\"var(--color-yellow-700)\"\n />\n </span>\n )}\n <h3 id={titleId} className=\"paywall-card-title\">{title}</h3>\n <p className=\"paywall-card-description\">\n {description}\n {learnMoreLinkText && (learnMoreHref || onLearnMoreClick) && (\n <Link\n href={learnMoreHref ?? '#'}\n label={learnMoreLinkText}\n external={!!learnMoreHref}\n className=\"paywall-card-learn-more\"\n onClick={(e) => { if (!learnMoreHref) { e.preventDefault(); } onLearnMoreClick?.(e); }}\n />\n )}\n </p>\n {withPoints && featureListDesc && (\n <p className=\"paywall-card-features-intro\">{featureListDesc}</p>\n )}\n {showFeatures && (\n <ul className=\"paywall-card-features-list\">\n {normalizedFeatures.map((item) => (\n <li key={item.text} className=\"paywall-card-feature-item\">\n <span className=\"paywall-card-feature-icon\" aria-hidden>\n {item.icon ?? defaultIcon}\n </span>\n <span>\n {item.href || item.onLinkClick ? (\n <Link\n href={item.href ?? '#'}\n label={item.text}\n external={item.external}\n onClick={(e) => { if (!item.href) { e.preventDefault(); } item.onLinkClick?.(e); }}\n />\n ) : (\n item.text\n )}\n </span>\n </li>\n ))}\n </ul>\n )}\n <div className=\"paywall-card-actions\">\n <Button\n type=\"ghost\"\n size=\"md\"\n label={laterButtonText}\n onClick={handleLaterClick}\n className=\"paywall-card-btn-later\"\n />\n <Button\n type=\"primary\"\n size=\"md\"\n label={purchaseButtonText}\n onClick={onPurchaseClick}\n className=\"paywall-card-btn-purchase\"\n />\n </div>\n </div>\n <div className=\"paywall-card-media\">\n {mediaContent}\n </div>\n </div>\n </section>\n );\n\n const modalContent = (\n <div\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby={titleId}\n className={`paywall-modal-content ${modalContentClassName}`}\n style={{ height, minHeight: height }}\n >\n {content}\n </div>\n );\n\n return (\n <>\n {trigger && <span className=\"paywall-trigger\">{trigger}</span>}\n <CustomModal\n isOpen={isOpen}\n onClose={onClose}\n onModalClick={() => {}}\n renderModalContent={() => modalContent}\n width={width}\n contentClassName=\"paywall-modal-content-wrapper\"\n automationId={automationId}\n />\n </>\n );\n};\n\nexport default Paywall;\n"],"names":["React__default","Button","Badge","Icon","Link","CustomModal","useStableId","PAYWALL_SIZE_DIMENSIONS","lg","width","height","sm","Paywall","isOpen","onClose","trigger","modalWidth","modalHeight","variant","size","availabilityLabel","availabilityBadgeText","title","description","learnMoreLinkText","learnMoreHref","onLearnMoreClick","featureListDesc","featuresList","featureItemIcon","mediaContent","laterButtonText","purchaseButtonText","onLaterClick","onPurchaseClick","className","modalContentClassName","automationId","id","providedId","titleId","handleLaterClick","dimensions","withPoints","normalizedFeatures","map","item","text","icon","href","external","onLinkClick","showFeatures","length","defaultIcon","React","createElement","name","rotation","content","label","bgColor","textColor","onClick","e","preventDefault","key","type","modalContent","role","style","minHeight","Fragment","onModalClick","renderModalContent","contentClassName"],"mappings":"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"}
1
+ {"version":3,"file":"index65.js","sources":["../src/components/InfoTooltip/index.tsx"],"sourcesContent":["import React, { useState, useEffect, useCallback } from 'react';\nimport { Popover } from '../Popover';\nimport './styles.scss';\n\nexport interface InfoTooltipProps {\n label: string;\n children: React.ReactNode;\n iconColor?: string;\n /**\n * Background color shown on hover. Defaults to var(--color-blue-200).\n */\n hoverBackgroundColor?: string;\n isDisabled?: boolean;\n /**\n * Remove padding from tooltip wrapper (useful for precise alignment)\n */\n noPadding?: boolean;\n}\n\nexport const InfoTooltip = ({\n label,\n children,\n iconColor = '',\n hoverBackgroundColor,\n isDisabled = false,\n noPadding = false\n}: InfoTooltipProps) => {\n const [isHovered, setIsHovered] = useState(false);\n const [isFocused, setIsFocused] = useState(false);\n\n // Show tooltip on hover OR focus (for keyboard accessibility)\n const isOpen = isHovered || isFocused;\n\n // Global Escape key handler (W3C WAI-ARIA tooltip pattern requirement)\n const handleEscapeKey = useCallback((event: KeyboardEvent) => {\n if (event.key === 'Escape') {\n setIsHovered(false);\n setIsFocused(false);\n // Prevent other handlers (e.g., modal) from also closing - \"innermost first\" pattern\n event.stopImmediatePropagation();\n }\n }, []);\n\n useEffect(() => {\n if (isOpen) {\n document.addEventListener('keydown', handleEscapeKey);\n return () => document.removeEventListener('keydown', handleEscapeKey);\n }\n }, [isOpen, handleEscapeKey]);\n\n const interactionHandlers = {\n onMouseEnter: () => setIsHovered(true),\n onMouseLeave: () => setIsHovered(false),\n onFocus: (event: React.FocusEvent<HTMLDivElement>) => {\n const focusTarget = event.target as HTMLElement;\n if (focusTarget.matches(':focus-visible')) {\n setIsFocused(true);\n }\n },\n onBlur: () => setIsFocused(false)\n };\n\n return (\n <div\n className={isDisabled ? 'se-design-info-tooltip-wrapper-disabled' : ''}\n {...(isDisabled ? {} : interactionHandlers)}\n >\n <Popover\n position={'bottom-center'}\n isPopoverOpen={isOpen}\n onPopoverToggle={(open) => {\n // Sync popover state changes (e.g., Escape key) back to component state\n if (!open) {\n setIsHovered(false);\n setIsFocused(false);\n }\n }}\n renderPopoverSrcElement={() => (\n <div\n className={`se-design-info-tooltip-src ${noPadding ? 'no-padding' : ''} ${\n isDisabled ? 'se-design-info-tooltip-disabled' : ''\n }`}\n style={\n {\n '--info-tooltip-icon-color': iconColor,\n ...(hoverBackgroundColor ? { '--info-tooltip-hover-bg': hoverBackgroundColor } : {}),\n cursor: isDisabled ? 'not-allowed' : 'pointer'\n } as React.CSSProperties\n }\n >\n {children}\n </div>\n )}\n renderPopoverContents={() => (\n <div className=\"se-design-info-tooltip-content\" data-automation-id=\"se-design-info-tooltip-content\">\n {label}\n </div>\n )}\n isWithPortal\n noBorder\n disableClickToggle\n popoverContentStyleProperty={{\n zIndex: 2000,\n backgroundColor: ''\n }}\n />\n </div>\n );\n};\n"],"names":["InfoTooltip","label","children","iconColor","hoverBackgroundColor","isDisabled","noPadding","isHovered","setIsHovered","useState","isFocused","setIsFocused","isOpen","handleEscapeKey","useCallback","event","key","stopImmediatePropagation","useEffect","document","addEventListener","removeEventListener","interactionHandlers","onMouseEnter","onMouseLeave","onFocus","target","matches","onBlur","React","createElement","_extends","className","Popover","position","isPopoverOpen","onPopoverToggle","open","renderPopoverSrcElement","style","cursor","renderPopoverContents","isWithPortal","noBorder","disableClickToggle","popoverContentStyleProperty","zIndex","backgroundColor"],"mappings":";;;;;;;;;;;;AAmBO,MAAMA,IAAcA,CAAC;AAAA,EAC1BC,OAAAA;AAAAA,EACAC,UAAAA;AAAAA,EACAC,WAAAA,IAAY;AAAA,EACZC,sBAAAA;AAAAA,EACAC,YAAAA,IAAa;AAAA,EACbC,WAAAA,IAAY;AACI,MAAM;AACtB,QAAM,CAACC,GAAWC,CAAY,IAAIC,EAAS,EAAK,GAC1C,CAACC,GAAWC,CAAY,IAAIF,EAAS,EAAK,GAG1CG,IAASL,KAAaG,GAGtBG,IAAkBC,EAAY,CAACC,MAAyB;AAC5D,IAAIA,EAAMC,QAAQ,aAChBR,EAAa,EAAK,GAClBG,EAAa,EAAK,GAElBI,EAAME,yBAAAA;AAAAA,EAEV,GAAG,CAAA,CAAE;AAELC,EAAAA,EAAU,MAAM;AACd,QAAIN;AACFO,sBAASC,iBAAiB,WAAWP,CAAe,GAC7C,MAAMM,SAASE,oBAAoB,WAAWR,CAAe;AAAA,EAExE,GAAG,CAACD,GAAQC,CAAe,CAAC;AAE5B,QAAMS,IAAsB;AAAA,IAC1BC,cAAcA,MAAMf,EAAa,EAAI;AAAA,IACrCgB,cAAcA,MAAMhB,EAAa,EAAK;AAAA,IACtCiB,SAASA,CAACV,MAA4C;AAEpD,MADoBA,EAAMW,OACVC,QAAQ,gBAAgB,KACtChB,EAAa,EAAI;AAAA,IAErB;AAAA,IACAiB,QAAQA,MAAMjB,EAAa,EAAK;AAAA,EAAA;AAGlC,SACEkB,gBAAAA,EAAAC,cAAA,OAAAC,EAAA;AAAA,IACEC,WAAW3B,IAAa,4CAA4C;AAAA,EAAA,GAC/DA,IAAa,CAAA,IAAKiB,CAAmB,GAE1CO,gBAAAA,EAAAC,cAACG,GAAO;AAAA,IACNC,UAAU;AAAA,IACVC,eAAevB;AAAAA,IACfwB,iBAAkBC,CAAAA,MAAS;AAEzB,MAAKA,MACH7B,EAAa,EAAK,GAClBG,EAAa,EAAK;AAAA,IAEtB;AAAA,IACA2B,yBAAyBA,MACvBT,gBAAAA,EAAAC,cAAA,OAAA;AAAA,MACEE,WAAW,8BAA8B1B,IAAY,eAAe,EAAE,IACpED,IAAa,oCAAoC,EAAE;AAAA,MAErDkC,OACE;AAAA,QACE,6BAA6BpC;AAAAA,QAC7B,GAAIC,IAAuB;AAAA,UAAE,2BAA2BA;AAAAA,QAAAA,IAAyB,CAAA;AAAA,QACjFoC,QAAQnC,IAAa,gBAAgB;AAAA,MAAA;AAAA,IACvC,GAGDH,CACE;AAAA,IAEPuC,uBAAuBA,MACrBZ,gBAAAA,EAAAC,cAAA,OAAA;AAAA,MAAKE,WAAU;AAAA,MAAiC,sBAAmB;AAAA,IAAA,GAChE/B,CACE;AAAA,IAEPyC,cAAY;AAAA,IACZC,UAAQ;AAAA,IACRC,oBAAkB;AAAA,IAClBC,6BAA6B;AAAA,MAC3BC,QAAQ;AAAA,MACRC,iBAAiB;AAAA,IAAA;AAAA,EACnB,CACD,CACE;AAET;"}
package/dist/index66.js CHANGED
@@ -1,15 +1,155 @@
1
- function i({
2
- titleId: r,
3
- descriptionId: t,
4
- isFocusable: a = !1
5
- }) {
6
- const e = {
7
- role: "region",
8
- "aria-labelledby": r
9
- };
10
- return t && (e["aria-describedby"] = t), a && (e.tabIndex = -1), e;
11
- }
1
+ import o, { useState as B, useRef as C, useCallback as m, useEffect as w } from "react";
2
+ import { Button as L } from "./index4.js";
3
+ import { Tooltip as D } from "./index16.js";
4
+ /* empty css */
5
+ const u = {
6
+ gotIt: "got_it",
7
+ finish: "finish",
8
+ next: "next",
9
+ back: "back"
10
+ }, Q = ({
11
+ steps: e = [],
12
+ screenBaseElementSelector: T = "",
13
+ handleCloseProductTour: d,
14
+ tourType: g = "",
15
+ automationId: f = "onboarding-tour",
16
+ highlightBorderRadius: E = 6,
17
+ labels: A
18
+ }) => {
19
+ const [t, k] = B(0), c = C(null), l = C(null), {
20
+ next: H = "Next",
21
+ gotIt: P = "Got It",
22
+ finish: M = "Finish",
23
+ skip: W = "Skip tour",
24
+ stepInfo: O = "Step {step} of {total}"
25
+ } = A || {}, s = document.querySelector(T), y = m(() => {
26
+ let n;
27
+ if (t >= e.length)
28
+ return n;
29
+ const i = document.querySelector(e[t]?.targetElementContainerSelector ? e[t].targetElementContainerSelector : e[t]?.targetElementSelector);
30
+ if (!i)
31
+ return n;
32
+ const r = i.getBoundingClientRect();
33
+ return r.top >= 0 && r.left >= 0 && r.bottom <= window.innerHeight && r.right <= window.innerWidth || (r.top < 0 ? i.scrollIntoView({
34
+ behavior: "auto",
35
+ block: "start"
36
+ }) : r.bottom > window.innerHeight && i.scrollIntoView({
37
+ behavior: "auto",
38
+ block: "end"
39
+ })), n = setTimeout(() => {
40
+ const x = document.querySelector(e[t]?.targetElementSelector);
41
+ if (!x || !c.current || !l.current)
42
+ return;
43
+ const a = x.getBoundingClientRect(), p = Math.max(document.documentElement.scrollHeight, document.body.scrollHeight);
44
+ c.current.style.height = `${p}px`;
45
+ const h = e[t]?.targetElementGap || {
46
+ horizontal: 0,
47
+ vertical: 0
48
+ }, S = E * 2, I = a.left - h.horizontal, N = a.top + window.scrollY - h.vertical, z = a.right + h.horizontal, F = a.bottom + window.scrollY + h.vertical, G = z - I, q = F - N, R = Math.max(document.documentElement.scrollWidth, document.body.scrollWidth), _ = encodeURIComponent(`
49
+ <svg width="${R}" height="${p}" xmlns="http://www.w3.org/2000/svg">
50
+ <defs>
51
+ <mask id="highlight-mask-${t}">
52
+ <rect x="0" y="0" width="${R}" height="${p}" fill="white"/>
53
+ <rect x="${I}" y="${N}" width="${G}" height="${q}" rx="${S}" ry="${S}" fill="black"/>
54
+ </mask>
55
+ </defs>
56
+ </svg>
57
+ `);
58
+ c.current.style.maskImage = `url("data:image/svg+xml,${_}#highlight-mask-${t}")`, c.current.style.webkitMaskImage = `url("data:image/svg+xml,${_}#highlight-mask-${t}")`, l.current.style.top = `${a.top}px`, l.current.style.left = `${a.left}px`, l.current.style.width = `${a.width}px`, l.current.style.height = `${a.height}px`, l.current.style.borderRadius = `${E}px`;
59
+ }, 50), n;
60
+ }, [t, e]), V = m(() => {
61
+ d(), s && s.scrollTo({
62
+ top: 0,
63
+ behavior: "smooth"
64
+ });
65
+ }, [d, s]), v = m((n) => {
66
+ n?.preventDefault(), n?.stopPropagation(), t < e.length - 1 ? k((i) => i + 1) : (d(n), s && s.scrollTo({
67
+ top: 0,
68
+ behavior: "smooth"
69
+ })), e[t]?.tourMixPanelHandler?.({
70
+ user_path: g,
71
+ action_type: `clicked_${t === e.length - 1 ? e.length === 1 ? u.gotIt : u.finish : u.next}`
72
+ });
73
+ }, [t, e, d, g, s]), $ = m(() => {
74
+ t > 0 && k((n) => n - 1), e[t]?.tourMixPanelHandler?.({
75
+ user_path: g,
76
+ action_type: `clicked_${u.back}`
77
+ });
78
+ }, [t, e, g]), b = m((n) => {
79
+ (n.keyCode === 37 || n.key === "ArrowLeft") && t > 0 && $(), (n.keyCode === 39 || n.key === "ArrowRight") && v();
80
+ }, [t, v, $]);
81
+ return w(() => (window.addEventListener("keydown", b), () => {
82
+ window.removeEventListener("keydown", b);
83
+ }), [b]), w(() => {
84
+ let n;
85
+ return t < e.length && (n = y()), () => {
86
+ n && clearTimeout(n);
87
+ };
88
+ }, [t, e, y]), w(() => {
89
+ if (t < e.length && c.current) {
90
+ const n = c.current, i = (r) => {
91
+ r.preventDefault(), r.stopPropagation();
92
+ };
93
+ return n.addEventListener("wheel", i, {
94
+ passive: !1
95
+ }), n.addEventListener("touchmove", i, {
96
+ passive: !1
97
+ }), n.addEventListener("scroll", i, {
98
+ passive: !1
99
+ }), () => {
100
+ n.removeEventListener("wheel", i), n.removeEventListener("touchmove", i), n.removeEventListener("scroll", i);
101
+ };
102
+ }
103
+ }, [t]), !e || e.length === 0 ? null : /* @__PURE__ */ o.createElement(o.Fragment, null, /* @__PURE__ */ o.createElement("div", {
104
+ className: "se-design-onboarding-tour-overlay",
105
+ ref: c,
106
+ "data-automation-id": `${f}-overlay`
107
+ }), /* @__PURE__ */ o.createElement(D, {
108
+ content: /* @__PURE__ */ o.createElement("div", {
109
+ className: "se-design-onboarding-tour-tooltip-content"
110
+ }, e[t]?.content?.illustration && /* @__PURE__ */ o.createElement("img", {
111
+ src: e[t].content.illustration,
112
+ className: "se-design-onboarding-tour-illustration",
113
+ alt: "illustration"
114
+ }), /* @__PURE__ */ o.createElement("div", {
115
+ className: "se-design-onboarding-tour-content"
116
+ }, e[t]?.content?.title && /* @__PURE__ */ o.createElement("p", {
117
+ className: "se-design-onboarding-tour-title"
118
+ }, e[t].content.title), e[t]?.content?.description && /* @__PURE__ */ o.createElement("p", {
119
+ className: "se-design-onboarding-tour-description"
120
+ }, e[t].content.description)), /* @__PURE__ */ o.createElement("div", {
121
+ className: "se-design-onboarding-tour-actions"
122
+ }, e.length > 1 && /* @__PURE__ */ o.createElement("span", {
123
+ className: "steps"
124
+ }, O.replace("{step}", `${t + 1}`).replace("{total}", `${e.length}`)), /* @__PURE__ */ o.createElement("div", {
125
+ className: "btns-container"
126
+ }, t !== e.length - 1 && /* @__PURE__ */ o.createElement(L, {
127
+ theme: "white",
128
+ type: "link",
129
+ label: W,
130
+ automationId: `${f}-skip-button`,
131
+ onClick: V
132
+ }), /* @__PURE__ */ o.createElement(L, {
133
+ theme: "white",
134
+ type: "primary",
135
+ size: "sm",
136
+ label: t === e.length - 1 ? e.length === 1 ? P : M : H,
137
+ automationId: `${f}-next-button`,
138
+ onClick: v
139
+ })))),
140
+ tooltipSrc: /* @__PURE__ */ o.createElement("div", {
141
+ className: "blocker",
142
+ ref: l
143
+ }),
144
+ tooltipSrcRef: l,
145
+ position: e[t]?.tooltipPosition || "bottom-center",
146
+ tooltipOffset: 16,
147
+ displayOn: "always-on",
148
+ isWithPortal: !0,
149
+ maxWidth: 384
150
+ }));
151
+ };
12
152
  export {
13
- i as getRegionAttributes
153
+ Q as OnboardingTour
14
154
  };
15
155
  //# sourceMappingURL=index66.js.map