@fluid-app/rep-widgets 0.1.16 → 0.1.18

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 (337) hide show
  1. package/dist/AlertWidget-CiMRJYmn.mjs +22 -0
  2. package/dist/AlertWidget-CiMRJYmn.mjs.map +1 -0
  3. package/dist/AlertWidget-DU_HP0EW.cjs +39 -0
  4. package/dist/AlertWidget-DU_HP0EW.cjs.map +1 -0
  5. package/dist/CalendarWidget-DshBk5tG.mjs +424 -0
  6. package/dist/CalendarWidget-DshBk5tG.mjs.map +1 -0
  7. package/dist/CalendarWidget-s7KgQ5JD.cjs +441 -0
  8. package/dist/CalendarWidget-s7KgQ5JD.cjs.map +1 -0
  9. package/dist/CarouselWidget-0RP-Rd1D.mjs +436 -0
  10. package/dist/CarouselWidget-0RP-Rd1D.mjs.map +1 -0
  11. package/dist/CarouselWidget-DLADgLPJ.cjs +453 -0
  12. package/dist/CarouselWidget-DLADgLPJ.cjs.map +1 -0
  13. package/dist/CatchUpWidget-CUnCumIf.mjs +247 -0
  14. package/dist/CatchUpWidget-CUnCumIf.mjs.map +1 -0
  15. package/dist/CatchUpWidget-DiqdwPvE.cjs +264 -0
  16. package/dist/CatchUpWidget-DiqdwPvE.cjs.map +1 -0
  17. package/dist/ChartWidget-DhAVW8w4.cjs +432 -0
  18. package/dist/ChartWidget-DhAVW8w4.cjs.map +1 -0
  19. package/dist/ChartWidget-DrF1e1sy.mjs +415 -0
  20. package/dist/ChartWidget-DrF1e1sy.mjs.map +1 -0
  21. package/dist/ContainerWidget-Cp0_vPZB.cjs +61 -0
  22. package/dist/ContainerWidget-Cp0_vPZB.cjs.map +1 -0
  23. package/dist/ContainerWidget-Xd231yys.mjs +44 -0
  24. package/dist/ContainerWidget-Xd231yys.mjs.map +1 -0
  25. package/dist/EmbedWidget-BQyYm50g.cjs +173 -0
  26. package/dist/EmbedWidget-BQyYm50g.cjs.map +1 -0
  27. package/dist/EmbedWidget-DQ2rCA4j.mjs +156 -0
  28. package/dist/EmbedWidget-DQ2rCA4j.mjs.map +1 -0
  29. package/dist/ImageWidget-DBBul7ca.mjs +150 -0
  30. package/dist/ImageWidget-DBBul7ca.mjs.map +1 -0
  31. package/dist/ImageWidget-DTwM7xCz.cjs +167 -0
  32. package/dist/ImageWidget-DTwM7xCz.cjs.map +1 -0
  33. package/dist/LayoutWidget-B1itwSsn.mjs +107 -0
  34. package/dist/LayoutWidget-B1itwSsn.mjs.map +1 -0
  35. package/dist/LayoutWidget-CWE_9JB5.cjs +124 -0
  36. package/dist/LayoutWidget-CWE_9JB5.cjs.map +1 -0
  37. package/dist/ListWidget-CxaLm0D5.cjs +919 -0
  38. package/dist/ListWidget-CxaLm0D5.cjs.map +1 -0
  39. package/dist/ListWidget-EXPlzfUE.mjs +901 -0
  40. package/dist/ListWidget-EXPlzfUE.mjs.map +1 -0
  41. package/dist/MediaRenderer-CcJvyOJ1.cjs +181 -0
  42. package/dist/MediaRenderer-CcJvyOJ1.cjs.map +1 -0
  43. package/dist/MediaRenderer-Uq90PZcY.mjs +163 -0
  44. package/dist/MediaRenderer-Uq90PZcY.mjs.map +1 -0
  45. package/dist/MySiteWidget-BTyb5AJM.mjs +262 -0
  46. package/dist/MySiteWidget-BTyb5AJM.mjs.map +1 -0
  47. package/dist/MySiteWidget-iRPl6b2F.cjs +279 -0
  48. package/dist/MySiteWidget-iRPl6b2F.cjs.map +1 -0
  49. package/dist/NestedWidget-CwyVsZ-f.mjs +330 -0
  50. package/dist/NestedWidget-CwyVsZ-f.mjs.map +1 -0
  51. package/dist/NestedWidget-DavPMVii.cjs +346 -0
  52. package/dist/NestedWidget-DavPMVii.cjs.map +1 -0
  53. package/dist/QuickShareWidget-BIOkquPG.cjs +262 -0
  54. package/dist/QuickShareWidget-BIOkquPG.cjs.map +1 -0
  55. package/dist/QuickShareWidget-BUbuTQFQ.mjs +245 -0
  56. package/dist/QuickShareWidget-BUbuTQFQ.mjs.map +1 -0
  57. package/dist/RecentActivityWidget-CxEgRz3c.mjs +391 -0
  58. package/dist/RecentActivityWidget-CxEgRz3c.mjs.map +1 -0
  59. package/dist/RecentActivityWidget-u1zCrwGF.cjs +408 -0
  60. package/dist/RecentActivityWidget-u1zCrwGF.cjs.map +1 -0
  61. package/dist/RegistryContext-6KXd4t6d.cjs +54 -0
  62. package/dist/RegistryContext-6KXd4t6d.cjs.map +1 -0
  63. package/dist/RegistryContext-CscXrsRa.mjs +36 -0
  64. package/dist/RegistryContext-CscXrsRa.mjs.map +1 -0
  65. package/dist/ScreenRenderer-BCd4Rsba.cjs +82 -0
  66. package/dist/ScreenRenderer-BCd4Rsba.cjs.map +1 -0
  67. package/dist/ScreenRenderer-CVJMpQ9A.mjs +76 -0
  68. package/dist/ScreenRenderer-CVJMpQ9A.mjs.map +1 -0
  69. package/dist/ScreenRendererContext-D62_Fazh.cjs +35 -0
  70. package/dist/ScreenRendererContext-D62_Fazh.cjs.map +1 -0
  71. package/dist/ScreenRendererContext-DaldtZnX.mjs +23 -0
  72. package/dist/ScreenRendererContext-DaldtZnX.mjs.map +1 -0
  73. package/dist/SpacerWidget-Bs18KYH9.mjs +43 -0
  74. package/dist/SpacerWidget-Bs18KYH9.mjs.map +1 -0
  75. package/dist/SpacerWidget-D-Foe9wG.cjs +60 -0
  76. package/dist/SpacerWidget-D-Foe9wG.cjs.map +1 -0
  77. package/dist/TableWidget-BeG92tkU.cjs +455 -0
  78. package/dist/TableWidget-BeG92tkU.cjs.map +1 -0
  79. package/dist/TableWidget-Cc4kQaOE.mjs +438 -0
  80. package/dist/TableWidget-Cc4kQaOE.mjs.map +1 -0
  81. package/dist/TextWidget-CQxOWNZK.mjs +129 -0
  82. package/dist/TextWidget-CQxOWNZK.mjs.map +1 -0
  83. package/dist/TextWidget-Cn7-yZGk.cjs +146 -0
  84. package/dist/TextWidget-Cn7-yZGk.cjs.map +1 -0
  85. package/dist/ToDoWidget--KBpHqbA.mjs +274 -0
  86. package/dist/ToDoWidget--KBpHqbA.mjs.map +1 -0
  87. package/dist/ToDoWidget-CK87BavM.cjs +291 -0
  88. package/dist/ToDoWidget-CK87BavM.cjs.map +1 -0
  89. package/dist/VideoWidget-DxuqyD5L.cjs +209 -0
  90. package/dist/VideoWidget-DxuqyD5L.cjs.map +1 -0
  91. package/dist/VideoWidget-uKkRf5pm.mjs +192 -0
  92. package/dist/VideoWidget-uKkRf5pm.mjs.map +1 -0
  93. package/dist/chunk-CZWwpsFl.cjs +43 -0
  94. package/dist/components/index.cjs +10 -13
  95. package/dist/components/index.cjs.map +1 -1
  96. package/dist/components/index.d.cts +8 -5
  97. package/dist/components/index.d.cts.map +1 -0
  98. package/dist/components/index.d.mts +11 -0
  99. package/dist/components/index.d.mts.map +1 -0
  100. package/dist/components/index.mjs +11 -0
  101. package/dist/components/index.mjs.map +1 -0
  102. package/dist/contexts/index.cjs +8 -29
  103. package/dist/contexts/index.d.cts +20 -14
  104. package/dist/contexts/index.d.cts.map +1 -0
  105. package/dist/contexts/{index.d.ts → index.d.mts} +20 -14
  106. package/dist/contexts/index.d.mts.map +1 -0
  107. package/dist/contexts/index.mjs +3 -0
  108. package/dist/core/index.cjs +37 -41
  109. package/dist/core/index.d.cts +41 -27
  110. package/dist/core/index.d.cts.map +1 -0
  111. package/dist/core/index.d.mts +78 -0
  112. package/dist/core/index.d.mts.map +1 -0
  113. package/dist/core/index.mjs +4 -0
  114. package/dist/error-state-DErSxZwH.mjs +18 -0
  115. package/dist/error-state-DErSxZwH.mjs.map +1 -0
  116. package/dist/error-state-DSzVUtEl.cjs +24 -0
  117. package/dist/error-state-DSzVUtEl.cjs.map +1 -0
  118. package/dist/fields-C29fgJje.mjs +2 -0
  119. package/dist/fields-CzY84PV7.d.cts +2 -0
  120. package/dist/fields-Da4_7j4S.d.mts +2 -0
  121. package/dist/rolldown-runtime-wcPFST8Q.mjs +13 -0
  122. package/dist/scroll-arrows-BZIlsE_x.cjs +35 -0
  123. package/dist/scroll-arrows-BZIlsE_x.cjs.map +1 -0
  124. package/dist/scroll-arrows-BevCYRNT.mjs +29 -0
  125. package/dist/scroll-arrows-BevCYRNT.mjs.map +1 -0
  126. package/dist/ui/index.cjs +69 -45
  127. package/dist/ui/index.d.cts +12 -7
  128. package/dist/ui/index.d.cts.map +1 -0
  129. package/dist/ui/index.d.mts +15 -0
  130. package/dist/ui/index.d.mts.map +1 -0
  131. package/dist/ui/index.mjs +3 -0
  132. package/dist/widgets/index.cjs +88 -209
  133. package/dist/widgets/index.cjs.map +1 -1
  134. package/dist/widgets/index.d.cts +814 -526
  135. package/dist/widgets/index.d.cts.map +1 -0
  136. package/dist/widgets/index.d.mts +892 -0
  137. package/dist/widgets/index.d.mts.map +1 -0
  138. package/dist/widgets/index.mjs +46 -0
  139. package/dist/widgets/index.mjs.map +1 -0
  140. package/package.json +6 -6
  141. package/dist/AlertWidget-3Q4AK7PE.js +0 -5
  142. package/dist/AlertWidget-3Q4AK7PE.js.map +0 -1
  143. package/dist/AlertWidget-C3YMPF7Y.cjs +0 -18
  144. package/dist/AlertWidget-C3YMPF7Y.cjs.map +0 -1
  145. package/dist/CalendarWidget-RAB5VESS.cjs +0 -18
  146. package/dist/CalendarWidget-RAB5VESS.cjs.map +0 -1
  147. package/dist/CalendarWidget-SEYTR3AG.js +0 -5
  148. package/dist/CalendarWidget-SEYTR3AG.js.map +0 -1
  149. package/dist/CarouselWidget-5LFXRR7Y.js +0 -6
  150. package/dist/CarouselWidget-5LFXRR7Y.js.map +0 -1
  151. package/dist/CarouselWidget-G5UHRD6R.cjs +0 -19
  152. package/dist/CarouselWidget-G5UHRD6R.cjs.map +0 -1
  153. package/dist/CatchUpWidget-NEMYZ7L5.js +0 -5
  154. package/dist/CatchUpWidget-NEMYZ7L5.js.map +0 -1
  155. package/dist/CatchUpWidget-XBU2GPFS.cjs +0 -18
  156. package/dist/CatchUpWidget-XBU2GPFS.cjs.map +0 -1
  157. package/dist/ChartWidget-463QVROY.cjs +0 -17
  158. package/dist/ChartWidget-463QVROY.cjs.map +0 -1
  159. package/dist/ChartWidget-554S2GQF.js +0 -4
  160. package/dist/ChartWidget-554S2GQF.js.map +0 -1
  161. package/dist/ContainerWidget-IOXW77X7.cjs +0 -21
  162. package/dist/ContainerWidget-IOXW77X7.cjs.map +0 -1
  163. package/dist/ContainerWidget-OLQPEXDT.js +0 -8
  164. package/dist/ContainerWidget-OLQPEXDT.js.map +0 -1
  165. package/dist/EmbedWidget-B7RFGTJB.js +0 -3
  166. package/dist/EmbedWidget-B7RFGTJB.js.map +0 -1
  167. package/dist/EmbedWidget-RETHBVTD.cjs +0 -16
  168. package/dist/EmbedWidget-RETHBVTD.cjs.map +0 -1
  169. package/dist/ImageWidget-BA2V3DPL.js +0 -4
  170. package/dist/ImageWidget-BA2V3DPL.js.map +0 -1
  171. package/dist/ImageWidget-SBC7LK7A.cjs +0 -17
  172. package/dist/ImageWidget-SBC7LK7A.cjs.map +0 -1
  173. package/dist/LayoutWidget-F3BDSGDP.cjs +0 -20
  174. package/dist/LayoutWidget-F3BDSGDP.cjs.map +0 -1
  175. package/dist/LayoutWidget-MBUJVGKA.js +0 -7
  176. package/dist/LayoutWidget-MBUJVGKA.js.map +0 -1
  177. package/dist/ListWidget-4PKBMBAS.cjs +0 -19
  178. package/dist/ListWidget-4PKBMBAS.cjs.map +0 -1
  179. package/dist/ListWidget-6SZK6X3X.js +0 -6
  180. package/dist/ListWidget-6SZK6X3X.js.map +0 -1
  181. package/dist/MySiteWidget-D6NFECIP.cjs +0 -18
  182. package/dist/MySiteWidget-D6NFECIP.cjs.map +0 -1
  183. package/dist/MySiteWidget-YA4DUIG7.js +0 -5
  184. package/dist/MySiteWidget-YA4DUIG7.js.map +0 -1
  185. package/dist/NestedWidget-UDNHYTMZ.cjs +0 -19
  186. package/dist/NestedWidget-UDNHYTMZ.cjs.map +0 -1
  187. package/dist/NestedWidget-VCZ3JBQY.js +0 -6
  188. package/dist/NestedWidget-VCZ3JBQY.js.map +0 -1
  189. package/dist/QuickShareWidget-LNUEJICJ.cjs +0 -17
  190. package/dist/QuickShareWidget-LNUEJICJ.cjs.map +0 -1
  191. package/dist/QuickShareWidget-SOQEHDR7.js +0 -4
  192. package/dist/QuickShareWidget-SOQEHDR7.js.map +0 -1
  193. package/dist/RecentActivityWidget-HA5N4HCZ.cjs +0 -18
  194. package/dist/RecentActivityWidget-HA5N4HCZ.cjs.map +0 -1
  195. package/dist/RecentActivityWidget-TP32GKHT.js +0 -5
  196. package/dist/RecentActivityWidget-TP32GKHT.js.map +0 -1
  197. package/dist/SpacerWidget-DX7QRN54.cjs +0 -16
  198. package/dist/SpacerWidget-DX7QRN54.cjs.map +0 -1
  199. package/dist/SpacerWidget-H464T5YD.js +0 -3
  200. package/dist/SpacerWidget-H464T5YD.js.map +0 -1
  201. package/dist/TableWidget-D46CWY4M.cjs +0 -18
  202. package/dist/TableWidget-D46CWY4M.cjs.map +0 -1
  203. package/dist/TableWidget-P4C4ZI23.js +0 -5
  204. package/dist/TableWidget-P4C4ZI23.js.map +0 -1
  205. package/dist/TextWidget-GNUQBLDJ.js +0 -4
  206. package/dist/TextWidget-GNUQBLDJ.js.map +0 -1
  207. package/dist/TextWidget-PUZPMPOC.cjs +0 -17
  208. package/dist/TextWidget-PUZPMPOC.cjs.map +0 -1
  209. package/dist/ToDoWidget-AOAMWMN4.js +0 -5
  210. package/dist/ToDoWidget-AOAMWMN4.js.map +0 -1
  211. package/dist/ToDoWidget-L6TXR37G.cjs +0 -18
  212. package/dist/ToDoWidget-L6TXR37G.cjs.map +0 -1
  213. package/dist/VideoWidget-T6S2D4WS.cjs +0 -17
  214. package/dist/VideoWidget-T6S2D4WS.cjs.map +0 -1
  215. package/dist/VideoWidget-TI72FPLK.js +0 -4
  216. package/dist/VideoWidget-TI72FPLK.js.map +0 -1
  217. package/dist/chunk-22AKFT5D.cjs +0 -274
  218. package/dist/chunk-22AKFT5D.cjs.map +0 -1
  219. package/dist/chunk-2NPVYROG.js +0 -117
  220. package/dist/chunk-2NPVYROG.js.map +0 -1
  221. package/dist/chunk-3EGVZDJH.cjs +0 -448
  222. package/dist/chunk-3EGVZDJH.cjs.map +0 -1
  223. package/dist/chunk-4ODOZF7H.js +0 -192
  224. package/dist/chunk-4ODOZF7H.js.map +0 -1
  225. package/dist/chunk-4ZFOJT6H.js +0 -271
  226. package/dist/chunk-4ZFOJT6H.js.map +0 -1
  227. package/dist/chunk-57ZUEL25.js +0 -14
  228. package/dist/chunk-57ZUEL25.js.map +0 -1
  229. package/dist/chunk-5VJYKNCS.cjs +0 -195
  230. package/dist/chunk-5VJYKNCS.cjs.map +0 -1
  231. package/dist/chunk-6GF46P3S.js +0 -33
  232. package/dist/chunk-6GF46P3S.js.map +0 -1
  233. package/dist/chunk-6RNVWRDD.cjs +0 -179
  234. package/dist/chunk-6RNVWRDD.cjs.map +0 -1
  235. package/dist/chunk-6ZECDBGI.js +0 -3
  236. package/dist/chunk-6ZECDBGI.js.map +0 -1
  237. package/dist/chunk-AQO2AKU2.cjs +0 -35
  238. package/dist/chunk-AQO2AKU2.cjs.map +0 -1
  239. package/dist/chunk-D43XJWX3.js +0 -300
  240. package/dist/chunk-D43XJWX3.js.map +0 -1
  241. package/dist/chunk-E5ERYB7Q.js +0 -39
  242. package/dist/chunk-E5ERYB7Q.js.map +0 -1
  243. package/dist/chunk-EPTJJSHT.cjs +0 -500
  244. package/dist/chunk-EPTJJSHT.cjs.map +0 -1
  245. package/dist/chunk-FDAUWHSY.cjs +0 -268
  246. package/dist/chunk-FDAUWHSY.cjs.map +0 -1
  247. package/dist/chunk-FSLUSFJ2.cjs +0 -75
  248. package/dist/chunk-FSLUSFJ2.cjs.map +0 -1
  249. package/dist/chunk-GC4SZ75B.js +0 -47
  250. package/dist/chunk-GC4SZ75B.js.map +0 -1
  251. package/dist/chunk-HDUFHTQC.js +0 -1024
  252. package/dist/chunk-HDUFHTQC.js.map +0 -1
  253. package/dist/chunk-HREBEVS5.cjs +0 -42
  254. package/dist/chunk-HREBEVS5.cjs.map +0 -1
  255. package/dist/chunk-IF36TB2H.js +0 -459
  256. package/dist/chunk-IF36TB2H.js.map +0 -1
  257. package/dist/chunk-J6HCPXT5.cjs +0 -40
  258. package/dist/chunk-J6HCPXT5.cjs.map +0 -1
  259. package/dist/chunk-JIS2K5YR.js +0 -13
  260. package/dist/chunk-JIS2K5YR.js.map +0 -1
  261. package/dist/chunk-JYWKXNUO.cjs +0 -37
  262. package/dist/chunk-JYWKXNUO.cjs.map +0 -1
  263. package/dist/chunk-KYCPG2DN.cjs +0 -17
  264. package/dist/chunk-KYCPG2DN.cjs.map +0 -1
  265. package/dist/chunk-L3HN4J2Y.js +0 -175
  266. package/dist/chunk-L3HN4J2Y.js.map +0 -1
  267. package/dist/chunk-LZJVUYSQ.cjs +0 -462
  268. package/dist/chunk-LZJVUYSQ.cjs.map +0 -1
  269. package/dist/chunk-MXWFM5J2.js +0 -493
  270. package/dist/chunk-MXWFM5J2.js.map +0 -1
  271. package/dist/chunk-NPTCR22X.cjs +0 -1031
  272. package/dist/chunk-NPTCR22X.cjs.map +0 -1
  273. package/dist/chunk-P4VXS3BG.cjs +0 -464
  274. package/dist/chunk-P4VXS3BG.cjs.map +0 -1
  275. package/dist/chunk-P6AKK6TA.cjs +0 -382
  276. package/dist/chunk-P6AKK6TA.cjs.map +0 -1
  277. package/dist/chunk-PLXOZ5BH.cjs +0 -140
  278. package/dist/chunk-PLXOZ5BH.cjs.map +0 -1
  279. package/dist/chunk-Q5YXTDPX.cjs +0 -150
  280. package/dist/chunk-Q5YXTDPX.cjs.map +0 -1
  281. package/dist/chunk-QB6UW6DD.js +0 -250
  282. package/dist/chunk-QB6UW6DD.js.map +0 -1
  283. package/dist/chunk-QG2INAJC.js +0 -461
  284. package/dist/chunk-QG2INAJC.js.map +0 -1
  285. package/dist/chunk-QXIIJNQK.cjs +0 -15
  286. package/dist/chunk-QXIIJNQK.cjs.map +0 -1
  287. package/dist/chunk-RKDOQV4T.js +0 -73
  288. package/dist/chunk-RKDOQV4T.js.map +0 -1
  289. package/dist/chunk-ROLEPF3N.js +0 -399
  290. package/dist/chunk-ROLEPF3N.js.map +0 -1
  291. package/dist/chunk-RPNLSRUS.cjs +0 -120
  292. package/dist/chunk-RPNLSRUS.cjs.map +0 -1
  293. package/dist/chunk-SINQXEBL.js +0 -160
  294. package/dist/chunk-SINQXEBL.js.map +0 -1
  295. package/dist/chunk-SLGOKKU7.cjs +0 -402
  296. package/dist/chunk-SLGOKKU7.cjs.map +0 -1
  297. package/dist/chunk-U6ODF4YB.cjs +0 -303
  298. package/dist/chunk-U6ODF4YB.cjs.map +0 -1
  299. package/dist/chunk-UXFD52LT.js +0 -137
  300. package/dist/chunk-UXFD52LT.js.map +0 -1
  301. package/dist/chunk-UZ7TYGUO.js +0 -147
  302. package/dist/chunk-UZ7TYGUO.js.map +0 -1
  303. package/dist/chunk-UZF75XZJ.js +0 -379
  304. package/dist/chunk-UZF75XZJ.js.map +0 -1
  305. package/dist/chunk-WTQNKZKV.cjs +0 -253
  306. package/dist/chunk-WTQNKZKV.cjs.map +0 -1
  307. package/dist/chunk-WWKBIVET.cjs +0 -163
  308. package/dist/chunk-WWKBIVET.cjs.map +0 -1
  309. package/dist/chunk-YDLNXR7R.js +0 -265
  310. package/dist/chunk-YDLNXR7R.js.map +0 -1
  311. package/dist/chunk-YOJRRPOG.js +0 -33
  312. package/dist/chunk-YOJRRPOG.js.map +0 -1
  313. package/dist/chunk-YU5DAILW.cjs +0 -14
  314. package/dist/chunk-YU5DAILW.cjs.map +0 -1
  315. package/dist/chunk-YZATKTYO.cjs +0 -50
  316. package/dist/chunk-YZATKTYO.cjs.map +0 -1
  317. package/dist/chunk-ZLTPLVOF.js +0 -445
  318. package/dist/chunk-ZLTPLVOF.js.map +0 -1
  319. package/dist/chunk-ZWFK5UUU.js +0 -11
  320. package/dist/chunk-ZWFK5UUU.js.map +0 -1
  321. package/dist/components/index.d.ts +0 -8
  322. package/dist/components/index.js +0 -11
  323. package/dist/components/index.js.map +0 -1
  324. package/dist/contexts/index.cjs.map +0 -1
  325. package/dist/contexts/index.js +0 -4
  326. package/dist/contexts/index.js.map +0 -1
  327. package/dist/core/index.cjs.map +0 -1
  328. package/dist/core/index.d.ts +0 -64
  329. package/dist/core/index.js +0 -6
  330. package/dist/core/index.js.map +0 -1
  331. package/dist/ui/index.cjs.map +0 -1
  332. package/dist/ui/index.d.ts +0 -10
  333. package/dist/ui/index.js +0 -4
  334. package/dist/ui/index.js.map +0 -1
  335. package/dist/widgets/index.d.ts +0 -604
  336. package/dist/widgets/index.js +0 -55
  337. package/dist/widgets/index.js.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/widgets/TableWidget.tsx"],"names":["jsx","MediaRenderer","getMediaPropsFromShareable","useState","useMemo","jsxs","Input","getFontSizeField","getColorField","getPaddingField","getBorderRadiusField"],"mappings":"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","file":"chunk-LZJVUYSQ.cjs","sourcesContent":["import { useState, useMemo, type ComponentProps } from \"react\";\nimport type {\n BackgroundValue,\n BorderRadiusOptions,\n ColorOptions,\n FontSizeOptions,\n PaddingOptions,\n} from \"@fluid-app/rep-core/types\";\nimport type { WidgetPropertySchema } from \"@fluid-app/rep-core/registries\";\nimport {\n getBorderRadiusField,\n getColorField,\n getFontSizeField,\n getPaddingField,\n} from \"../core/fields\";\nimport { Input } from \"@fluid-app/ui-primitives\";\nimport {\n MediaRenderer,\n getMediaPropsFromShareable,\n} from \"../components/MediaRenderer\";\nimport { type ShareableItem } from \"@fluid-app/rep-core/types\";\n\n// Column definition for the table\ntype ColumnDef = {\n key: string;\n label: string;\n sortable: boolean;\n render?: (value: unknown, item: ShareableItem) => React.ReactNode;\n};\n\nconst DEFAULT_DATA: ShareableItem[] = [];\n\n// ---------------------------------------------------------------------------\n// Column cell renderers\n// ---------------------------------------------------------------------------\n\nfunction ImageCellRenderer(_value: unknown, item: ShareableItem) {\n return (\n <div className=\"h-10 w-10 rounded object-cover\">\n <MediaRenderer {...getMediaPropsFromShareable(item)} />\n </div>\n );\n}\n\nfunction PriceCellRenderer(_value: unknown, item: ShareableItem) {\n return ((item.display_price as string) ?? item.price) || \"-\";\n}\n\nfunction StatusCellRenderer(value: unknown) {\n const status = String(value || \"unknown\").toLowerCase();\n const statusStyles: Record<string, string> = {\n active: \"bg-primary text-primary-foreground\",\n inactive: \"bg-secondary text-secondary-foreground\",\n unknown: \"bg-muted text-muted-foreground\",\n };\n return (\n <span\n className={`inline-flex rounded-full px-2 py-1 text-xs font-medium ${statusStyles[status] || \"bg-muted text-foreground\"}`}\n >\n {String(value || \"Unknown\")}\n </span>\n );\n}\n\n// Default columns for product data\nconst defaultColumns: ColumnDef[] = [\n {\n key: \"imageUrl\",\n label: \"Image\",\n sortable: false,\n render: ImageCellRenderer,\n },\n {\n key: \"title\",\n label: \"Title\",\n sortable: true,\n },\n {\n key: \"price\",\n label: \"Price\",\n sortable: true,\n render: PriceCellRenderer,\n },\n {\n key: \"status\",\n label: \"Status\",\n sortable: true,\n render: StatusCellRenderer,\n },\n];\n\ntype TableWidgetProps = ComponentProps<\"div\"> & {\n // Title\n titleEnabled?: boolean;\n titleText?: string;\n titleFontSize?: FontSizeOptions;\n titleColor?: ColorOptions;\n\n // Styling\n background?: BackgroundValue;\n alternatingColorEnabled?: boolean;\n textColor?: ColorOptions;\n headerBackgroundColor?: ColorOptions;\n headerTextColor?: ColorOptions;\n padding?: PaddingOptions;\n borderRadius?: BorderRadiusOptions;\n\n // Data\n data?: ShareableItem[];\n\n // Features\n filterEnabled?: boolean;\n sortingEnabled?: boolean;\n paginationEnabled?: boolean;\n maxRowsPerPage?: number;\n};\n\nexport function TableWidget({\n // Title defaults\n titleEnabled = true,\n titleText = \"Products\",\n titleFontSize = \"xl\",\n titleColor = \"foreground\",\n\n // Styling defaults\n background = {\n type: \"solid\",\n color: \"background\",\n },\n alternatingColorEnabled = true,\n textColor = \"foreground\",\n headerBackgroundColor = \"muted\",\n headerTextColor = \"foreground\",\n padding = 4,\n borderRadius = \"md\",\n\n // Data\n data = DEFAULT_DATA,\n\n // Feature defaults\n filterEnabled = true,\n sortingEnabled = true,\n paginationEnabled = true,\n maxRowsPerPage = 5,\n\n className,\n ...props\n}: TableWidgetProps) {\n const backgroundColor = background.color || \"background\";\n const backgroundImage =\n (background.resource?.image_url || background.resource?.imageUrl) &&\n background.type === \"image\"\n ? `url(${background.resource.image_url || background.resource.imageUrl})`\n : \"none\";\n const pageSize = maxRowsPerPage;\n\n // State for filtering, sorting, and pagination\n const [globalFilter, setGlobalFilter] = useState(\"\");\n const [sortConfig, setSortConfig] = useState<{\n key: string;\n direction: \"asc\" | \"desc\";\n } | null>(null);\n const [currentPage, setCurrentPage] = useState(1);\n\n const columns = defaultColumns;\n\n // Filter data\n const filteredData = useMemo(() => {\n let result = [...data];\n\n if (globalFilter) {\n const lowerFilter = globalFilter.toLowerCase();\n result = result.filter((item) =>\n columns.some((col) => {\n const value = item[col.key];\n return String(value ?? \"\")\n .toLowerCase()\n .includes(lowerFilter);\n }),\n );\n }\n\n return result;\n }, [data, globalFilter, columns]);\n\n // Sort data\n const sortedData = useMemo(() => {\n if (!sortConfig) return filteredData;\n\n return [...filteredData].sort((a, b) => {\n const aValue = a[sortConfig.key];\n const bValue = b[sortConfig.key];\n\n // Handle null/undefined\n if (aValue == null && bValue == null) return 0;\n if (aValue == null) return sortConfig.direction === \"asc\" ? 1 : -1;\n if (bValue == null) return sortConfig.direction === \"asc\" ? -1 : 1;\n\n // Compare values\n let comparison = 0;\n if (typeof aValue === \"number\" && typeof bValue === \"number\") {\n comparison = aValue - bValue;\n } else {\n comparison = String(aValue).localeCompare(String(bValue));\n }\n\n return sortConfig.direction === \"asc\" ? comparison : -comparison;\n });\n }, [filteredData, sortConfig]);\n\n // Paginate data\n const paginatedData = useMemo(() => {\n if (!paginationEnabled) return sortedData;\n\n const startIndex = (currentPage - 1) * pageSize;\n return sortedData.slice(startIndex, startIndex + pageSize);\n }, [sortedData, currentPage, pageSize, paginationEnabled]);\n\n const totalPages = Math.ceil(sortedData.length / pageSize);\n\n // Reset to page 1 when filters change\n const handleGlobalFilterChange = (value: string) => {\n setGlobalFilter(value);\n setCurrentPage(1);\n };\n\n // Handle sort\n const handleSort = (key: string) => {\n if (!sortingEnabled) return;\n\n setSortConfig((prev) => {\n if (prev?.key !== key) return { key, direction: \"asc\" };\n if (prev.direction === \"asc\") return { key, direction: \"desc\" };\n return null;\n });\n };\n\n // Get sort indicator\n const getSortIndicator = (key: string) => {\n if (sortConfig?.key !== key) return null;\n return sortConfig.direction === \"asc\" ? \" ↑\" : \" ↓\";\n };\n\n // Empty state\n if (data.length === 0) {\n return (\n <div\n className={`@container rounded-${borderRadius} bg-${backgroundColor} p-${padding} ${className}`}\n style={{ backgroundImage }}\n {...props}\n >\n <div className=\"text-muted-foreground flex min-h-[200px] flex-col items-center justify-center gap-2\">\n <div className=\"text-4xl\">📋</div>\n <p className=\"text-sm\">No data available</p>\n <p className=\"text-muted-foreground/70 text-xs\">\n Connect a data source to display table data\n </p>\n </div>\n </div>\n );\n }\n\n return (\n <div\n className={`@container overflow-hidden ${paginationEnabled ? \"\" : \"overflow-y-auto\"} rounded-${borderRadius} text-${textColor} ${className}`}\n style={{ backgroundImage }}\n {...props}\n >\n <div\n className={`flex items-center justify-between p-${padding} bg-${backgroundColor}`}\n >\n {/* Title */}\n {titleEnabled && titleText && (\n <h2\n className={`text-${titleFontSize === \"md\" ? \"base\" : titleFontSize} font-bold text-${titleColor}`}\n >\n {titleText}\n </h2>\n )}\n\n {/* Global Search */}\n {filterEnabled && (\n <Input\n type=\"text\"\n placeholder=\"Search all columns...\"\n value={globalFilter}\n onChange={(e: React.ChangeEvent<HTMLInputElement>) =>\n handleGlobalFilterChange(e.target.value)\n }\n className={`w-full rounded-md border border-${headerBackgroundColor}-600 bg-${headerBackgroundColor}-400 ring-offset-muted px-3 py-2 text-sm placeholder:text-${headerTextColor}-900 focus-visible:ring-primary focus-visible:ring-2 focus-visible:ring-offset-2 focus-visible:outline-none md:w-64`}\n />\n )}\n </div>\n\n {/* Table */}\n <div className=\"overflow-x-auto\">\n <table className=\"w-full border-collapse\">\n <thead>\n <tr\n className={`bg-${headerBackgroundColor}-400 border-${headerBackgroundColor}-600 border-y`}\n >\n {columns.map((col) => (\n <th\n key={col.key}\n className={`px-4 py-3 text-left text-sm font-semibold text-${headerTextColor} ${col.sortable && sortingEnabled ? \"cursor-pointer select-none hover:opacity-80\" : \"\"}`}\n {...(col.sortable && sortingEnabled\n ? {\n role: \"button\" as const,\n tabIndex: 0,\n onClick: () => handleSort(col.key),\n onKeyDown: (e: React.KeyboardEvent) => {\n if (e.key === \"Enter\" || e.key === \" \") {\n e.preventDefault();\n handleSort(col.key);\n }\n },\n }\n : {})}\n >\n <div className=\"flex flex-col gap-1\">\n <span>\n {col.label}\n {col.sortable &&\n sortingEnabled &&\n getSortIndicator(col.key)}\n </span>\n </div>\n </th>\n ))}\n </tr>\n </thead>\n <tbody>\n {paginatedData.map((item, index) => (\n <tr\n key={item.id ?? index}\n className={`h-17 border-b border-${backgroundColor}-600 last:border-none bg-${backgroundColor} ${alternatingColorEnabled ? `even:bg-${backgroundColor}-400` : \"\"}`}\n >\n {columns.map((col) => (\n <td key={col.key} className=\"px-4 py-3 text-sm\">\n {col.render\n ? col.render(item[col.key], item)\n : String(item[col.key] ?? \"-\")}\n </td>\n ))}\n </tr>\n ))}\n {/* Empty rows to fill the last page for consistent pagination position */}\n {paginationEnabled &&\n paginatedData.length < pageSize &&\n paginatedData.length > 0 &&\n Array.from({ length: pageSize - paginatedData.length }).map(\n (_, index) => (\n <tr\n key={`empty-${index}`}\n className={`h-17 border-b border-${backgroundColor}-600 last:border-none bg-${backgroundColor} ${alternatingColorEnabled ? `even:bg-${backgroundColor}-400` : \"\"}`}\n >\n {columns.map((col) => (\n <td key={col.key} className=\"px-4 py-3 text-sm\">\n &nbsp;\n </td>\n ))}\n </tr>\n ),\n )}\n </tbody>\n </table>\n </div>\n\n {/* No results message */}\n {paginatedData.length === 0 && data.length > 0 && (\n <div className={`py-8 text-center bg-${backgroundColor}`}>\n <p className=\"text-sm\">No results found</p>\n <p className=\"text-xs\">Try adjusting your search</p>\n </div>\n )}\n\n {/* Pagination */}\n {paginationEnabled && totalPages > 1 && (\n <div\n className={`flex flex-col items-center justify-between gap-2 border-t border-${backgroundColor}-600 p-${padding} @md:flex-row bg-${backgroundColor}-400 text-${textColor}`}\n >\n <p className=\"text-sm\">\n Showing {(currentPage - 1) * pageSize + 1}-\n {Math.min(currentPage * pageSize, sortedData.length)} of{\" \"}\n {sortedData.length} results\n </p>\n <div className=\"flex items-center gap-2\">\n <button\n onClick={() => setCurrentPage((p) => Math.max(1, p - 1))}\n disabled={currentPage === 1}\n className={`rounded-md border border-${headerBackgroundColor}-600 bg-${headerBackgroundColor} ring-offset-muted placeholder:text-muted-foreground focus-visible:ring-primary px-3 py-1 text-sm transition-opacity hover:opacity-80 focus-visible:ring-2 focus-visible:ring-offset-2 focus-visible:outline-none disabled:cursor-not-allowed disabled:opacity-50`}\n >\n Previous\n </button>\n <span className=\"text-sm\">\n Page {currentPage} of {totalPages}\n </span>\n <button\n onClick={() => setCurrentPage((p) => Math.min(totalPages, p + 1))}\n disabled={currentPage === totalPages}\n className={`rounded-md border border-${headerBackgroundColor}-600 bg-${headerBackgroundColor} ring-offset-muted placeholder:text-muted-foreground focus-visible:ring-primary px-3 py-1 text-sm transition-opacity hover:opacity-80 focus-visible:ring-2 focus-visible:ring-offset-2 focus-visible:outline-none disabled:cursor-not-allowed disabled:opacity-50`}\n >\n Next\n </button>\n </div>\n </div>\n )}\n </div>\n );\n}\n\nexport const tableWidgetPropertySchema: WidgetPropertySchema = {\n widgetType: \"TableWidget\",\n displayName: \"Table Widget\",\n tabsConfig: [\n { id: \"styling\", label: \"Styling\" },\n { id: \"behavior\", label: \"Behavior\" },\n { id: \"data\", label: \"Data\" },\n ],\n dataSourceTargetProps: [\"data\"],\n fields: [\n // Content Tab - Title Group\n {\n key: \"titleEnabled\",\n label: \"Widget Title\",\n type: \"boolean\",\n description: \"Enable the title displayed above the table\",\n defaultValue: true,\n tab: \"styling\",\n group: \"Title\",\n },\n {\n key: \"titleText\",\n label: \"Title\",\n type: \"text\",\n description: \"Title text displayed above the table\",\n defaultValue: \"Products\",\n tab: \"styling\",\n group: \"Title\",\n requiresKeyToBeTrue: \"titleEnabled\",\n },\n getFontSizeField({\n label: \"Title Font Size\",\n defaultValue: \"xl\",\n key: \"titleFontSize\",\n description: \"Font size for the widget title\",\n tab: \"styling\",\n group: \"Title\",\n requiresKeyToBeTrue: \"titleEnabled\",\n }),\n getColorField({\n key: \"titleColor\",\n label: \"Title Color\",\n description: \"Color for the widget title\",\n defaultValue: \"foreground\",\n tab: \"styling\",\n group: \"Title\",\n requiresKeyToBeTrue: \"titleEnabled\",\n }),\n\n // Styling Tab - Design Group\n {\n type: \"background\",\n key: \"background\",\n label: \"Background\",\n description: \"Background for the table container\",\n defaultValue: \"background\",\n tab: \"styling\",\n group: \"Design\",\n },\n {\n key: \"alternatingColorEnabled\",\n label: \"Enable Alternating Colors\",\n type: \"boolean\",\n description: \"Enable alternating colors for table rows\",\n defaultValue: true,\n tab: \"styling\",\n group: \"Design\",\n },\n getColorField({\n key: \"headerBackgroundColor\",\n label: \"Header Background\",\n description: \"Background color for the table header\",\n defaultValue: \"muted\",\n tab: \"styling\",\n group: \"Design\",\n }),\n getColorField({\n key: \"textColor\",\n label: \"Text Color\",\n description: \"Default text color for table content\",\n defaultValue: \"foreground\",\n tab: \"styling\",\n group: \"Design\",\n }),\n getColorField({\n key: \"headerTextColor\",\n label: \"Header Text Color\",\n description: \"Text color for the table header\",\n defaultValue: \"foreground\",\n tab: \"styling\",\n group: \"Design\",\n }),\n {\n key: \"separator\",\n type: \"separator\",\n label: \"Separator\",\n tab: \"styling\",\n group: \"Design\",\n },\n getPaddingField({\n key: \"padding\",\n label: \"Padding\",\n description: \"Padding around the table container\",\n defaultValue: 4,\n tab: \"styling\",\n group: \"Design\",\n }),\n getBorderRadiusField({\n key: \"borderRadius\",\n label: \"Border Radius\",\n description: \"Border radius for the table container\",\n defaultValue: \"md\",\n tab: \"styling\",\n group: \"Design\",\n }),\n\n // Behavior Tab - Features Group\n {\n key: \"filterEnabled\",\n label: \"Enable Filters\",\n type: \"boolean\",\n description: \"Show global search and column filters\",\n defaultValue: true,\n tab: \"behavior\",\n group: \"Features\",\n },\n {\n key: \"sortingEnabled\",\n label: \"Enable Sorting\",\n type: \"boolean\",\n description: \"Allow sorting by clicking column headers\",\n defaultValue: true,\n tab: \"behavior\",\n group: \"Features\",\n },\n {\n key: \"paginationEnabled\",\n label: \"Enable Pagination\",\n type: \"boolean\",\n description: \"Split data into pages\",\n defaultValue: true,\n tab: \"behavior\",\n group: \"Features\",\n },\n {\n key: \"maxRowsPerPage\",\n label: \"Max Rows Per Page\",\n type: \"number\",\n description: \"Maximum number of rows to display per page\",\n min: 1,\n max: 50,\n step: 1,\n defaultValue: 5,\n tab: \"behavior\",\n group: \"Features\",\n requiresKeyToBeTrue: \"paginationEnabled\",\n },\n\n // Data Tab\n {\n key: \"dataSource\",\n label: \"Data Source\",\n type: \"dataSource\",\n description: \"Configure data source for the table\",\n tab: \"data\",\n group: \"Data Configuration\",\n },\n ],\n} as const satisfies WidgetPropertySchema;\n"]}
@@ -1,493 +0,0 @@
1
- import { MediaRenderer, getMediaPropsFromWidgetSchema } from './chunk-L3HN4J2Y.js';
2
- import { ScrollArrows } from './chunk-YOJRRPOG.js';
3
- import { getFontSizeField, getColorField, getBorderRadiusField, getPaddingField, getButtonSizeField } from './chunk-6ZECDBGI.js';
4
- import DOMPurify from 'dompurify';
5
- import { Button } from '@fluid-app/ui-primitives';
6
- import { useState, useCallback, useEffect } from 'react';
7
- import { getHeightField } from '@fluid-app/rep-core/registries';
8
- import { jsx, jsxs } from 'react/jsx-runtime';
9
-
10
- var DEFAULT_SLIDES = [];
11
- function CarouselWidget({
12
- slides = DEFAULT_SLIDES,
13
- autoScrollInterval = 3e3,
14
- enableAutoScroll = false,
15
- carouselHeight = "400px",
16
- align = { vertical: "bottom", horizontal: "left" },
17
- overlayIntensity = 40,
18
- borderRadius = "none",
19
- padding = 0,
20
- textWidth = "100%",
21
- headerSize = "lg",
22
- headerColor = "background",
23
- textSize = "md",
24
- textColor = "background",
25
- showButton = true,
26
- buttonColor = "background",
27
- buttonSize = "default",
28
- overlayEnabled = true,
29
- overlayType = "solid",
30
- className,
31
- ...props
32
- }) {
33
- const [currentIndex, setCurrentIndex] = useState(0);
34
- const [isHovered, setIsHovered] = useState(false);
35
- const hasSlides = slides.length > 0;
36
- const totalSlides = slides.length;
37
- const goToNext = useCallback(() => {
38
- if (!hasSlides) return;
39
- setCurrentIndex((prev) => {
40
- if (prev === totalSlides - 1) {
41
- return 0;
42
- }
43
- return prev + 1;
44
- });
45
- }, [hasSlides, totalSlides]);
46
- const goToPrevious = useCallback(() => {
47
- if (!hasSlides) return;
48
- setCurrentIndex((prev) => {
49
- if (prev === 0) {
50
- return totalSlides - 1;
51
- }
52
- return prev - 1;
53
- });
54
- }, [hasSlides, totalSlides]);
55
- const goToSlide = useCallback(
56
- (index) => {
57
- if (!hasSlides) return;
58
- if (index >= 0 && index < totalSlides) {
59
- setCurrentIndex(index);
60
- }
61
- },
62
- [hasSlides, totalSlides]
63
- );
64
- useEffect(() => {
65
- if (!enableAutoScroll || !hasSlides || isHovered) return;
66
- const intervalId = setInterval(() => {
67
- goToNext();
68
- }, autoScrollInterval);
69
- return () => clearInterval(intervalId);
70
- }, [enableAutoScroll, autoScrollInterval, hasSlides, isHovered, goToNext]);
71
- useEffect(() => {
72
- if (currentIndex >= totalSlides && totalSlides > 0) {
73
- setCurrentIndex(0);
74
- }
75
- }, [totalSlides, currentIndex]);
76
- if (!hasSlides) {
77
- return /* @__PURE__ */ jsx(
78
- "div",
79
- {
80
- className: `rounded-${borderRadius} ${className} w-full overflow-hidden`,
81
- style: { minHeight: carouselHeight },
82
- ...props,
83
- children: /* @__PURE__ */ jsx(
84
- "div",
85
- {
86
- className: "bg-muted flex h-full w-full items-center justify-center",
87
- style: { minHeight: carouselHeight },
88
- children: /* @__PURE__ */ jsxs("div", { className: "text-muted-foreground flex flex-col items-center gap-2", children: [
89
- /* @__PURE__ */ jsx("div", { className: "text-4xl", children: "\u{1F3A0}" }),
90
- /* @__PURE__ */ jsx("p", { className: "text-sm", children: "No slides added" }),
91
- /* @__PURE__ */ jsx("p", { className: "text-muted-foreground/70 text-xs", children: "Add slides to create a carousel" })
92
- ] })
93
- }
94
- )
95
- }
96
- );
97
- }
98
- return /* @__PURE__ */ jsxs(
99
- "div",
100
- {
101
- className: `relative w-full overflow-hidden rounded-${borderRadius} ${className}`,
102
- style: { minHeight: carouselHeight },
103
- onMouseEnter: () => setIsHovered(true),
104
- onMouseLeave: () => setIsHovered(false),
105
- ...props,
106
- children: [
107
- /* @__PURE__ */ jsx(
108
- "div",
109
- {
110
- className: "relative h-full w-full",
111
- style: { minHeight: carouselHeight },
112
- children: /* @__PURE__ */ jsx(
113
- "div",
114
- {
115
- className: "flex h-full transition-transform duration-500 ease-in-out",
116
- style: {
117
- transform: `translateX(-${currentIndex * 100}%)`
118
- },
119
- children: slides.map((slide) => /* @__PURE__ */ jsxs(
120
- "div",
121
- {
122
- className: "relative h-full w-full flex-shrink-0",
123
- style: { minWidth: "100%", minHeight: carouselHeight },
124
- children: [
125
- /* @__PURE__ */ jsx("div", { className: "absolute inset-0 h-full w-full", children: /* @__PURE__ */ jsx(
126
- MediaRenderer,
127
- {
128
- ...getMediaPropsFromWidgetSchema(slide.content)
129
- }
130
- ) }),
131
- overlayEnabled && /* @__PURE__ */ jsx(
132
- "div",
133
- {
134
- className: `absolute inset-0 z-9 ${overlayType === "gradient" ? "bg-gradient-to-t from-black to-transparent" : "bg-black"}`,
135
- style: {
136
- opacity: (Number(String(overlayIntensity).replace("%", "")) || 40) / 100
137
- }
138
- }
139
- ),
140
- /* @__PURE__ */ jsx(
141
- "div",
142
- {
143
- className: `absolute inset-x-0 z-10 flex px-3 ${align.horizontal === "left" ? "justify-start" : align.horizontal === "center" ? "justify-center" : "justify-end"} ${align.vertical === "top" ? "top-0 pt-13" : align.vertical === "center" ? "top-1/2 -translate-y-1/2" : "bottom-0 pb-13"}`,
144
- children: /* @__PURE__ */ jsxs(
145
- "div",
146
- {
147
- className: `p-${padding} flex flex-col gap-3`,
148
- style: { maxWidth: textWidth },
149
- children: [
150
- /* @__PURE__ */ jsxs("div", { className: `flex flex-col text-${align.horizontal}`, children: [
151
- slide.title && /* @__PURE__ */ jsx(
152
- "h2",
153
- {
154
- className: `mb-2 leading-tight font-bold text-${headerColor} text-${headerSize === "md" ? "base" : headerSize}`,
155
- children: slide.title
156
- }
157
- ),
158
- slide.description && /* @__PURE__ */ jsx(
159
- "div",
160
- {
161
- className: `leading-snug text-${textColor} text-${textSize === "md" ? "base" : textSize} line-clamp-2`,
162
- dangerouslySetInnerHTML: {
163
- __html: DOMPurify.sanitize(slide.description, {
164
- ALLOWED_TAGS: [
165
- "br",
166
- "strong",
167
- "em",
168
- "b",
169
- "i",
170
- "ul",
171
- "ol",
172
- "li",
173
- "p"
174
- ],
175
- ALLOWED_ATTR: []
176
- })
177
- }
178
- }
179
- )
180
- ] }),
181
- slide.buttonText && slide.buttonEnabled && showButton && /* @__PURE__ */ jsx("div", { className: `text-${align.horizontal}`, children: /* @__PURE__ */ jsx(
182
- Button,
183
- {
184
- size: buttonSize,
185
- className: `rounded-md py-1 font-semibold bg-${buttonColor} text-${buttonColor}-foreground hover:bg-${buttonColor}/90`,
186
- asChild: true,
187
- children: /* @__PURE__ */ jsx("a", { href: slide.buttonLink, children: slide.buttonText })
188
- }
189
- ) })
190
- ]
191
- }
192
- )
193
- }
194
- )
195
- ]
196
- },
197
- slide.id
198
- ))
199
- }
200
- )
201
- }
202
- ),
203
- totalSlides > 1 && /* @__PURE__ */ jsxs(
204
- "div",
205
- {
206
- className: `p-${padding} absolute bottom-0 z-10 flex w-full items-center justify-between ${align.horizontal === "center" ? "h-full" : ""}`,
207
- children: [
208
- /* @__PURE__ */ jsx(
209
- "div",
210
- {
211
- className: `flex items-center ${align.horizontal === "center" ? `p-${padding} absolute inset-x-0 bottom-3 justify-center` : ""}`,
212
- children: /* @__PURE__ */ jsx(
213
- "div",
214
- {
215
- className: `flex items-center gap-2 ${align.horizontal === "center" ? "justify-center" : ""}`,
216
- children: slides.map((_, index) => /* @__PURE__ */ jsx(
217
- "button",
218
- {
219
- className: `h-[6px] w-[6px] rounded-full transition-colors ${index === currentIndex ? "bg-background" : "bg-background/40 hover:bg-background/60"}`,
220
- onClick: () => goToSlide(index),
221
- "aria-label": `Go to slide ${index + 1}`,
222
- "aria-current": index === currentIndex ? "true" : "false"
223
- },
224
- `dot-${index}`
225
- ))
226
- }
227
- )
228
- }
229
- ),
230
- /* @__PURE__ */ jsx(
231
- "div",
232
- {
233
- className: `flex items-center gap-[10px] ${align.horizontal === "center" ? `absolute inset-x-0 top-1/2 justify-between px-${padding}` : ""}`,
234
- children: /* @__PURE__ */ jsx(ScrollArrows, { onPrevious: goToPrevious, onNext: goToNext })
235
- }
236
- )
237
- ]
238
- }
239
- )
240
- ]
241
- }
242
- );
243
- }
244
- var carouselWidgetPropertySchema = {
245
- widgetType: "CarouselWidget",
246
- displayName: "Carousel",
247
- tabsConfig: [
248
- { id: "styling", label: "Styling" },
249
- { id: "behavior", label: "Behavior" },
250
- { id: "data", label: "Data" }
251
- ],
252
- dataSourceTargetProps: ["slides"],
253
- fields: [
254
- // Styling tab - Text Styling group
255
- getFontSizeField({
256
- defaultValue: "lg",
257
- key: "headerSize",
258
- label: "Header Font Size",
259
- description: "Font size for the slide header",
260
- tab: "styling",
261
- group: "Text Styling"
262
- }),
263
- getColorField({
264
- defaultValue: "background",
265
- key: "headerColor",
266
- label: "Header Color",
267
- description: "Color variant for the slide header",
268
- tab: "styling",
269
- group: "Text Styling"
270
- }),
271
- {
272
- key: "separator",
273
- type: "separator",
274
- label: "Separator",
275
- tab: "styling",
276
- group: "Text Styling"
277
- },
278
- getFontSizeField({
279
- defaultValue: "md",
280
- key: "textSize",
281
- label: "Text Font Size",
282
- description: "Font size for the slide text",
283
- tab: "styling",
284
- group: "Text Styling"
285
- }),
286
- getColorField({
287
- defaultValue: "background",
288
- key: "textColor",
289
- label: "Text Color",
290
- description: "Color variant for the slide text",
291
- tab: "styling",
292
- group: "Text Styling"
293
- }),
294
- // Styling tab - Layout group
295
- {
296
- key: "align",
297
- label: "Alignment",
298
- type: "alignment",
299
- description: "Alignment of the carousel content",
300
- defaultValue: { vertical: "bottom", horizontal: "left" },
301
- options: {
302
- verticalEnabled: true,
303
- horizontalEnabled: true
304
- },
305
- tab: "styling",
306
- group: "Layout"
307
- },
308
- {
309
- key: "textWidth",
310
- label: "Content Width",
311
- type: "text",
312
- description: "Maximum width for slide content (e.g., 100%, 50%, 600px)",
313
- defaultValue: "100%",
314
- tab: "styling",
315
- group: "Layout"
316
- },
317
- // Styling tab - Design group
318
- getHeightField({
319
- key: "carouselHeight",
320
- label: "Carousel Height",
321
- description: "Height of the carousel",
322
- min: 100,
323
- max: 1200,
324
- step: 10,
325
- defaultValue: "400px",
326
- tab: "styling",
327
- group: "Design"
328
- }),
329
- {
330
- key: "separator2",
331
- type: "separator",
332
- label: "Separator",
333
- tab: "styling",
334
- group: "Design"
335
- },
336
- getBorderRadiusField({
337
- defaultValue: "md",
338
- key: "borderRadius",
339
- label: "Border Radius",
340
- description: "Rounded corners for the carousel",
341
- tab: "styling",
342
- group: "Design"
343
- }),
344
- getPaddingField({
345
- defaultValue: 4,
346
- key: "padding",
347
- label: "Padding",
348
- description: "Padding for the carousel",
349
- tab: "styling",
350
- group: "Design"
351
- }),
352
- {
353
- key: "overlayEnabled",
354
- label: "Enable Overlay",
355
- type: "boolean",
356
- description: "Add background overlay to slide content",
357
- defaultValue: true,
358
- tab: "styling",
359
- group: "Design"
360
- },
361
- {
362
- key: "overlayType",
363
- label: "Overlay Type",
364
- type: "buttonGroup",
365
- description: "Type of overlay to add to the slide content",
366
- defaultValue: "gradient",
367
- options: [
368
- { label: "Solid", value: "solid" },
369
- { label: "Gradient", value: "gradient" }
370
- ],
371
- tab: "styling",
372
- group: "Design",
373
- requiresKeyToBeTrue: "overlayEnabled"
374
- },
375
- {
376
- key: "overlayIntensity",
377
- label: "Overlay Intensity",
378
- type: "slider",
379
- description: "Opacity of the overlay background (0-100)",
380
- min: 0,
381
- max: 100,
382
- step: 5,
383
- defaultValue: 50,
384
- unit: "%",
385
- tab: "styling",
386
- group: "Design",
387
- requiresKeyToBeTrue: "overlayEnabled"
388
- },
389
- {
390
- key: "showButton",
391
- label: "Show Button",
392
- type: "boolean",
393
- description: "Display the button in slide content",
394
- defaultValue: true,
395
- tab: "styling",
396
- group: "Design"
397
- },
398
- getColorField({
399
- defaultValue: "primary",
400
- key: "buttonColor",
401
- label: "Button Color",
402
- description: "Color variant for the slide button",
403
- tab: "styling",
404
- group: "Design",
405
- requiresKeyToBeTrue: "showButton"
406
- }),
407
- getButtonSizeField({
408
- defaultValue: "default",
409
- key: "buttonSize",
410
- label: "Button Size",
411
- description: "Size of the slide button",
412
- tab: "styling",
413
- group: "Design",
414
- requiresKeyToBeTrue: "showButton"
415
- }),
416
- // Behavior tab - Auto-Scroll group
417
- {
418
- key: "enableAutoScroll",
419
- label: "Enable Auto-Scroll",
420
- type: "boolean",
421
- description: "Automatically advance to the next slide",
422
- defaultValue: false,
423
- tab: "behavior",
424
- group: "Auto-Scroll"
425
- },
426
- {
427
- key: "autoScrollInterval",
428
- label: "Auto-Scroll Interval (ms)",
429
- type: "number",
430
- description: "Time in milliseconds between automatic slide transitions",
431
- min: 1e3,
432
- max: 1e4,
433
- step: 500,
434
- defaultValue: 3e3,
435
- tab: "behavior",
436
- group: "Auto-Scroll",
437
- requiresKeyToBeTrue: "enableAutoScroll"
438
- },
439
- // Data tab - Data Configuration group
440
- {
441
- key: "dataSource",
442
- label: "Data Source",
443
- type: "dataSource",
444
- description: "",
445
- tab: "data",
446
- group: "Data Configuration"
447
- }
448
- ],
449
- // Per-item configuration schema for custom data sources
450
- itemConfigSchema: {
451
- description: "Configure settings for this slide",
452
- fields: [
453
- {
454
- key: "title",
455
- label: "Custom Title",
456
- type: "text",
457
- description: "Override the item's title for this slide"
458
- },
459
- {
460
- key: "description",
461
- label: "Custom Description",
462
- type: "textarea",
463
- description: "Override the item's description for this slide",
464
- rows: 3
465
- },
466
- {
467
- key: "buttonEnabled",
468
- label: "Show Button",
469
- type: "boolean",
470
- description: "Show the button in the slide",
471
- defaultValue: false
472
- },
473
- {
474
- key: "buttonText",
475
- label: "Button Text",
476
- type: "text",
477
- description: "Text to display on the slide button",
478
- requiresKeyToBeTrue: "buttonEnabled"
479
- },
480
- {
481
- key: "buttonLink",
482
- label: "Button Link",
483
- type: "text",
484
- description: "URL for the slide button",
485
- requiresKeyToBeTrue: "buttonEnabled"
486
- }
487
- ]
488
- }
489
- };
490
-
491
- export { CarouselWidget, carouselWidgetPropertySchema };
492
- //# sourceMappingURL=chunk-MXWFM5J2.js.map
493
- //# sourceMappingURL=chunk-MXWFM5J2.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/widgets/CarouselWidget.tsx"],"names":[],"mappings":"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","file":"chunk-MXWFM5J2.js","sourcesContent":["import DOMPurify from \"dompurify\";\nimport { Button } from \"@fluid-app/ui-primitives\";\nimport { ScrollArrows } from \"../ui/scroll-arrows\";\nimport type { ComponentProps } from \"react\";\nimport { useEffect, useState, useCallback } from \"react\";\nimport {\n MediaRenderer,\n getMediaPropsFromWidgetSchema,\n} from \"../components/MediaRenderer\";\nimport type {\n WidgetSchema,\n BorderRadiusOptions,\n ColorOptions,\n AlignOptions,\n FontSizeOptions,\n PaddingOptions,\n ButtonSizeOptions,\n} from \"@fluid-app/rep-core/types\";\nimport {\n getHeightField,\n type WidgetPropertySchema,\n} from \"@fluid-app/rep-core/registries\";\nimport {\n getBorderRadiusField,\n getColorField,\n getFontSizeField,\n getPaddingField,\n getButtonSizeField,\n} from \"../core/fields\";\n\nconst DEFAULT_SLIDES: CarouselSlide[] = [];\n\ntype CarouselSlide = {\n id: string;\n content: WidgetSchema;\n title?: string;\n description?: string;\n buttonEnabled?: boolean;\n buttonText?: string;\n buttonVariant?:\n | \"default\"\n | \"secondary\"\n | \"outline\"\n | \"destructive\"\n | \"ghost\"\n | \"link\";\n buttonLink?: string;\n};\n\ntype CarouselWidgetProps = ComponentProps<\"div\"> & {\n slides?: CarouselSlide[];\n autoScrollInterval?: number;\n enableAutoScroll?: boolean;\n\n // Layout\n align?: AlignOptions;\n carouselHeight?: string;\n borderRadius?: BorderRadiusOptions;\n padding?: PaddingOptions;\n\n // Text Styling\n headerSize?: FontSizeOptions;\n headerColor?: ColorOptions;\n textSize?: FontSizeOptions;\n textColor?: ColorOptions;\n textWidth?: string;\n\n // Button\n showButton?: boolean;\n buttonColor?: ColorOptions;\n buttonSize?: ButtonSizeOptions;\n\n // Overlay\n overlayEnabled?: boolean;\n overlayType?: \"solid\" | \"gradient\";\n overlayIntensity?: number;\n};\n\nexport function CarouselWidget({\n slides = DEFAULT_SLIDES,\n autoScrollInterval = 3000,\n enableAutoScroll = false,\n carouselHeight = \"400px\",\n align = { vertical: \"bottom\", horizontal: \"left\" },\n overlayIntensity = 40,\n borderRadius = \"none\",\n padding = 0,\n textWidth = \"100%\",\n headerSize = \"lg\",\n headerColor = \"background\",\n textSize = \"md\",\n textColor = \"background\",\n showButton = true,\n buttonColor = \"background\",\n buttonSize = \"default\",\n overlayEnabled = true,\n overlayType = \"solid\",\n className,\n ...props\n}: CarouselWidgetProps) {\n const [currentIndex, setCurrentIndex] = useState(0);\n const [isHovered, setIsHovered] = useState(false);\n\n const hasSlides = slides.length > 0;\n const totalSlides = slides.length;\n\n const goToNext = useCallback(() => {\n if (!hasSlides) return;\n setCurrentIndex((prev) => {\n if (prev === totalSlides - 1) {\n return 0;\n }\n return prev + 1;\n });\n }, [hasSlides, totalSlides]);\n\n const goToPrevious = useCallback(() => {\n if (!hasSlides) return;\n setCurrentIndex((prev) => {\n if (prev === 0) {\n return totalSlides - 1;\n }\n return prev - 1;\n });\n }, [hasSlides, totalSlides]);\n\n const goToSlide = useCallback(\n (index: number) => {\n if (!hasSlides) return;\n if (index >= 0 && index < totalSlides) {\n setCurrentIndex(index);\n }\n },\n [hasSlides, totalSlides],\n );\n\n // Auto-scroll effect\n useEffect(() => {\n if (!enableAutoScroll || !hasSlides || isHovered) return;\n\n const intervalId = setInterval(() => {\n goToNext();\n }, autoScrollInterval);\n\n return () => clearInterval(intervalId);\n }, [enableAutoScroll, autoScrollInterval, hasSlides, isHovered, goToNext]);\n\n // Reset to first slide if slides change\n useEffect(() => {\n if (currentIndex >= totalSlides && totalSlides > 0) {\n setCurrentIndex(0);\n }\n }, [totalSlides, currentIndex]);\n\n if (!hasSlides) {\n return (\n <div\n className={`rounded-${borderRadius} ${className} w-full overflow-hidden`}\n style={{ minHeight: carouselHeight }}\n {...props}\n >\n <div\n className=\"bg-muted flex h-full w-full items-center justify-center\"\n style={{ minHeight: carouselHeight }}\n >\n <div className=\"text-muted-foreground flex flex-col items-center gap-2\">\n <div className=\"text-4xl\">🎠</div>\n <p className=\"text-sm\">No slides added</p>\n <p className=\"text-muted-foreground/70 text-xs\">\n Add slides to create a carousel\n </p>\n </div>\n </div>\n </div>\n );\n }\n\n return (\n <div\n className={`relative w-full overflow-hidden rounded-${borderRadius} ${className}`}\n style={{ minHeight: carouselHeight }}\n onMouseEnter={() => setIsHovered(true)}\n onMouseLeave={() => setIsHovered(false)}\n {...props}\n >\n {/* Slides Container */}\n <div\n className=\"relative h-full w-full\"\n style={{ minHeight: carouselHeight }}\n >\n <div\n className=\"flex h-full transition-transform duration-500 ease-in-out\"\n style={{\n transform: `translateX(-${currentIndex * 100}%)`,\n }}\n >\n {slides.map((slide) => (\n <div\n key={slide.id}\n className=\"relative h-full w-full flex-shrink-0\"\n style={{ minWidth: \"100%\", minHeight: carouselHeight }}\n >\n {/* Background image/content layer */}\n <div className=\"absolute inset-0 h-full w-full\">\n <MediaRenderer\n {...getMediaPropsFromWidgetSchema(slide.content)}\n />\n </div>\n\n {/* Dark overlay for text readability */}\n {overlayEnabled && (\n <div\n className={`absolute inset-0 z-9 ${\n overlayType === \"gradient\"\n ? \"bg-gradient-to-t from-black to-transparent\"\n : \"bg-black\"\n }`}\n style={{\n opacity:\n (Number(String(overlayIntensity).replace(\"%\", \"\")) ||\n 40) / 100,\n }}\n />\n )}\n\n {/* Content box */}\n <div\n className={`absolute inset-x-0 z-10 flex px-3 ${\n align.horizontal === \"left\"\n ? \"justify-start\"\n : align.horizontal === \"center\"\n ? \"justify-center\"\n : \"justify-end\"\n } ${\n align.vertical === \"top\"\n ? \"top-0 pt-13\"\n : align.vertical === \"center\"\n ? \"top-1/2 -translate-y-1/2\"\n : \"bottom-0 pb-13\"\n }`}\n >\n <div\n className={`p-${padding} flex flex-col gap-3`}\n style={{ maxWidth: textWidth }}\n >\n {/* Heading and text */}\n <div className={`flex flex-col text-${align.horizontal}`}>\n {slide.title && (\n <h2\n className={`mb-2 leading-tight font-bold text-${headerColor} text-${headerSize === \"md\" ? \"base\" : headerSize}`}\n >\n {slide.title}\n </h2>\n )}\n {slide.description && (\n <div\n className={`leading-snug text-${textColor} text-${textSize === \"md\" ? \"base\" : textSize} line-clamp-2`}\n dangerouslySetInnerHTML={{\n __html: DOMPurify.sanitize(slide.description, {\n ALLOWED_TAGS: [\n \"br\",\n \"strong\",\n \"em\",\n \"b\",\n \"i\",\n \"ul\",\n \"ol\",\n \"li\",\n \"p\",\n ],\n ALLOWED_ATTR: [],\n }),\n }}\n />\n )}\n </div>\n\n {/* Button */}\n {slide.buttonText && slide.buttonEnabled && showButton && (\n <div className={`text-${align.horizontal}`}>\n <Button\n size={buttonSize}\n className={`rounded-md py-1 font-semibold bg-${buttonColor} text-${buttonColor}-foreground hover:bg-${buttonColor}/90`}\n asChild\n >\n <a href={slide.buttonLink}>{slide.buttonText}</a>\n </Button>\n </div>\n )}\n </div>\n </div>\n </div>\n ))}\n </div>\n </div>\n {/* Dots and Navigation */}\n {totalSlides > 1 && (\n <div\n className={`p-${padding} absolute bottom-0 z-10 flex w-full items-center justify-between ${align.horizontal === \"center\" ? \"h-full\" : \"\"}`}\n >\n {/* Pagination dots - always at bottom */}\n <div\n className={`flex items-center ${\n align.horizontal === \"center\"\n ? `p-${padding} absolute inset-x-0 bottom-3 justify-center`\n : \"\"\n }`}\n >\n <div\n className={`flex items-center gap-2 ${\n align.horizontal === \"center\" ? \"justify-center\" : \"\"\n }`}\n >\n {slides.map((_, index) => (\n <button\n key={`dot-${index}`}\n className={`h-[6px] w-[6px] rounded-full transition-colors ${\n index === currentIndex\n ? \"bg-background\"\n : \"bg-background/40 hover:bg-background/60\"\n }`}\n onClick={() => goToSlide(index)}\n aria-label={`Go to slide ${index + 1}`}\n aria-current={index === currentIndex ? \"true\" : \"false\"}\n />\n ))}\n </div>\n </div>\n\n {/* Navigation arrows - position changes based on alignment */}\n <div\n className={`flex items-center gap-[10px] ${\n align.horizontal === \"center\"\n ? `absolute inset-x-0 top-1/2 justify-between px-${padding}`\n : \"\"\n }`}\n >\n <ScrollArrows onPrevious={goToPrevious} onNext={goToNext} />\n </div>\n </div>\n )}\n </div>\n );\n}\n\nexport const carouselWidgetPropertySchema: WidgetPropertySchema = {\n widgetType: \"CarouselWidget\",\n displayName: \"Carousel\",\n tabsConfig: [\n { id: \"styling\", label: \"Styling\" },\n { id: \"behavior\", label: \"Behavior\" },\n { id: \"data\", label: \"Data\" },\n ],\n dataSourceTargetProps: [\"slides\"],\n fields: [\n // Styling tab - Text Styling group\n getFontSizeField({\n defaultValue: \"lg\",\n key: \"headerSize\",\n label: \"Header Font Size\",\n description: \"Font size for the slide header\",\n tab: \"styling\",\n group: \"Text Styling\",\n }),\n getColorField({\n defaultValue: \"background\",\n key: \"headerColor\",\n label: \"Header Color\",\n description: \"Color variant for the slide header\",\n tab: \"styling\",\n group: \"Text Styling\",\n }),\n {\n key: \"separator\",\n type: \"separator\",\n label: \"Separator\",\n tab: \"styling\",\n group: \"Text Styling\",\n },\n getFontSizeField({\n defaultValue: \"md\",\n key: \"textSize\",\n label: \"Text Font Size\",\n description: \"Font size for the slide text\",\n tab: \"styling\",\n group: \"Text Styling\",\n }),\n getColorField({\n defaultValue: \"background\",\n key: \"textColor\",\n label: \"Text Color\",\n description: \"Color variant for the slide text\",\n tab: \"styling\",\n group: \"Text Styling\",\n }),\n // Styling tab - Layout group\n {\n key: \"align\",\n label: \"Alignment\",\n type: \"alignment\",\n description: \"Alignment of the carousel content\",\n defaultValue: { vertical: \"bottom\", horizontal: \"left\" },\n options: {\n verticalEnabled: true,\n horizontalEnabled: true,\n },\n tab: \"styling\",\n group: \"Layout\",\n },\n {\n key: \"textWidth\",\n label: \"Content Width\",\n type: \"text\",\n description: \"Maximum width for slide content (e.g., 100%, 50%, 600px)\",\n defaultValue: \"100%\",\n tab: \"styling\",\n group: \"Layout\",\n },\n // Styling tab - Design group\n getHeightField({\n key: \"carouselHeight\",\n label: \"Carousel Height\",\n description: \"Height of the carousel\",\n min: 100,\n max: 1200,\n step: 10,\n defaultValue: \"400px\",\n tab: \"styling\",\n group: \"Design\",\n }),\n {\n key: \"separator2\",\n type: \"separator\",\n label: \"Separator\",\n tab: \"styling\",\n group: \"Design\",\n },\n getBorderRadiusField({\n defaultValue: \"md\",\n key: \"borderRadius\",\n label: \"Border Radius\",\n description: \"Rounded corners for the carousel\",\n tab: \"styling\",\n group: \"Design\",\n }),\n getPaddingField({\n defaultValue: 4,\n key: \"padding\",\n label: \"Padding\",\n description: \"Padding for the carousel\",\n tab: \"styling\",\n group: \"Design\",\n }),\n {\n key: \"overlayEnabled\",\n label: \"Enable Overlay\",\n type: \"boolean\",\n description: \"Add background overlay to slide content\",\n defaultValue: true,\n tab: \"styling\",\n group: \"Design\",\n },\n {\n key: \"overlayType\",\n label: \"Overlay Type\",\n type: \"buttonGroup\",\n description: \"Type of overlay to add to the slide content\",\n defaultValue: \"gradient\",\n options: [\n { label: \"Solid\", value: \"solid\" },\n { label: \"Gradient\", value: \"gradient\" },\n ],\n tab: \"styling\",\n group: \"Design\",\n requiresKeyToBeTrue: \"overlayEnabled\",\n },\n {\n key: \"overlayIntensity\",\n label: \"Overlay Intensity\",\n type: \"slider\",\n description: \"Opacity of the overlay background (0-100)\",\n min: 0,\n max: 100,\n step: 5,\n defaultValue: 50,\n unit: \"%\",\n tab: \"styling\",\n group: \"Design\",\n requiresKeyToBeTrue: \"overlayEnabled\",\n },\n {\n key: \"showButton\",\n label: \"Show Button\",\n type: \"boolean\",\n description: \"Display the button in slide content\",\n defaultValue: true,\n tab: \"styling\",\n group: \"Design\",\n },\n getColorField({\n defaultValue: \"primary\",\n key: \"buttonColor\",\n label: \"Button Color\",\n description: \"Color variant for the slide button\",\n tab: \"styling\",\n group: \"Design\",\n requiresKeyToBeTrue: \"showButton\",\n }),\n getButtonSizeField({\n defaultValue: \"default\",\n key: \"buttonSize\",\n label: \"Button Size\",\n description: \"Size of the slide button\",\n tab: \"styling\",\n group: \"Design\",\n requiresKeyToBeTrue: \"showButton\",\n }),\n // Behavior tab - Auto-Scroll group\n {\n key: \"enableAutoScroll\",\n label: \"Enable Auto-Scroll\",\n type: \"boolean\",\n description: \"Automatically advance to the next slide\",\n defaultValue: false,\n tab: \"behavior\",\n group: \"Auto-Scroll\",\n },\n {\n key: \"autoScrollInterval\",\n label: \"Auto-Scroll Interval (ms)\",\n type: \"number\",\n description: \"Time in milliseconds between automatic slide transitions\",\n min: 1000,\n max: 10000,\n step: 500,\n defaultValue: 3000,\n tab: \"behavior\",\n group: \"Auto-Scroll\",\n requiresKeyToBeTrue: \"enableAutoScroll\",\n },\n // Data tab - Data Configuration group\n {\n key: \"dataSource\",\n label: \"Data Source\",\n type: \"dataSource\",\n description: \"\",\n tab: \"data\",\n group: \"Data Configuration\",\n },\n ],\n // Per-item configuration schema for custom data sources\n itemConfigSchema: {\n description: \"Configure settings for this slide\",\n fields: [\n {\n key: \"title\",\n label: \"Custom Title\",\n type: \"text\",\n description: \"Override the item's title for this slide\",\n },\n {\n key: \"description\",\n label: \"Custom Description\",\n type: \"textarea\",\n description: \"Override the item's description for this slide\",\n rows: 3,\n },\n {\n key: \"buttonEnabled\",\n label: \"Show Button\",\n type: \"boolean\",\n description: \"Show the button in the slide\",\n defaultValue: false,\n },\n {\n key: \"buttonText\",\n label: \"Button Text\",\n type: \"text\",\n description: \"Text to display on the slide button\",\n requiresKeyToBeTrue: \"buttonEnabled\",\n },\n {\n key: \"buttonLink\",\n label: \"Button Link\",\n type: \"text\",\n description: \"URL for the slide button\",\n requiresKeyToBeTrue: \"buttonEnabled\",\n },\n ],\n },\n} as const satisfies WidgetPropertySchema;\n"]}