@fluid-app/portal-sdk 0.1.62 → 0.1.63

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 (119) hide show
  1. package/dist/{AppDownloadScreen-CLWxnFsd.mjs → AppDownloadScreen-DUGGDlr4.mjs} +9 -9
  2. package/dist/{AppDownloadScreen-CH96k5cA.cjs → AppDownloadScreen-DW3cBnbI.cjs} +9 -9
  3. package/dist/{AppDownloadScreen-BH7GQ-qi.cjs → AppDownloadScreen-oMzxBETr.cjs} +2 -2
  4. package/dist/{AppDownloadScreen-BH7GQ-qi.cjs.map → AppDownloadScreen-oMzxBETr.cjs.map} +1 -1
  5. package/dist/{AppDownloadScreen-DcVl4492.mjs → AppDownloadScreen-pm8fLxZX.mjs} +2 -2
  6. package/dist/{AppDownloadScreen-DcVl4492.mjs.map → AppDownloadScreen-pm8fLxZX.mjs.map} +1 -1
  7. package/dist/{CarouselWidget-lx6QKa-q.mjs → CarouselWidget-BGdjG-xz.mjs} +2 -2
  8. package/dist/{CarouselWidget-lx6QKa-q.mjs.map → CarouselWidget-BGdjG-xz.mjs.map} +1 -1
  9. package/dist/{CarouselWidget-B74eKTnT.cjs → CarouselWidget-CC6ZQZ8e.cjs} +2 -2
  10. package/dist/{CarouselWidget-C_Bpw7nB.cjs → CarouselWidget-DgskhtDP.cjs} +2 -2
  11. package/dist/{CarouselWidget-C_Bpw7nB.cjs.map → CarouselWidget-DgskhtDP.cjs.map} +1 -1
  12. package/dist/{ContactsScreen-IAGjo08W.cjs → ContactsScreen-B3k1fVQx.cjs} +2 -2
  13. package/dist/{ContactsScreen-IAGjo08W.cjs.map → ContactsScreen-B3k1fVQx.cjs.map} +1 -1
  14. package/dist/{ContactsScreen-Dk9bp3Jj.mjs → ContactsScreen-CH6u8cRi.mjs} +2 -2
  15. package/dist/{ContactsScreen-Dk9bp3Jj.mjs.map → ContactsScreen-CH6u8cRi.mjs.map} +1 -1
  16. package/dist/{ContactsScreen-B8iWQTbP.cjs → ContactsScreen-C_c2yy5J.cjs} +9 -9
  17. package/dist/{ContactsScreen-C8Bp62F4.mjs → ContactsScreen-ruymx9Pi.mjs} +9 -9
  18. package/dist/{FluidProvider-9JuTycML.cjs → FluidProvider-SnHdl4ww.cjs} +13 -13
  19. package/dist/{FluidProvider-9JuTycML.cjs.map → FluidProvider-SnHdl4ww.cjs.map} +1 -1
  20. package/dist/{FluidProvider-9ZC28GXK.mjs → FluidProvider-uuu90TSG.mjs} +13 -13
  21. package/dist/{FluidProvider-9ZC28GXK.mjs.map → FluidProvider-uuu90TSG.mjs.map} +1 -1
  22. package/dist/{ImageWidget-BLnPO0Ba.mjs → ImageWidget-BHwucvLx.mjs} +2 -2
  23. package/dist/{ImageWidget-BLnPO0Ba.mjs.map → ImageWidget-BHwucvLx.mjs.map} +1 -1
  24. package/dist/{ImageWidget-DbDhysGw.cjs → ImageWidget-BRfKvv08.cjs} +2 -2
  25. package/dist/{ImageWidget-DbDhysGw.cjs.map → ImageWidget-BRfKvv08.cjs.map} +1 -1
  26. package/dist/{ListWidget-D6XZ53U9.cjs → ListWidget-BwyavG5d.cjs} +2 -2
  27. package/dist/{ListWidget-CiV9j7vm.cjs → ListWidget-DAtEwFCR.cjs} +2 -2
  28. package/dist/{ListWidget-CiV9j7vm.cjs.map → ListWidget-DAtEwFCR.cjs.map} +1 -1
  29. package/dist/{ListWidget-DuPrSL9o.mjs → ListWidget-ZqCYH78q.mjs} +2 -2
  30. package/dist/{ListWidget-DuPrSL9o.mjs.map → ListWidget-ZqCYH78q.mjs.map} +1 -1
  31. package/dist/{MediaRenderer-CY2gR7hk.mjs → MediaRenderer-B3R-Q6Qt.mjs} +8 -5
  32. package/dist/MediaRenderer-B3R-Q6Qt.mjs.map +1 -0
  33. package/dist/{MediaRenderer-CkMwv5q1.cjs → MediaRenderer-CRKJcPD9.cjs} +8 -5
  34. package/dist/MediaRenderer-CRKJcPD9.cjs.map +1 -0
  35. package/dist/{MessagingScreen-DpVYlTyB.cjs → MessagingScreen-27HyrQ1V.cjs} +3 -3
  36. package/dist/{MessagingScreen-DpVYlTyB.cjs.map → MessagingScreen-27HyrQ1V.cjs.map} +1 -1
  37. package/dist/{MessagingScreen-BuZTTy-l.cjs → MessagingScreen-C7xDqpLm.cjs} +9 -9
  38. package/dist/{MessagingScreen-RhCqymLN.mjs → MessagingScreen-CGS474IP.mjs} +9 -9
  39. package/dist/{MessagingScreen-DdQPLrmd.mjs → MessagingScreen-tFbOXFq4.mjs} +3 -3
  40. package/dist/{MessagingScreen-DdQPLrmd.mjs.map → MessagingScreen-tFbOXFq4.mjs.map} +1 -1
  41. package/dist/{MySiteScreen-DadI19bJ.cjs → MySiteScreen-B_UnnWDX.cjs} +9 -9
  42. package/dist/{MySiteScreen-DNn3aWn0.cjs → MySiteScreen-C-cS0_qZ.cjs} +2 -2
  43. package/dist/{MySiteScreen-DNn3aWn0.cjs.map → MySiteScreen-C-cS0_qZ.cjs.map} +1 -1
  44. package/dist/{MySiteScreen-Ddxdk1Pe.mjs → MySiteScreen-DR_xY95c.mjs} +2 -2
  45. package/dist/{MySiteScreen-Ddxdk1Pe.mjs.map → MySiteScreen-DR_xY95c.mjs.map} +1 -1
  46. package/dist/{MySiteScreen-Dbvaw1nu.mjs → MySiteScreen-bUfo9RDR.mjs} +9 -9
  47. package/dist/{NestedWidget-7Fn8H4aI.cjs → NestedWidget-BzFrzPFd.cjs} +2 -2
  48. package/dist/{NestedWidget-DS8F_8SN.mjs → NestedWidget-JS_3-isb.mjs} +2 -2
  49. package/dist/{NestedWidget-DS8F_8SN.mjs.map → NestedWidget-JS_3-isb.mjs.map} +1 -1
  50. package/dist/{NestedWidget-C1neMqH7.cjs → NestedWidget-cl38JElu.cjs} +2 -2
  51. package/dist/{NestedWidget-C1neMqH7.cjs.map → NestedWidget-cl38JElu.cjs.map} +1 -1
  52. package/dist/{OrdersScreen-QFndb0Oi.mjs → OrdersScreen-CO9vm0Wj.mjs} +9 -9
  53. package/dist/{OrdersScreen-CwTIkQNI.mjs → OrdersScreen-CQzgIEa4.mjs} +3 -3
  54. package/dist/{OrdersScreen-CwTIkQNI.mjs.map → OrdersScreen-CQzgIEa4.mjs.map} +1 -1
  55. package/dist/{OrdersScreen-CZdh8mbE.cjs → OrdersScreen-JCVS__ag.cjs} +9 -9
  56. package/dist/{OrdersScreen-DpyL3mIg.cjs → OrdersScreen-OexJlI4Y.cjs} +3 -3
  57. package/dist/{OrdersScreen-DpyL3mIg.cjs.map → OrdersScreen-OexJlI4Y.cjs.map} +1 -1
  58. package/dist/{ProductsScreen-CmZw1rWf.mjs → ProductsScreen-B0BsPJth.mjs} +3 -3
  59. package/dist/{ProductsScreen-CmZw1rWf.mjs.map → ProductsScreen-B0BsPJth.mjs.map} +1 -1
  60. package/dist/{ProductsScreen-dN4s469R.cjs → ProductsScreen-BcM3LqsG.cjs} +9 -9
  61. package/dist/{ProductsScreen-CGjMUHds.cjs → ProductsScreen-BgVl8GAm.cjs} +3 -3
  62. package/dist/{ProductsScreen-CGjMUHds.cjs.map → ProductsScreen-BgVl8GAm.cjs.map} +1 -1
  63. package/dist/{ProductsScreen-HaYLhqt1.mjs → ProductsScreen-GOW8lxiN.mjs} +9 -9
  64. package/dist/{ProfileScreen-1hqd2fN7.cjs → ProfileScreen-DFM_r4T5.cjs} +3 -3
  65. package/dist/{ProfileScreen-1hqd2fN7.cjs.map → ProfileScreen-DFM_r4T5.cjs.map} +1 -1
  66. package/dist/{ProfileScreen-DSr0OwIA.mjs → ProfileScreen-Tcqc5WfU.mjs} +9 -9
  67. package/dist/{ProfileScreen-_4yPoIgh.cjs → ProfileScreen-e-uj2ulO.cjs} +9 -9
  68. package/dist/{ProfileScreen-pCW_VAPN.mjs → ProfileScreen-pvpnY0cG.mjs} +3 -3
  69. package/dist/{ProfileScreen-pCW_VAPN.mjs.map → ProfileScreen-pvpnY0cG.mjs.map} +1 -1
  70. package/dist/{ShareablesScreen-DNzrgsmZ.cjs → ShareablesScreen-8rSANBth.cjs} +9 -9
  71. package/dist/{ShareablesScreen-CdXtyZma.cjs → ShareablesScreen-C7M_kGX9.cjs} +3 -3
  72. package/dist/{ShareablesScreen-CdXtyZma.cjs.map → ShareablesScreen-C7M_kGX9.cjs.map} +1 -1
  73. package/dist/{ShareablesScreen-xqMDNJ6m.mjs → ShareablesScreen-KFwyduqD.mjs} +9 -9
  74. package/dist/{ShareablesScreen-Cm8zbATC.mjs → ShareablesScreen-SS9rcLym.mjs} +3 -3
  75. package/dist/{ShareablesScreen-Cm8zbATC.mjs.map → ShareablesScreen-SS9rcLym.mjs.map} +1 -1
  76. package/dist/{ShopScreen-D2cMeKSk.mjs → ShopScreen-Bg696rqv.mjs} +9 -9
  77. package/dist/{ShopScreen-BnVS75fU.cjs → ShopScreen-DCKr0cbB.cjs} +9 -9
  78. package/dist/{ShopScreen-Dc3lQLGI.mjs → ShopScreen-DFWQY8hT.mjs} +4 -4
  79. package/dist/{ShopScreen-Dc3lQLGI.mjs.map → ShopScreen-DFWQY8hT.mjs.map} +1 -1
  80. package/dist/{ShopScreen-qZa0cEwy.cjs → ShopScreen-qgOXPdUf.cjs} +4 -4
  81. package/dist/{ShopScreen-qZa0cEwy.cjs.map → ShopScreen-qgOXPdUf.cjs.map} +1 -1
  82. package/dist/{SubscriptionsScreen-749p5heX.mjs → SubscriptionsScreen-50w7SgWX.mjs} +3 -3
  83. package/dist/{SubscriptionsScreen-749p5heX.mjs.map → SubscriptionsScreen-50w7SgWX.mjs.map} +1 -1
  84. package/dist/{SubscriptionsScreen-DxVV0sZx.mjs → SubscriptionsScreen-BVLHc7-p.mjs} +9 -9
  85. package/dist/{SubscriptionsScreen-DRgSTuJv.cjs → SubscriptionsScreen-DKI17q_K.cjs} +9 -9
  86. package/dist/{SubscriptionsScreen-7VBEggJ_.cjs → SubscriptionsScreen-Vn6EN634.cjs} +3 -3
  87. package/dist/{SubscriptionsScreen-7VBEggJ_.cjs.map → SubscriptionsScreen-Vn6EN634.cjs.map} +1 -1
  88. package/dist/{TableWidget-BnhJPYUm.cjs → TableWidget-CcPSLT0B.cjs} +2 -2
  89. package/dist/{TableWidget-Vcxw-se8.cjs → TableWidget-Cri6r5Yr.cjs} +2 -2
  90. package/dist/{TableWidget-Vcxw-se8.cjs.map → TableWidget-Cri6r5Yr.cjs.map} +1 -1
  91. package/dist/{TableWidget-CK5jQxjz.mjs → TableWidget-DjYabx1e.mjs} +2 -2
  92. package/dist/{TableWidget-CK5jQxjz.mjs.map → TableWidget-DjYabx1e.mjs.map} +1 -1
  93. package/dist/{VideoWidget-ho9fGQ3V.mjs → VideoWidget-51MxnPRZ.mjs} +4 -4
  94. package/dist/VideoWidget-51MxnPRZ.mjs.map +1 -0
  95. package/dist/{VideoWidget-7Q2eqHFn.cjs → VideoWidget-DnnuIvW1.cjs} +4 -4
  96. package/dist/VideoWidget-DnnuIvW1.cjs.map +1 -0
  97. package/dist/index.cjs +41 -41
  98. package/dist/index.mjs +41 -41
  99. package/dist/{use-account-clients-cHyQEhPp.cjs → use-account-clients-Bem920_7.cjs} +2 -2
  100. package/dist/{use-account-clients-cHyQEhPp.cjs.map → use-account-clients-Bem920_7.cjs.map} +1 -1
  101. package/dist/{use-account-clients-CqC0etbc.mjs → use-account-clients-FUcF1B-z.mjs} +2 -2
  102. package/dist/{use-account-clients-CqC0etbc.mjs.map → use-account-clients-FUcF1B-z.mjs.map} +1 -1
  103. package/dist/{use-current-user-Ccn1lGeB.cjs → use-current-user-Bld9wMVT.cjs} +3 -3
  104. package/dist/{use-current-user-Ccn1lGeB.cjs.map → use-current-user-Bld9wMVT.cjs.map} +1 -1
  105. package/dist/{use-current-user-CyodELl8.mjs → use-current-user-DnBpWIw6.mjs} +3 -3
  106. package/dist/{use-current-user-CyodELl8.mjs.map → use-current-user-DnBpWIw6.mjs.map} +1 -1
  107. package/dist/{use-customer-account-DODRyBye.mjs → use-customer-account-Dix8Ja5O.mjs} +3 -3
  108. package/dist/{use-customer-account-DODRyBye.mjs.map → use-customer-account-Dix8Ja5O.mjs.map} +1 -1
  109. package/dist/{use-customer-account-DOmzp1sM.cjs → use-customer-account-Rm2QXJiZ.cjs} +3 -3
  110. package/dist/{use-customer-account-DOmzp1sM.cjs.map → use-customer-account-Rm2QXJiZ.cjs.map} +1 -1
  111. package/dist/{use-fluid-api-BvakcAkY.mjs → use-fluid-api-CedscoxF.mjs} +2 -2
  112. package/dist/{use-fluid-api-BvakcAkY.mjs.map → use-fluid-api-CedscoxF.mjs.map} +1 -1
  113. package/dist/{use-fluid-api-CBm9h3s3.cjs → use-fluid-api-DyI6LDsV.cjs} +2 -2
  114. package/dist/{use-fluid-api-CBm9h3s3.cjs.map → use-fluid-api-DyI6LDsV.cjs.map} +1 -1
  115. package/package.json +12 -12
  116. package/dist/MediaRenderer-CY2gR7hk.mjs.map +0 -1
  117. package/dist/MediaRenderer-CkMwv5q1.cjs.map +0 -1
  118. package/dist/VideoWidget-7Q2eqHFn.cjs.map +0 -1
  119. package/dist/VideoWidget-ho9fGQ3V.mjs.map +0 -1
package/dist/index.cjs CHANGED
@@ -1,7 +1,7 @@
1
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
2
2
  const require_chunk = require("./chunk-DAgNkxik.cjs");
3
- const require_FluidProvider = require("./FluidProvider-9JuTycML.cjs");
4
- const require_ProfileScreen = require("./ProfileScreen-1hqd2fN7.cjs");
3
+ const require_FluidProvider = require("./FluidProvider-SnHdl4ww.cjs");
4
+ const require_ProfileScreen = require("./ProfileScreen-DFM_r4T5.cjs");
5
5
  require("./error-state-CGCSDJIJ.cjs");
6
6
  const require_PointsWidget = require("./PointsWidget-Bs74dyFl.cjs");
7
7
  const require_ScreenRenderer = require("./ScreenRenderer-D-vpSa-G.cjs");
@@ -16,47 +16,47 @@ const require_CardWidget = require("./CardWidget-BkLF5NI4.cjs");
16
16
  require("./purify.es-BNrhJaiC.cjs");
17
17
  const require_src = require("./src-DqIS-4ns.cjs");
18
18
  require("./scroll-arrows-BNDly6uT.cjs");
19
- require("./MediaRenderer-CkMwv5q1.cjs");
20
- const require_CarouselWidget = require("./CarouselWidget-C_Bpw7nB.cjs");
19
+ require("./MediaRenderer-CRKJcPD9.cjs");
20
+ const require_CarouselWidget = require("./CarouselWidget-DgskhtDP.cjs");
21
21
  const require_CatchUpWidget = require("./CatchUpWidget-DXjW4lrg.cjs");
22
22
  const require_ChartWidget = require("./ChartWidget-CS600CjN.cjs");
23
23
  const require_LayoutWidget = require("./LayoutWidget-q4xxJVPn.cjs");
24
24
  const require_ContainerWidget = require("./ContainerWidget-CdUs8OBL.cjs");
25
- const require_ImageWidget = require("./ImageWidget-DbDhysGw.cjs");
25
+ const require_ImageWidget = require("./ImageWidget-BRfKvv08.cjs");
26
26
  const require_LinkWidget = require("./LinkWidget-Bvw5OZwU.cjs");
27
- const require_ListWidget = require("./ListWidget-CiV9j7vm.cjs");
27
+ const require_ListWidget = require("./ListWidget-DAtEwFCR.cjs");
28
28
  const require_MySiteWidget = require("./MySiteWidget-BPp8ZoqT.cjs");
29
- const require_NestedWidget = require("./NestedWidget-C1neMqH7.cjs");
29
+ const require_NestedWidget = require("./NestedWidget-cl38JElu.cjs");
30
30
  const require_QuickShareWidget = require("./QuickShareWidget-C5u0Rngd.cjs");
31
31
  const require_RecentActivityWidget = require("./RecentActivityWidget-WmA5W55V.cjs");
32
32
  const require_SeparatorWidget = require("./SeparatorWidget-UJrep6Kl.cjs");
33
33
  const require_SpacerWidget = require("./SpacerWidget-Br2IZFFv.cjs");
34
- const require_TableWidget = require("./TableWidget-Vcxw-se8.cjs");
34
+ const require_TableWidget = require("./TableWidget-Cri6r5Yr.cjs");
35
35
  const require_ToDoWidget = require("./ToDoWidget-Bv6POc5R.cjs");
36
- const require_VideoWidget = require("./VideoWidget-7Q2eqHFn.cjs");
37
- const require_use_account_clients = require("./use-account-clients-cHyQEhPp.cjs");
36
+ const require_VideoWidget = require("./VideoWidget-DnnuIvW1.cjs");
37
+ const require_use_account_clients = require("./use-account-clients-Bem920_7.cjs");
38
38
  const require_ScreenHeaderContext = require("./ScreenHeaderContext-eyKPyDoQ.cjs");
39
- const require_use_fluid_api = require("./use-fluid-api-CBm9h3s3.cjs");
40
- const require_use_current_user = require("./use-current-user-Ccn1lGeB.cjs");
39
+ const require_use_fluid_api = require("./use-fluid-api-DyI6LDsV.cjs");
40
+ const require_use_current_user = require("./use-current-user-Bld9wMVT.cjs");
41
41
  const require_CustomersScreen = require("./CustomersScreen-CJUmGfJY.cjs");
42
42
  const require_AppNavigationContext = require("./AppNavigationContext-B88_pXjo.cjs");
43
- const require_MessagingScreen = require("./MessagingScreen-DpVYlTyB.cjs");
43
+ const require_MessagingScreen = require("./MessagingScreen-27HyrQ1V.cjs");
44
44
  require("./order-detail-JVq0-ps1.cjs");
45
- const require_SubscriptionsScreen = require("./SubscriptionsScreen-7VBEggJ_.cjs");
45
+ const require_SubscriptionsScreen = require("./SubscriptionsScreen-Vn6EN634.cjs");
46
46
  require("./dist-NpiIdjkL.cjs");
47
47
  require("./es-qN_AsxTa.cjs");
48
- const require_ContactsScreen = require("./ContactsScreen-IAGjo08W.cjs");
48
+ const require_ContactsScreen = require("./ContactsScreen-B3k1fVQx.cjs");
49
49
  require("./src-DL_WTpu5.cjs");
50
50
  require("./dist-Cs6PV1Tf.cjs");
51
- const require_OrdersScreen = require("./OrdersScreen-DpyL3mIg.cjs");
51
+ const require_OrdersScreen = require("./OrdersScreen-OexJlI4Y.cjs");
52
52
  require("./src-D1poJLOQ.cjs");
53
- const require_ShopScreen = require("./ShopScreen-qZa0cEwy.cjs");
54
- const require_ShareablesScreen = require("./ShareablesScreen-CdXtyZma.cjs");
53
+ const require_ShopScreen = require("./ShopScreen-qgOXPdUf.cjs");
54
+ const require_ShareablesScreen = require("./ShareablesScreen-C7M_kGX9.cjs");
55
55
  require("./dist-oTn1xy1Z.cjs");
56
- const require_ProductsScreen = require("./ProductsScreen-CGjMUHds.cjs");
57
- const require_MySiteScreen = require("./MySiteScreen-DNn3aWn0.cjs");
56
+ const require_ProductsScreen = require("./ProductsScreen-BgVl8GAm.cjs");
57
+ const require_MySiteScreen = require("./MySiteScreen-C-cS0_qZ.cjs");
58
58
  require("./UpgradeScreen-BbP-0Pcg.cjs");
59
- require("./AppDownloadScreen-BH7GQ-qi.cjs");
59
+ require("./AppDownloadScreen-oMzxBETr.cjs");
60
60
  let react = require("react");
61
61
  react = require_chunk.__toESM(react);
62
62
  let _tanstack_react_query = require("@tanstack/react-query");
@@ -2403,18 +2403,18 @@ function AccountManageLayout({ children }) {
2403
2403
  }
2404
2404
  //#endregion
2405
2405
  //#region src/shell/system-screen-map.ts
2406
- const ProfileScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./ProfileScreen-_4yPoIgh.cjs")).then((m) => ({ default: m.ProfileScreen })));
2407
- const OrdersScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./OrdersScreen-CZdh8mbE.cjs")).then((m) => ({ default: m.OrdersScreen })));
2408
- const SubscriptionsScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./SubscriptionsScreen-DRgSTuJv.cjs")).then((m) => ({ default: m.SubscriptionsScreen })));
2409
- const MessagingScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./MessagingScreen-BuZTTy-l.cjs")).then((m) => ({ default: m.MessagingScreen })));
2410
- const ContactsScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./ContactsScreen-B8iWQTbP.cjs")).then((m) => ({ default: m.ContactsScreen })));
2411
- const ShopScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./ShopScreen-BnVS75fU.cjs")).then((m) => ({ default: m.ShopScreen })));
2406
+ const ProfileScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./ProfileScreen-e-uj2ulO.cjs")).then((m) => ({ default: m.ProfileScreen })));
2407
+ const OrdersScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./OrdersScreen-JCVS__ag.cjs")).then((m) => ({ default: m.OrdersScreen })));
2408
+ const SubscriptionsScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./SubscriptionsScreen-DKI17q_K.cjs")).then((m) => ({ default: m.SubscriptionsScreen })));
2409
+ const MessagingScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./MessagingScreen-C7xDqpLm.cjs")).then((m) => ({ default: m.MessagingScreen })));
2410
+ const ContactsScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./ContactsScreen-C_c2yy5J.cjs")).then((m) => ({ default: m.ContactsScreen })));
2411
+ const ShopScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./ShopScreen-DCKr0cbB.cjs")).then((m) => ({ default: m.ShopScreen })));
2412
2412
  const CustomersScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./CustomersScreen-CJUmGfJY.cjs")).then((n) => n.CustomersScreen_exports).then((m) => ({ default: m.CustomersScreen })));
2413
- const ProductsScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./ProductsScreen-dN4s469R.cjs")).then((m) => ({ default: m.ProductsScreen })));
2414
- const ShareablesScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./ShareablesScreen-DNzrgsmZ.cjs")).then((m) => ({ default: m.ShareablesScreen })));
2415
- const MySiteScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./MySiteScreen-DadI19bJ.cjs")).then((m) => ({ default: m.MySiteScreen })));
2413
+ const ProductsScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./ProductsScreen-BcM3LqsG.cjs")).then((m) => ({ default: m.ProductsScreen })));
2414
+ const ShareablesScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./ShareablesScreen-8rSANBth.cjs")).then((m) => ({ default: m.ShareablesScreen })));
2415
+ const MySiteScreen$1 = (0, react.lazy)(() => Promise.resolve().then(() => require("./MySiteScreen-B_UnnWDX.cjs")).then((m) => ({ default: m.MySiteScreen })));
2416
2416
  const UpgradeScreen = (0, react.lazy)(() => Promise.resolve().then(() => require("./UpgradeScreen-DJKNVL-O.cjs")).then((m) => ({ default: m.UpgradeScreen })));
2417
- const AppDownloadScreen = (0, react.lazy)(() => Promise.resolve().then(() => require("./AppDownloadScreen-CH96k5cA.cjs")).then((m) => ({ default: m.AppDownloadScreen })));
2417
+ const AppDownloadScreen = (0, react.lazy)(() => Promise.resolve().then(() => require("./AppDownloadScreen-DW3cBnbI.cjs")).then((m) => ({ default: m.AppDownloadScreen })));
2418
2418
  const SYSTEM_SLUG_SCREEN_MAP = {
2419
2419
  profile: ProfileScreen$1,
2420
2420
  orders: OrdersScreen$1,
@@ -3814,18 +3814,18 @@ function useContact(_contactId) {
3814
3814
  //#endregion
3815
3815
  //#region src/screens/index.ts
3816
3816
  const screenPropertySchemas = {
3817
- ProfileScreen: () => Promise.resolve().then(() => require("./ProfileScreen-_4yPoIgh.cjs")).then((m) => m.profileScreenPropertySchema),
3818
- MessagingScreen: () => Promise.resolve().then(() => require("./MessagingScreen-BuZTTy-l.cjs")).then((m) => m.messagingScreenPropertySchema),
3819
- ContactsScreen: () => Promise.resolve().then(() => require("./ContactsScreen-B8iWQTbP.cjs")).then((m) => m.contactsScreenPropertySchema),
3820
- OrdersScreen: () => Promise.resolve().then(() => require("./OrdersScreen-CZdh8mbE.cjs")).then((m) => m.ordersScreenPropertySchema),
3821
- SubscriptionsScreen: () => Promise.resolve().then(() => require("./SubscriptionsScreen-DRgSTuJv.cjs")).then((m) => m.subscriptionsScreenPropertySchema),
3817
+ ProfileScreen: () => Promise.resolve().then(() => require("./ProfileScreen-e-uj2ulO.cjs")).then((m) => m.profileScreenPropertySchema),
3818
+ MessagingScreen: () => Promise.resolve().then(() => require("./MessagingScreen-C7xDqpLm.cjs")).then((m) => m.messagingScreenPropertySchema),
3819
+ ContactsScreen: () => Promise.resolve().then(() => require("./ContactsScreen-C_c2yy5J.cjs")).then((m) => m.contactsScreenPropertySchema),
3820
+ OrdersScreen: () => Promise.resolve().then(() => require("./OrdersScreen-JCVS__ag.cjs")).then((m) => m.ordersScreenPropertySchema),
3821
+ SubscriptionsScreen: () => Promise.resolve().then(() => require("./SubscriptionsScreen-DKI17q_K.cjs")).then((m) => m.subscriptionsScreenPropertySchema),
3822
3822
  CustomersScreen: () => Promise.resolve().then(() => require("./CustomersScreen-CJUmGfJY.cjs")).then((n) => n.CustomersScreen_exports).then((m) => m.customersScreenPropertySchema),
3823
- ProductsScreen: () => Promise.resolve().then(() => require("./ProductsScreen-dN4s469R.cjs")).then((m) => m.productsScreenPropertySchema),
3824
- MySiteScreen: () => Promise.resolve().then(() => require("./MySiteScreen-DadI19bJ.cjs")).then((m) => m.mySiteScreenPropertySchema),
3825
- ShareablesScreen: () => Promise.resolve().then(() => require("./ShareablesScreen-DNzrgsmZ.cjs")).then((m) => m.shareablesScreenPropertySchema),
3826
- ShopScreen: () => Promise.resolve().then(() => require("./ShopScreen-BnVS75fU.cjs")).then((m) => m.shopScreenPropertySchema),
3823
+ ProductsScreen: () => Promise.resolve().then(() => require("./ProductsScreen-BcM3LqsG.cjs")).then((m) => m.productsScreenPropertySchema),
3824
+ MySiteScreen: () => Promise.resolve().then(() => require("./MySiteScreen-B_UnnWDX.cjs")).then((m) => m.mySiteScreenPropertySchema),
3825
+ ShareablesScreen: () => Promise.resolve().then(() => require("./ShareablesScreen-8rSANBth.cjs")).then((m) => m.shareablesScreenPropertySchema),
3826
+ ShopScreen: () => Promise.resolve().then(() => require("./ShopScreen-DCKr0cbB.cjs")).then((m) => m.shopScreenPropertySchema),
3827
3827
  UpgradeScreen: () => Promise.resolve().then(() => require("./UpgradeScreen-DJKNVL-O.cjs")).then((m) => m.upgradeScreenPropertySchema),
3828
- AppDownloadScreen: () => Promise.resolve().then(() => require("./AppDownloadScreen-CH96k5cA.cjs")).then((m) => m.appDownloadScreenPropertySchema)
3828
+ AppDownloadScreen: () => Promise.resolve().then(() => require("./AppDownloadScreen-DW3cBnbI.cjs")).then((m) => m.appDownloadScreenPropertySchema)
3829
3829
  };
3830
3830
  /**
3831
3831
  * Core page template IDs
package/dist/index.mjs CHANGED
@@ -1,5 +1,5 @@
1
- import { A as storeToken, B as USER_TYPES, C as extractAllTokensFromUrl, D as clearTokens, E as hasTokenInUrl, F as isValidToken, H as createPersister, I as validateToken, L as AUTH_CONSTANTS, M as getTokenExpiration, N as getTokenTimeRemaining, O as getStoredToken, P as isTokenExpired, R as STORAGE_KEYS, S as cleanTokenFromUrl, T as extractTokenFromUrl, U as deleteDatabase, V as isUserType, _ as toNavigationItem, a as FluidAuthProvider, b as DEFAULT_AUTH_URL, c as useThemeContext, d as createFluidClient, f as isApiError, g as transformThemes, h as transformManifestToRepAppData, i as widgetPropertySchemas, j as decodeToken, k as hasStoredToken, l as themes_exports, m as getActiveThemeId, n as useFluidContext, o as useFluidAuthContext, p as buildThemeDefinition, r as DEFAULT_SDK_WIDGET_REGISTRY, s as FluidThemeProvider, t as FluidProvider, u as ApiError, v as normalizeComponentTree, w as extractCompanyTokenFromUrl, x as createDefaultAuthRedirect, y as toScreenDefinition, z as URL_PARAMS } from "./FluidProvider-9ZC28GXK.mjs";
2
- import { n as profileScreenPropertySchema, t as ProfileScreen } from "./ProfileScreen-pCW_VAPN.mjs";
1
+ import { A as storeToken, B as USER_TYPES, C as extractAllTokensFromUrl, D as clearTokens, E as hasTokenInUrl, F as isValidToken, H as createPersister, I as validateToken, L as AUTH_CONSTANTS, M as getTokenExpiration, N as getTokenTimeRemaining, O as getStoredToken, P as isTokenExpired, R as STORAGE_KEYS, S as cleanTokenFromUrl, T as extractTokenFromUrl, U as deleteDatabase, V as isUserType, _ as toNavigationItem, a as FluidAuthProvider, b as DEFAULT_AUTH_URL, c as useThemeContext, d as createFluidClient, f as isApiError, g as transformThemes, h as transformManifestToRepAppData, i as widgetPropertySchemas, j as decodeToken, k as hasStoredToken, l as themes_exports, m as getActiveThemeId, n as useFluidContext, o as useFluidAuthContext, p as buildThemeDefinition, r as DEFAULT_SDK_WIDGET_REGISTRY, s as FluidThemeProvider, t as FluidProvider, u as ApiError, v as normalizeComponentTree, w as extractCompanyTokenFromUrl, x as createDefaultAuthRedirect, y as toScreenDefinition, z as URL_PARAMS } from "./FluidProvider-uuu90TSG.mjs";
2
+ import { n as profileScreenPropertySchema, t as ProfileScreen } from "./ProfileScreen-pvpnY0cG.mjs";
3
3
  import "./error-state-BGEvTYIh.mjs";
4
4
  import { a as useDataSourceRegistryConfig, r as pointsWidgetPropertySchema, t as PointsWidget } from "./PointsWidget-DjSC-B2i.mjs";
5
5
  import { i as useRegistry } from "./ScreenRenderer-CnxT7sYF.mjs";
@@ -13,48 +13,48 @@ import { r as calendarWidgetPropertySchema, t as CalendarWidget } from "./Calend
13
13
  import { r as cardWidgetPropertySchema, t as CardWidget } from "./CardWidget-BKk7OtDP.mjs";
14
14
  import "./purify.es-BiyaWMrt.mjs";
15
15
  import { C as SheetContent, D as SheetTrigger, I as Input, K as DropdownMenu, R as IconButton, S as Sheet, Y as DropdownMenuLabel, an as AlertDialogContent, cn as AlertDialogHeader, et as DropdownMenuTrigger, ht as CollapsibleTrigger, in as AlertDialogCancel, ln as AlertDialogMedia, mt as CollapsibleContent, nn as AlertDialog, on as AlertDialogDescription, pt as Collapsible, q as DropdownMenuContent, rn as AlertDialogAction, sn as AlertDialogFooter, un as AlertDialogTitle, x as Skeleton$1, yn as cn$1 } from "./src-Bh-9OV8i.mjs";
16
- import { a as useMessagingAuth, i as useMessagingConfig, n as messagingScreenPropertySchema, r as createFluidFileUploader, t as MessagingScreen } from "./MessagingScreen-DdQPLrmd.mjs";
16
+ import { a as useMessagingAuth, i as useMessagingConfig, n as messagingScreenPropertySchema, r as createFluidFileUploader, t as MessagingScreen } from "./MessagingScreen-tFbOXFq4.mjs";
17
17
  import "./scroll-arrows-D9DfrbI-.mjs";
18
- import "./MediaRenderer-CY2gR7hk.mjs";
19
- import { r as carouselWidgetPropertySchema, t as CarouselWidget } from "./CarouselWidget-lx6QKa-q.mjs";
18
+ import "./MediaRenderer-B3R-Q6Qt.mjs";
19
+ import { r as carouselWidgetPropertySchema, t as CarouselWidget } from "./CarouselWidget-BGdjG-xz.mjs";
20
20
  import { r as catchUpWidgetPropertySchema, t as CatchUpWidget } from "./CatchUpWidget-BGOAfvS0.mjs";
21
21
  import { r as chartWidgetPropertySchema, t as ChartWidget } from "./ChartWidget-DSaru9Bb.mjs";
22
22
  import { r as layoutWidgetPropertySchema, t as LayoutWidget } from "./LayoutWidget-DVqlQga6.mjs";
23
23
  import { r as containerWidgetPropertySchema, t as ContainerWidget } from "./ContainerWidget-Dlno2qQ7.mjs";
24
- import { r as imageWidgetPropertySchema, t as ImageWidget } from "./ImageWidget-BLnPO0Ba.mjs";
24
+ import { r as imageWidgetPropertySchema, t as ImageWidget } from "./ImageWidget-BHwucvLx.mjs";
25
25
  import { r as linkWidgetPropertySchema, t as LinkWidget } from "./LinkWidget-dwIVKZD0.mjs";
26
- import { r as listWidgetPropertySchema, t as ListWidget } from "./ListWidget-DuPrSL9o.mjs";
26
+ import { r as listWidgetPropertySchema, t as ListWidget } from "./ListWidget-ZqCYH78q.mjs";
27
27
  import { r as mySiteWidgetPropertySchema, t as MySiteWidget } from "./MySiteWidget-KK2_WF16.mjs";
28
- import { r as nestedWidgetPropertySchema, t as NestedWidget } from "./NestedWidget-DS8F_8SN.mjs";
28
+ import { r as nestedWidgetPropertySchema, t as NestedWidget } from "./NestedWidget-JS_3-isb.mjs";
29
29
  import { r as quickShareWidgetPropertySchema, t as QuickShareWidget } from "./QuickShareWidget-DsBI1JQ_.mjs";
30
30
  import { r as recentActivityWidgetPropertySchema, t as RecentActivityWidget } from "./RecentActivityWidget-CuU8Rd77.mjs";
31
31
  import { r as separatorWidgetPropertySchema, t as SeparatorWidget } from "./SeparatorWidget-DQqeYY3c.mjs";
32
32
  import { r as spacerWidgetPropertySchema, t as SpacerWidget } from "./SpacerWidget-DgVU58BC.mjs";
33
- import { r as tableWidgetPropertySchema, t as TableWidget } from "./TableWidget-CK5jQxjz.mjs";
33
+ import { r as tableWidgetPropertySchema, t as TableWidget } from "./TableWidget-DjYabx1e.mjs";
34
34
  import { r as toDoWidgetPropertySchema, t as ToDoWidget } from "./ToDoWidget-Cmvf7I6c.mjs";
35
- import { r as videoWidgetPropertySchema, t as VideoWidget } from "./VideoWidget-ho9fGQ3V.mjs";
36
- import { o as useFluidAuth } from "./use-account-clients-CqC0etbc.mjs";
35
+ import { r as videoWidgetPropertySchema, t as VideoWidget } from "./VideoWidget-51MxnPRZ.mjs";
36
+ import { o as useFluidAuth } from "./use-account-clients-FUcF1B-z.mjs";
37
37
  import { i as useScreenHeaderContext, t as ScreenHeaderProvider } from "./ScreenHeaderContext-CrdfLGKk.mjs";
38
- import { t as useFluidApi } from "./use-fluid-api-BvakcAkY.mjs";
39
- import { i as useCompanyScopedQueryKey, n as useCurrentUser, r as createCompanyQueryKey, t as CURRENT_USER_QUERY_KEY } from "./use-current-user-CyodELl8.mjs";
38
+ import { t as useFluidApi } from "./use-fluid-api-CedscoxF.mjs";
39
+ import { i as useCompanyScopedQueryKey, n as useCurrentUser, r as createCompanyQueryKey, t as CURRENT_USER_QUERY_KEY } from "./use-current-user-DnBpWIw6.mjs";
40
40
  import { i as CoreScreenPlaceholder, r as customersScreenPropertySchema, t as CustomersScreen } from "./CustomersScreen-D22G27ru.mjs";
41
41
  import { n as useAppNavigation, t as AppNavigationProvider } from "./AppNavigationContext-DJeNcP4Y.mjs";
42
42
  import "./order-detail-DkMYJvzl.mjs";
43
- import { n as subscriptionsScreenPropertySchema, t as SubscriptionsScreen } from "./SubscriptionsScreen-749p5heX.mjs";
43
+ import { n as subscriptionsScreenPropertySchema, t as SubscriptionsScreen } from "./SubscriptionsScreen-50w7SgWX.mjs";
44
44
  import "./dist-CMGXkSgZ.mjs";
45
45
  import "./es-CrIkZTQ3.mjs";
46
- import { n as contactsScreenPropertySchema, t as ContactsScreen } from "./ContactsScreen-Dk9bp3Jj.mjs";
46
+ import { n as contactsScreenPropertySchema, t as ContactsScreen } from "./ContactsScreen-CH6u8cRi.mjs";
47
47
  import "./src-BakNjVTk.mjs";
48
48
  import "./dist-Cl4FsM3V.mjs";
49
- import { n as ordersScreenPropertySchema, t as OrdersScreen } from "./OrdersScreen-CwTIkQNI.mjs";
49
+ import { n as ordersScreenPropertySchema, t as OrdersScreen } from "./OrdersScreen-CQzgIEa4.mjs";
50
50
  import "./src-CzK-t4_m.mjs";
51
- import { n as shopScreenPropertySchema, t as ShopScreen } from "./ShopScreen-Dc3lQLGI.mjs";
52
- import { n as shareablesScreenPropertySchema, t as ShareablesScreen } from "./ShareablesScreen-Cm8zbATC.mjs";
51
+ import { n as shopScreenPropertySchema, t as ShopScreen } from "./ShopScreen-DFWQY8hT.mjs";
52
+ import { n as shareablesScreenPropertySchema, t as ShareablesScreen } from "./ShareablesScreen-SS9rcLym.mjs";
53
53
  import "./sortable.esm-DreCqRxJ.mjs";
54
- import { n as productsScreenPropertySchema, t as ProductsScreen } from "./ProductsScreen-CmZw1rWf.mjs";
55
- import { n as mySiteScreenPropertySchema, t as MySiteScreen } from "./MySiteScreen-Ddxdk1Pe.mjs";
54
+ import { n as productsScreenPropertySchema, t as ProductsScreen } from "./ProductsScreen-B0BsPJth.mjs";
55
+ import { n as mySiteScreenPropertySchema, t as MySiteScreen } from "./MySiteScreen-DR_xY95c.mjs";
56
56
  import "./UpgradeScreen-D7LfdVSJ.mjs";
57
- import "./AppDownloadScreen-DcVl4492.mjs";
57
+ import "./AppDownloadScreen-pm8fLxZX.mjs";
58
58
  import * as React$1 from "react";
59
59
  import { StrictMode, Suspense, createContext, forwardRef, lazy, memo, useCallback, useContext, useEffect, useMemo, useRef, useState, useSyncExternalStore } from "react";
60
60
  import { useMutation, useQueries, useQuery, useQueryClient } from "@tanstack/react-query";
@@ -2401,18 +2401,18 @@ function AccountManageLayout({ children }) {
2401
2401
  }
2402
2402
  //#endregion
2403
2403
  //#region src/shell/system-screen-map.ts
2404
- const ProfileScreen$1 = lazy(() => import("./ProfileScreen-DSr0OwIA.mjs").then((m) => ({ default: m.ProfileScreen })));
2405
- const OrdersScreen$1 = lazy(() => import("./OrdersScreen-QFndb0Oi.mjs").then((m) => ({ default: m.OrdersScreen })));
2406
- const SubscriptionsScreen$1 = lazy(() => import("./SubscriptionsScreen-DxVV0sZx.mjs").then((m) => ({ default: m.SubscriptionsScreen })));
2407
- const MessagingScreen$1 = lazy(() => import("./MessagingScreen-RhCqymLN.mjs").then((m) => ({ default: m.MessagingScreen })));
2408
- const ContactsScreen$1 = lazy(() => import("./ContactsScreen-C8Bp62F4.mjs").then((m) => ({ default: m.ContactsScreen })));
2409
- const ShopScreen$1 = lazy(() => import("./ShopScreen-D2cMeKSk.mjs").then((m) => ({ default: m.ShopScreen })));
2404
+ const ProfileScreen$1 = lazy(() => import("./ProfileScreen-Tcqc5WfU.mjs").then((m) => ({ default: m.ProfileScreen })));
2405
+ const OrdersScreen$1 = lazy(() => import("./OrdersScreen-CO9vm0Wj.mjs").then((m) => ({ default: m.OrdersScreen })));
2406
+ const SubscriptionsScreen$1 = lazy(() => import("./SubscriptionsScreen-BVLHc7-p.mjs").then((m) => ({ default: m.SubscriptionsScreen })));
2407
+ const MessagingScreen$1 = lazy(() => import("./MessagingScreen-CGS474IP.mjs").then((m) => ({ default: m.MessagingScreen })));
2408
+ const ContactsScreen$1 = lazy(() => import("./ContactsScreen-ruymx9Pi.mjs").then((m) => ({ default: m.ContactsScreen })));
2409
+ const ShopScreen$1 = lazy(() => import("./ShopScreen-Bg696rqv.mjs").then((m) => ({ default: m.ShopScreen })));
2410
2410
  const CustomersScreen$1 = lazy(() => import("./CustomersScreen-D22G27ru.mjs").then((n) => n.n).then((m) => ({ default: m.CustomersScreen })));
2411
- const ProductsScreen$1 = lazy(() => import("./ProductsScreen-HaYLhqt1.mjs").then((m) => ({ default: m.ProductsScreen })));
2412
- const ShareablesScreen$1 = lazy(() => import("./ShareablesScreen-xqMDNJ6m.mjs").then((m) => ({ default: m.ShareablesScreen })));
2413
- const MySiteScreen$1 = lazy(() => import("./MySiteScreen-Dbvaw1nu.mjs").then((m) => ({ default: m.MySiteScreen })));
2411
+ const ProductsScreen$1 = lazy(() => import("./ProductsScreen-GOW8lxiN.mjs").then((m) => ({ default: m.ProductsScreen })));
2412
+ const ShareablesScreen$1 = lazy(() => import("./ShareablesScreen-KFwyduqD.mjs").then((m) => ({ default: m.ShareablesScreen })));
2413
+ const MySiteScreen$1 = lazy(() => import("./MySiteScreen-bUfo9RDR.mjs").then((m) => ({ default: m.MySiteScreen })));
2414
2414
  const UpgradeScreen = lazy(() => import("./UpgradeScreen-D7LfdVSJ.mjs").then((n) => n.t).then((m) => ({ default: m.UpgradeScreen })));
2415
- const AppDownloadScreen = lazy(() => import("./AppDownloadScreen-CLWxnFsd.mjs").then((m) => ({ default: m.AppDownloadScreen })));
2415
+ const AppDownloadScreen = lazy(() => import("./AppDownloadScreen-DUGGDlr4.mjs").then((m) => ({ default: m.AppDownloadScreen })));
2416
2416
  const SYSTEM_SLUG_SCREEN_MAP = {
2417
2417
  profile: ProfileScreen$1,
2418
2418
  orders: OrdersScreen$1,
@@ -3812,18 +3812,18 @@ function useContact(_contactId) {
3812
3812
  //#endregion
3813
3813
  //#region src/screens/index.ts
3814
3814
  const screenPropertySchemas = {
3815
- ProfileScreen: () => import("./ProfileScreen-DSr0OwIA.mjs").then((m) => m.profileScreenPropertySchema),
3816
- MessagingScreen: () => import("./MessagingScreen-RhCqymLN.mjs").then((m) => m.messagingScreenPropertySchema),
3817
- ContactsScreen: () => import("./ContactsScreen-C8Bp62F4.mjs").then((m) => m.contactsScreenPropertySchema),
3818
- OrdersScreen: () => import("./OrdersScreen-QFndb0Oi.mjs").then((m) => m.ordersScreenPropertySchema),
3819
- SubscriptionsScreen: () => import("./SubscriptionsScreen-DxVV0sZx.mjs").then((m) => m.subscriptionsScreenPropertySchema),
3815
+ ProfileScreen: () => import("./ProfileScreen-Tcqc5WfU.mjs").then((m) => m.profileScreenPropertySchema),
3816
+ MessagingScreen: () => import("./MessagingScreen-CGS474IP.mjs").then((m) => m.messagingScreenPropertySchema),
3817
+ ContactsScreen: () => import("./ContactsScreen-ruymx9Pi.mjs").then((m) => m.contactsScreenPropertySchema),
3818
+ OrdersScreen: () => import("./OrdersScreen-CO9vm0Wj.mjs").then((m) => m.ordersScreenPropertySchema),
3819
+ SubscriptionsScreen: () => import("./SubscriptionsScreen-BVLHc7-p.mjs").then((m) => m.subscriptionsScreenPropertySchema),
3820
3820
  CustomersScreen: () => import("./CustomersScreen-D22G27ru.mjs").then((n) => n.n).then((m) => m.customersScreenPropertySchema),
3821
- ProductsScreen: () => import("./ProductsScreen-HaYLhqt1.mjs").then((m) => m.productsScreenPropertySchema),
3822
- MySiteScreen: () => import("./MySiteScreen-Dbvaw1nu.mjs").then((m) => m.mySiteScreenPropertySchema),
3823
- ShareablesScreen: () => import("./ShareablesScreen-xqMDNJ6m.mjs").then((m) => m.shareablesScreenPropertySchema),
3824
- ShopScreen: () => import("./ShopScreen-D2cMeKSk.mjs").then((m) => m.shopScreenPropertySchema),
3821
+ ProductsScreen: () => import("./ProductsScreen-GOW8lxiN.mjs").then((m) => m.productsScreenPropertySchema),
3822
+ MySiteScreen: () => import("./MySiteScreen-bUfo9RDR.mjs").then((m) => m.mySiteScreenPropertySchema),
3823
+ ShareablesScreen: () => import("./ShareablesScreen-KFwyduqD.mjs").then((m) => m.shareablesScreenPropertySchema),
3824
+ ShopScreen: () => import("./ShopScreen-Bg696rqv.mjs").then((m) => m.shopScreenPropertySchema),
3825
3825
  UpgradeScreen: () => import("./UpgradeScreen-D7LfdVSJ.mjs").then((n) => n.t).then((m) => m.upgradeScreenPropertySchema),
3826
- AppDownloadScreen: () => import("./AppDownloadScreen-CLWxnFsd.mjs").then((m) => m.appDownloadScreenPropertySchema)
3826
+ AppDownloadScreen: () => import("./AppDownloadScreen-DUGGDlr4.mjs").then((m) => m.appDownloadScreenPropertySchema)
3827
3827
  };
3828
3828
  /**
3829
3829
  * Core page template IDs
@@ -1,5 +1,5 @@
1
1
  require("./chunk-DAgNkxik.cjs");
2
- const require_FluidProvider = require("./FluidProvider-9JuTycML.cjs");
2
+ const require_FluidProvider = require("./FluidProvider-SnHdl4ww.cjs");
3
3
  let react = require("react");
4
4
  //#region src/hooks/use-fluid-auth.ts
5
5
  /**
@@ -151,4 +151,4 @@ Object.defineProperty(exports, "useSubscriptionsClient", {
151
151
  }
152
152
  });
153
153
 
154
- //# sourceMappingURL=use-account-clients-cHyQEhPp.cjs.map
154
+ //# sourceMappingURL=use-account-clients-Bem920_7.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"use-account-clients-cHyQEhPp.cjs","names":["useFluidAuthContext","useFluidContext","createOrdersFetchClient","createSubscriptionsFetchClient","createFluidPayFetchClient","createCoreFetchClient"],"sources":["../src/hooks/use-fluid-auth.ts","../src/account/use-account-clients.ts"],"sourcesContent":["/**\n * useFluidAuth Hook\n *\n * Provides access to authentication state and utilities.\n * This is the primary hook for interacting with auth in components.\n */\n\nimport { useFluidAuthContext } from \"../providers/FluidAuthProvider\";\nimport type { FluidAuthContextValue } from \"../auth/types\";\n\n/**\n * Hook to access authentication state and utilities.\n *\n * Must be used within a `FluidAuthProvider`.\n *\n * @returns Authentication context with user info, loading state, and utilities\n * @throws Error if used outside FluidAuthProvider\n *\n * @example\n * ```tsx\n * function UserProfile() {\n * const { isAuthenticated, isLoading, user, clearAuth } = useFluidAuth();\n *\n * if (isLoading) {\n * return <Spinner />;\n * }\n *\n * if (!isAuthenticated) {\n * return <p>Please log in</p>;\n * }\n *\n * return (\n * <div>\n * <p>Welcome, {user.full_name}!</p>\n * <button onClick={clearAuth}>Log out</button>\n * </div>\n * );\n * }\n * ```\n */\nexport function useFluidAuth(): FluidAuthContextValue {\n return useFluidAuthContext();\n}\n","import { useMemo } from \"react\";\nimport {\n createFetchClient as createOrdersFetchClient,\n type FetchClient as OrdersFetchClient,\n} from \"@fluid-app/orders-api-client\";\nimport {\n createFetchClient as createSubscriptionsFetchClient,\n type FetchClient as SubscriptionsFetchClient,\n} from \"@fluid-app/subscriptions-api-client\";\nimport {\n createFetchClient as createFluidPayFetchClient,\n type FetchClient as FluidPayFetchClient,\n} from \"@fluid-app/fluid-pay-api-client\";\nimport {\n createFetchClient as createCoreFetchClient,\n type FetchClient as CoreFetchClient,\n} from \"@fluid-app/api-client-core\";\nimport { useFluidContext } from \"../providers/FluidProvider\";\nimport { useFluidAuth } from \"../hooks/use-fluid-auth\";\n\n/** API version prefix for versioned endpoints (e.g. points ledger) */\nexport const API_VERSION = \"/v202506\";\n\n/**\n * Ensures baseUrl ends with /api.\n * Domain-specific API clients (orders, subscriptions, fluid-pay) use endpoint\n * paths without /api (e.g. /fluid_pay/me, /subscriptions), matching fluid-admin's\n * NEXT_PUBLIC_API_URL convention. The portal SDK's config.baseUrl is the domain\n * root (e.g. https://api.fluid.app), so we append /api here.\n */\nfunction withApiPrefix(baseUrl: string): string {\n const base = baseUrl.replace(/\\/+$/, \"\");\n return base.endsWith(\"/api\") ? base : `${base}/api`;\n}\n\nexport function useOrdersClient(): OrdersFetchClient {\n const { config } = useFluidContext();\n const { token } = useFluidAuth();\n\n return useMemo(\n () =>\n createOrdersFetchClient({\n baseUrl: withApiPrefix(config.baseUrl),\n getAuthToken: () => token,\n onAuthError: config.onAuthError,\n }),\n [config.baseUrl, config.onAuthError, token],\n );\n}\n\nexport function useSubscriptionsClient(): SubscriptionsFetchClient {\n const { config } = useFluidContext();\n const { token } = useFluidAuth();\n\n return useMemo(\n () =>\n createSubscriptionsFetchClient({\n baseUrl: withApiPrefix(config.baseUrl),\n getAuthToken: () => token,\n onAuthError: config.onAuthError,\n }),\n [config.baseUrl, config.onAuthError, token],\n );\n}\n\nexport function useFluidPayClient(): FluidPayFetchClient {\n const { config } = useFluidContext();\n const { token } = useFluidAuth();\n\n return useMemo(\n () =>\n createFluidPayFetchClient({\n baseUrl: withApiPrefix(config.baseUrl),\n getAuthToken: () => token,\n onAuthError: config.onAuthError,\n }),\n [config.baseUrl, config.onAuthError, token],\n );\n}\n\n/**\n * Generic SDK fetch client for endpoints not covered by domain-specific clients\n * (e.g. /countries, /v202506/customers/:id/points_ledgers).\n * Uses the same auth/baseUrl/error handling as the domain clients.\n */\nexport function useSdkClient(): CoreFetchClient {\n const { config } = useFluidContext();\n const { token } = useFluidAuth();\n\n return useMemo(\n () =>\n createCoreFetchClient({\n baseUrl: withApiPrefix(config.baseUrl),\n getAuthToken: () => token,\n onAuthError: config.onAuthError,\n }),\n [config.baseUrl, config.onAuthError, token],\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAwCA,SAAgB,eAAsC;AACpD,QAAOA,sBAAAA,qBAAqB;;;;;ACpB9B,MAAa,cAAc;;;;;;;;AAS3B,SAAS,cAAc,SAAyB;CAC9C,MAAM,OAAO,QAAQ,QAAQ,QAAQ,GAAG;AACxC,QAAO,KAAK,SAAS,OAAO,GAAG,OAAO,GAAG,KAAK;;AAGhD,SAAgB,kBAAqC;CACnD,MAAM,EAAE,WAAWC,sBAAAA,iBAAiB;CACpC,MAAM,EAAE,UAAU,cAAc;AAEhC,SAAA,GAAA,MAAA,eAEIC,sBAAAA,kBAAwB;EACtB,SAAS,cAAc,OAAO,QAAQ;EACtC,oBAAoB;EACpB,aAAa,OAAO;EACrB,CAAC,EACJ;EAAC,OAAO;EAAS,OAAO;EAAa;EAAM,CAC5C;;AAGH,SAAgB,yBAAmD;CACjE,MAAM,EAAE,WAAWD,sBAAAA,iBAAiB;CACpC,MAAM,EAAE,UAAU,cAAc;AAEhC,SAAA,GAAA,MAAA,eAEIE,sBAAAA,kBAA+B;EAC7B,SAAS,cAAc,OAAO,QAAQ;EACtC,oBAAoB;EACpB,aAAa,OAAO;EACrB,CAAC,EACJ;EAAC,OAAO;EAAS,OAAO;EAAa;EAAM,CAC5C;;AAGH,SAAgB,oBAAyC;CACvD,MAAM,EAAE,WAAWF,sBAAAA,iBAAiB;CACpC,MAAM,EAAE,UAAU,cAAc;AAEhC,SAAA,GAAA,MAAA,eAEIG,sBAAAA,kBAA0B;EACxB,SAAS,cAAc,OAAO,QAAQ;EACtC,oBAAoB;EACpB,aAAa,OAAO;EACrB,CAAC,EACJ;EAAC,OAAO;EAAS,OAAO;EAAa;EAAM,CAC5C;;;;;;;AAQH,SAAgB,eAAgC;CAC9C,MAAM,EAAE,WAAWH,sBAAAA,iBAAiB;CACpC,MAAM,EAAE,UAAU,cAAc;AAEhC,SAAA,GAAA,MAAA,eAEII,sBAAAA,kBAAsB;EACpB,SAAS,cAAc,OAAO,QAAQ;EACtC,oBAAoB;EACpB,aAAa,OAAO;EACrB,CAAC,EACJ;EAAC,OAAO;EAAS,OAAO;EAAa;EAAM,CAC5C"}
1
+ {"version":3,"file":"use-account-clients-Bem920_7.cjs","names":["useFluidAuthContext","useFluidContext","createOrdersFetchClient","createSubscriptionsFetchClient","createFluidPayFetchClient","createCoreFetchClient"],"sources":["../src/hooks/use-fluid-auth.ts","../src/account/use-account-clients.ts"],"sourcesContent":["/**\n * useFluidAuth Hook\n *\n * Provides access to authentication state and utilities.\n * This is the primary hook for interacting with auth in components.\n */\n\nimport { useFluidAuthContext } from \"../providers/FluidAuthProvider\";\nimport type { FluidAuthContextValue } from \"../auth/types\";\n\n/**\n * Hook to access authentication state and utilities.\n *\n * Must be used within a `FluidAuthProvider`.\n *\n * @returns Authentication context with user info, loading state, and utilities\n * @throws Error if used outside FluidAuthProvider\n *\n * @example\n * ```tsx\n * function UserProfile() {\n * const { isAuthenticated, isLoading, user, clearAuth } = useFluidAuth();\n *\n * if (isLoading) {\n * return <Spinner />;\n * }\n *\n * if (!isAuthenticated) {\n * return <p>Please log in</p>;\n * }\n *\n * return (\n * <div>\n * <p>Welcome, {user.full_name}!</p>\n * <button onClick={clearAuth}>Log out</button>\n * </div>\n * );\n * }\n * ```\n */\nexport function useFluidAuth(): FluidAuthContextValue {\n return useFluidAuthContext();\n}\n","import { useMemo } from \"react\";\nimport {\n createFetchClient as createOrdersFetchClient,\n type FetchClient as OrdersFetchClient,\n} from \"@fluid-app/orders-api-client\";\nimport {\n createFetchClient as createSubscriptionsFetchClient,\n type FetchClient as SubscriptionsFetchClient,\n} from \"@fluid-app/subscriptions-api-client\";\nimport {\n createFetchClient as createFluidPayFetchClient,\n type FetchClient as FluidPayFetchClient,\n} from \"@fluid-app/fluid-pay-api-client\";\nimport {\n createFetchClient as createCoreFetchClient,\n type FetchClient as CoreFetchClient,\n} from \"@fluid-app/api-client-core\";\nimport { useFluidContext } from \"../providers/FluidProvider\";\nimport { useFluidAuth } from \"../hooks/use-fluid-auth\";\n\n/** API version prefix for versioned endpoints (e.g. points ledger) */\nexport const API_VERSION = \"/v202506\";\n\n/**\n * Ensures baseUrl ends with /api.\n * Domain-specific API clients (orders, subscriptions, fluid-pay) use endpoint\n * paths without /api (e.g. /fluid_pay/me, /subscriptions), matching fluid-admin's\n * NEXT_PUBLIC_API_URL convention. The portal SDK's config.baseUrl is the domain\n * root (e.g. https://api.fluid.app), so we append /api here.\n */\nfunction withApiPrefix(baseUrl: string): string {\n const base = baseUrl.replace(/\\/+$/, \"\");\n return base.endsWith(\"/api\") ? base : `${base}/api`;\n}\n\nexport function useOrdersClient(): OrdersFetchClient {\n const { config } = useFluidContext();\n const { token } = useFluidAuth();\n\n return useMemo(\n () =>\n createOrdersFetchClient({\n baseUrl: withApiPrefix(config.baseUrl),\n getAuthToken: () => token,\n onAuthError: config.onAuthError,\n }),\n [config.baseUrl, config.onAuthError, token],\n );\n}\n\nexport function useSubscriptionsClient(): SubscriptionsFetchClient {\n const { config } = useFluidContext();\n const { token } = useFluidAuth();\n\n return useMemo(\n () =>\n createSubscriptionsFetchClient({\n baseUrl: withApiPrefix(config.baseUrl),\n getAuthToken: () => token,\n onAuthError: config.onAuthError,\n }),\n [config.baseUrl, config.onAuthError, token],\n );\n}\n\nexport function useFluidPayClient(): FluidPayFetchClient {\n const { config } = useFluidContext();\n const { token } = useFluidAuth();\n\n return useMemo(\n () =>\n createFluidPayFetchClient({\n baseUrl: withApiPrefix(config.baseUrl),\n getAuthToken: () => token,\n onAuthError: config.onAuthError,\n }),\n [config.baseUrl, config.onAuthError, token],\n );\n}\n\n/**\n * Generic SDK fetch client for endpoints not covered by domain-specific clients\n * (e.g. /countries, /v202506/customers/:id/points_ledgers).\n * Uses the same auth/baseUrl/error handling as the domain clients.\n */\nexport function useSdkClient(): CoreFetchClient {\n const { config } = useFluidContext();\n const { token } = useFluidAuth();\n\n return useMemo(\n () =>\n createCoreFetchClient({\n baseUrl: withApiPrefix(config.baseUrl),\n getAuthToken: () => token,\n onAuthError: config.onAuthError,\n }),\n [config.baseUrl, config.onAuthError, token],\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAwCA,SAAgB,eAAsC;AACpD,QAAOA,sBAAAA,qBAAqB;;;;;ACpB9B,MAAa,cAAc;;;;;;;;AAS3B,SAAS,cAAc,SAAyB;CAC9C,MAAM,OAAO,QAAQ,QAAQ,QAAQ,GAAG;AACxC,QAAO,KAAK,SAAS,OAAO,GAAG,OAAO,GAAG,KAAK;;AAGhD,SAAgB,kBAAqC;CACnD,MAAM,EAAE,WAAWC,sBAAAA,iBAAiB;CACpC,MAAM,EAAE,UAAU,cAAc;AAEhC,SAAA,GAAA,MAAA,eAEIC,sBAAAA,kBAAwB;EACtB,SAAS,cAAc,OAAO,QAAQ;EACtC,oBAAoB;EACpB,aAAa,OAAO;EACrB,CAAC,EACJ;EAAC,OAAO;EAAS,OAAO;EAAa;EAAM,CAC5C;;AAGH,SAAgB,yBAAmD;CACjE,MAAM,EAAE,WAAWD,sBAAAA,iBAAiB;CACpC,MAAM,EAAE,UAAU,cAAc;AAEhC,SAAA,GAAA,MAAA,eAEIE,sBAAAA,kBAA+B;EAC7B,SAAS,cAAc,OAAO,QAAQ;EACtC,oBAAoB;EACpB,aAAa,OAAO;EACrB,CAAC,EACJ;EAAC,OAAO;EAAS,OAAO;EAAa;EAAM,CAC5C;;AAGH,SAAgB,oBAAyC;CACvD,MAAM,EAAE,WAAWF,sBAAAA,iBAAiB;CACpC,MAAM,EAAE,UAAU,cAAc;AAEhC,SAAA,GAAA,MAAA,eAEIG,sBAAAA,kBAA0B;EACxB,SAAS,cAAc,OAAO,QAAQ;EACtC,oBAAoB;EACpB,aAAa,OAAO;EACrB,CAAC,EACJ;EAAC,OAAO;EAAS,OAAO;EAAa;EAAM,CAC5C;;;;;;;AAQH,SAAgB,eAAgC;CAC9C,MAAM,EAAE,WAAWH,sBAAAA,iBAAiB;CACpC,MAAM,EAAE,UAAU,cAAc;AAEhC,SAAA,GAAA,MAAA,eAEII,sBAAAA,kBAAsB;EACpB,SAAS,cAAc,OAAO,QAAQ;EACtC,oBAAoB;EACpB,aAAa,OAAO;EACrB,CAAC,EACJ;EAAC,OAAO;EAAS,OAAO;EAAa;EAAM,CAC5C"}
@@ -1,4 +1,4 @@
1
- import { n as useFluidContext, o as useFluidAuthContext, q as createFetchClient } from "./FluidProvider-9ZC28GXK.mjs";
1
+ import { n as useFluidContext, o as useFluidAuthContext, q as createFetchClient } from "./FluidProvider-uuu90TSG.mjs";
2
2
  import { useMemo } from "react";
3
3
  //#region src/hooks/use-fluid-auth.ts
4
4
  /**
@@ -115,4 +115,4 @@ function useSdkClient() {
115
115
  //#endregion
116
116
  export { useSubscriptionsClient as a, useSdkClient as i, useFluidPayClient as n, useFluidAuth as o, useOrdersClient as r, API_VERSION as t };
117
117
 
118
- //# sourceMappingURL=use-account-clients-CqC0etbc.mjs.map
118
+ //# sourceMappingURL=use-account-clients-FUcF1B-z.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"use-account-clients-CqC0etbc.mjs","names":["createOrdersFetchClient","createSubscriptionsFetchClient","createFluidPayFetchClient","createCoreFetchClient"],"sources":["../src/hooks/use-fluid-auth.ts","../src/account/use-account-clients.ts"],"sourcesContent":["/**\n * useFluidAuth Hook\n *\n * Provides access to authentication state and utilities.\n * This is the primary hook for interacting with auth in components.\n */\n\nimport { useFluidAuthContext } from \"../providers/FluidAuthProvider\";\nimport type { FluidAuthContextValue } from \"../auth/types\";\n\n/**\n * Hook to access authentication state and utilities.\n *\n * Must be used within a `FluidAuthProvider`.\n *\n * @returns Authentication context with user info, loading state, and utilities\n * @throws Error if used outside FluidAuthProvider\n *\n * @example\n * ```tsx\n * function UserProfile() {\n * const { isAuthenticated, isLoading, user, clearAuth } = useFluidAuth();\n *\n * if (isLoading) {\n * return <Spinner />;\n * }\n *\n * if (!isAuthenticated) {\n * return <p>Please log in</p>;\n * }\n *\n * return (\n * <div>\n * <p>Welcome, {user.full_name}!</p>\n * <button onClick={clearAuth}>Log out</button>\n * </div>\n * );\n * }\n * ```\n */\nexport function useFluidAuth(): FluidAuthContextValue {\n return useFluidAuthContext();\n}\n","import { useMemo } from \"react\";\nimport {\n createFetchClient as createOrdersFetchClient,\n type FetchClient as OrdersFetchClient,\n} from \"@fluid-app/orders-api-client\";\nimport {\n createFetchClient as createSubscriptionsFetchClient,\n type FetchClient as SubscriptionsFetchClient,\n} from \"@fluid-app/subscriptions-api-client\";\nimport {\n createFetchClient as createFluidPayFetchClient,\n type FetchClient as FluidPayFetchClient,\n} from \"@fluid-app/fluid-pay-api-client\";\nimport {\n createFetchClient as createCoreFetchClient,\n type FetchClient as CoreFetchClient,\n} from \"@fluid-app/api-client-core\";\nimport { useFluidContext } from \"../providers/FluidProvider\";\nimport { useFluidAuth } from \"../hooks/use-fluid-auth\";\n\n/** API version prefix for versioned endpoints (e.g. points ledger) */\nexport const API_VERSION = \"/v202506\";\n\n/**\n * Ensures baseUrl ends with /api.\n * Domain-specific API clients (orders, subscriptions, fluid-pay) use endpoint\n * paths without /api (e.g. /fluid_pay/me, /subscriptions), matching fluid-admin's\n * NEXT_PUBLIC_API_URL convention. The portal SDK's config.baseUrl is the domain\n * root (e.g. https://api.fluid.app), so we append /api here.\n */\nfunction withApiPrefix(baseUrl: string): string {\n const base = baseUrl.replace(/\\/+$/, \"\");\n return base.endsWith(\"/api\") ? base : `${base}/api`;\n}\n\nexport function useOrdersClient(): OrdersFetchClient {\n const { config } = useFluidContext();\n const { token } = useFluidAuth();\n\n return useMemo(\n () =>\n createOrdersFetchClient({\n baseUrl: withApiPrefix(config.baseUrl),\n getAuthToken: () => token,\n onAuthError: config.onAuthError,\n }),\n [config.baseUrl, config.onAuthError, token],\n );\n}\n\nexport function useSubscriptionsClient(): SubscriptionsFetchClient {\n const { config } = useFluidContext();\n const { token } = useFluidAuth();\n\n return useMemo(\n () =>\n createSubscriptionsFetchClient({\n baseUrl: withApiPrefix(config.baseUrl),\n getAuthToken: () => token,\n onAuthError: config.onAuthError,\n }),\n [config.baseUrl, config.onAuthError, token],\n );\n}\n\nexport function useFluidPayClient(): FluidPayFetchClient {\n const { config } = useFluidContext();\n const { token } = useFluidAuth();\n\n return useMemo(\n () =>\n createFluidPayFetchClient({\n baseUrl: withApiPrefix(config.baseUrl),\n getAuthToken: () => token,\n onAuthError: config.onAuthError,\n }),\n [config.baseUrl, config.onAuthError, token],\n );\n}\n\n/**\n * Generic SDK fetch client for endpoints not covered by domain-specific clients\n * (e.g. /countries, /v202506/customers/:id/points_ledgers).\n * Uses the same auth/baseUrl/error handling as the domain clients.\n */\nexport function useSdkClient(): CoreFetchClient {\n const { config } = useFluidContext();\n const { token } = useFluidAuth();\n\n return useMemo(\n () =>\n createCoreFetchClient({\n baseUrl: withApiPrefix(config.baseUrl),\n getAuthToken: () => token,\n onAuthError: config.onAuthError,\n }),\n [config.baseUrl, config.onAuthError, token],\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAwCA,SAAgB,eAAsC;AACpD,QAAO,qBAAqB;;;;;ACpB9B,MAAa,cAAc;;;;;;;;AAS3B,SAAS,cAAc,SAAyB;CAC9C,MAAM,OAAO,QAAQ,QAAQ,QAAQ,GAAG;AACxC,QAAO,KAAK,SAAS,OAAO,GAAG,OAAO,GAAG,KAAK;;AAGhD,SAAgB,kBAAqC;CACnD,MAAM,EAAE,WAAW,iBAAiB;CACpC,MAAM,EAAE,UAAU,cAAc;AAEhC,QAAO,cAEHA,kBAAwB;EACtB,SAAS,cAAc,OAAO,QAAQ;EACtC,oBAAoB;EACpB,aAAa,OAAO;EACrB,CAAC,EACJ;EAAC,OAAO;EAAS,OAAO;EAAa;EAAM,CAC5C;;AAGH,SAAgB,yBAAmD;CACjE,MAAM,EAAE,WAAW,iBAAiB;CACpC,MAAM,EAAE,UAAU,cAAc;AAEhC,QAAO,cAEHC,kBAA+B;EAC7B,SAAS,cAAc,OAAO,QAAQ;EACtC,oBAAoB;EACpB,aAAa,OAAO;EACrB,CAAC,EACJ;EAAC,OAAO;EAAS,OAAO;EAAa;EAAM,CAC5C;;AAGH,SAAgB,oBAAyC;CACvD,MAAM,EAAE,WAAW,iBAAiB;CACpC,MAAM,EAAE,UAAU,cAAc;AAEhC,QAAO,cAEHC,kBAA0B;EACxB,SAAS,cAAc,OAAO,QAAQ;EACtC,oBAAoB;EACpB,aAAa,OAAO;EACrB,CAAC,EACJ;EAAC,OAAO;EAAS,OAAO;EAAa;EAAM,CAC5C;;;;;;;AAQH,SAAgB,eAAgC;CAC9C,MAAM,EAAE,WAAW,iBAAiB;CACpC,MAAM,EAAE,UAAU,cAAc;AAEhC,QAAO,cAEHC,kBAAsB;EACpB,SAAS,cAAc,OAAO,QAAQ;EACtC,oBAAoB;EACpB,aAAa,OAAO;EACrB,CAAC,EACJ;EAAC,OAAO;EAAS,OAAO;EAAa;EAAM,CAC5C"}
1
+ {"version":3,"file":"use-account-clients-FUcF1B-z.mjs","names":["createOrdersFetchClient","createSubscriptionsFetchClient","createFluidPayFetchClient","createCoreFetchClient"],"sources":["../src/hooks/use-fluid-auth.ts","../src/account/use-account-clients.ts"],"sourcesContent":["/**\n * useFluidAuth Hook\n *\n * Provides access to authentication state and utilities.\n * This is the primary hook for interacting with auth in components.\n */\n\nimport { useFluidAuthContext } from \"../providers/FluidAuthProvider\";\nimport type { FluidAuthContextValue } from \"../auth/types\";\n\n/**\n * Hook to access authentication state and utilities.\n *\n * Must be used within a `FluidAuthProvider`.\n *\n * @returns Authentication context with user info, loading state, and utilities\n * @throws Error if used outside FluidAuthProvider\n *\n * @example\n * ```tsx\n * function UserProfile() {\n * const { isAuthenticated, isLoading, user, clearAuth } = useFluidAuth();\n *\n * if (isLoading) {\n * return <Spinner />;\n * }\n *\n * if (!isAuthenticated) {\n * return <p>Please log in</p>;\n * }\n *\n * return (\n * <div>\n * <p>Welcome, {user.full_name}!</p>\n * <button onClick={clearAuth}>Log out</button>\n * </div>\n * );\n * }\n * ```\n */\nexport function useFluidAuth(): FluidAuthContextValue {\n return useFluidAuthContext();\n}\n","import { useMemo } from \"react\";\nimport {\n createFetchClient as createOrdersFetchClient,\n type FetchClient as OrdersFetchClient,\n} from \"@fluid-app/orders-api-client\";\nimport {\n createFetchClient as createSubscriptionsFetchClient,\n type FetchClient as SubscriptionsFetchClient,\n} from \"@fluid-app/subscriptions-api-client\";\nimport {\n createFetchClient as createFluidPayFetchClient,\n type FetchClient as FluidPayFetchClient,\n} from \"@fluid-app/fluid-pay-api-client\";\nimport {\n createFetchClient as createCoreFetchClient,\n type FetchClient as CoreFetchClient,\n} from \"@fluid-app/api-client-core\";\nimport { useFluidContext } from \"../providers/FluidProvider\";\nimport { useFluidAuth } from \"../hooks/use-fluid-auth\";\n\n/** API version prefix for versioned endpoints (e.g. points ledger) */\nexport const API_VERSION = \"/v202506\";\n\n/**\n * Ensures baseUrl ends with /api.\n * Domain-specific API clients (orders, subscriptions, fluid-pay) use endpoint\n * paths without /api (e.g. /fluid_pay/me, /subscriptions), matching fluid-admin's\n * NEXT_PUBLIC_API_URL convention. The portal SDK's config.baseUrl is the domain\n * root (e.g. https://api.fluid.app), so we append /api here.\n */\nfunction withApiPrefix(baseUrl: string): string {\n const base = baseUrl.replace(/\\/+$/, \"\");\n return base.endsWith(\"/api\") ? base : `${base}/api`;\n}\n\nexport function useOrdersClient(): OrdersFetchClient {\n const { config } = useFluidContext();\n const { token } = useFluidAuth();\n\n return useMemo(\n () =>\n createOrdersFetchClient({\n baseUrl: withApiPrefix(config.baseUrl),\n getAuthToken: () => token,\n onAuthError: config.onAuthError,\n }),\n [config.baseUrl, config.onAuthError, token],\n );\n}\n\nexport function useSubscriptionsClient(): SubscriptionsFetchClient {\n const { config } = useFluidContext();\n const { token } = useFluidAuth();\n\n return useMemo(\n () =>\n createSubscriptionsFetchClient({\n baseUrl: withApiPrefix(config.baseUrl),\n getAuthToken: () => token,\n onAuthError: config.onAuthError,\n }),\n [config.baseUrl, config.onAuthError, token],\n );\n}\n\nexport function useFluidPayClient(): FluidPayFetchClient {\n const { config } = useFluidContext();\n const { token } = useFluidAuth();\n\n return useMemo(\n () =>\n createFluidPayFetchClient({\n baseUrl: withApiPrefix(config.baseUrl),\n getAuthToken: () => token,\n onAuthError: config.onAuthError,\n }),\n [config.baseUrl, config.onAuthError, token],\n );\n}\n\n/**\n * Generic SDK fetch client for endpoints not covered by domain-specific clients\n * (e.g. /countries, /v202506/customers/:id/points_ledgers).\n * Uses the same auth/baseUrl/error handling as the domain clients.\n */\nexport function useSdkClient(): CoreFetchClient {\n const { config } = useFluidContext();\n const { token } = useFluidAuth();\n\n return useMemo(\n () =>\n createCoreFetchClient({\n baseUrl: withApiPrefix(config.baseUrl),\n getAuthToken: () => token,\n onAuthError: config.onAuthError,\n }),\n [config.baseUrl, config.onAuthError, token],\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAwCA,SAAgB,eAAsC;AACpD,QAAO,qBAAqB;;;;;ACpB9B,MAAa,cAAc;;;;;;;;AAS3B,SAAS,cAAc,SAAyB;CAC9C,MAAM,OAAO,QAAQ,QAAQ,QAAQ,GAAG;AACxC,QAAO,KAAK,SAAS,OAAO,GAAG,OAAO,GAAG,KAAK;;AAGhD,SAAgB,kBAAqC;CACnD,MAAM,EAAE,WAAW,iBAAiB;CACpC,MAAM,EAAE,UAAU,cAAc;AAEhC,QAAO,cAEHA,kBAAwB;EACtB,SAAS,cAAc,OAAO,QAAQ;EACtC,oBAAoB;EACpB,aAAa,OAAO;EACrB,CAAC,EACJ;EAAC,OAAO;EAAS,OAAO;EAAa;EAAM,CAC5C;;AAGH,SAAgB,yBAAmD;CACjE,MAAM,EAAE,WAAW,iBAAiB;CACpC,MAAM,EAAE,UAAU,cAAc;AAEhC,QAAO,cAEHC,kBAA+B;EAC7B,SAAS,cAAc,OAAO,QAAQ;EACtC,oBAAoB;EACpB,aAAa,OAAO;EACrB,CAAC,EACJ;EAAC,OAAO;EAAS,OAAO;EAAa;EAAM,CAC5C;;AAGH,SAAgB,oBAAyC;CACvD,MAAM,EAAE,WAAW,iBAAiB;CACpC,MAAM,EAAE,UAAU,cAAc;AAEhC,QAAO,cAEHC,kBAA0B;EACxB,SAAS,cAAc,OAAO,QAAQ;EACtC,oBAAoB;EACpB,aAAa,OAAO;EACrB,CAAC,EACJ;EAAC,OAAO;EAAS,OAAO;EAAa;EAAM,CAC5C;;;;;;;AAQH,SAAgB,eAAgC;CAC9C,MAAM,EAAE,WAAW,iBAAiB;CACpC,MAAM,EAAE,UAAU,cAAc;AAEhC,QAAO,cAEHC,kBAAsB;EACpB,SAAS,cAAc,OAAO,QAAQ;EACtC,oBAAoB;EACpB,aAAa,OAAO;EACrB,CAAC,EACJ;EAAC,OAAO;EAAS,OAAO;EAAa;EAAM,CAC5C"}
@@ -1,6 +1,6 @@
1
1
  require("./chunk-DAgNkxik.cjs");
2
- const require_FluidProvider = require("./FluidProvider-9JuTycML.cjs");
3
- const require_use_fluid_api = require("./use-fluid-api-CBm9h3s3.cjs");
2
+ const require_FluidProvider = require("./FluidProvider-SnHdl4ww.cjs");
3
+ const require_use_fluid_api = require("./use-fluid-api-DyI6LDsV.cjs");
4
4
  let react = require("react");
5
5
  let _tanstack_react_query = require("@tanstack/react-query");
6
6
  //#region src/hooks/query-keys.ts
@@ -122,4 +122,4 @@ Object.defineProperty(exports, "useCurrentUser", {
122
122
  }
123
123
  });
124
124
 
125
- //# sourceMappingURL=use-current-user-Ccn1lGeB.cjs.map
125
+ //# sourceMappingURL=use-current-user-Bld9wMVT.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"use-current-user-Ccn1lGeB.cjs","names":["useFluidAuthContext","useFluidApi"],"sources":["../src/hooks/query-keys.ts","../src/hooks/use-current-user.ts"],"sourcesContent":["/**\n * Company-scoped query key factory for TanStack Query.\n *\n * All portal SDK query keys are prefixed with [\"company\", companyId, ...]\n * so that switching companies naturally invalidates the entire cache scope.\n *\n * The exported `*_QUERY_KEY` constants (e.g. PROFILE_QUERY_KEY) remain as\n * backwards-compatible base keys. The runtime keys used by hooks include the\n * company prefix via {@link createCompanyQueryKey}.\n */\n\nimport { useCallback, useRef } from \"react\";\nimport { useFluidAuthContext } from \"../providers/FluidAuthProvider\";\n\n/**\n * Create a company-scoped query key by prepending [\"company\", companyId].\n *\n * @param companyId - The company ID from the JWT payload\n * @param baseKey - The base query key segments (e.g. [\"fluid\", \"profile\"])\n * @returns A tuple like [\"company\", 42, \"fluid\", \"profile\"]\n *\n * @example\n * ```ts\n * const key = createCompanyQueryKey(42, \"fluid\", \"profile\");\n * // => [\"company\", 42, \"fluid\", \"profile\"]\n * ```\n */\nexport function createCompanyQueryKey(\n companyId: number,\n ...baseKey: readonly string[]\n): readonly [\"company\", number, ...string[]] {\n return [\"company\", companyId, ...baseKey] as const;\n}\n\n/**\n * Hook that returns a `scopeKey` function bound to the current company ID\n * from the auth context. If the user is not authenticated or has no\n * company_id, the base key is returned unscoped (graceful degradation).\n *\n * @example\n * ```tsx\n * function MyComponent() {\n * const { scopeKey } = useCompanyScopedQueryKey();\n * const queryKey = scopeKey(PROFILE_QUERY_KEY);\n * // => [\"company\", 42, \"fluid\", \"profile\"] (when authenticated)\n * // => [\"fluid\", \"profile\"] (fallback)\n * }\n * ```\n */\nexport function useCompanyScopedQueryKey(): {\n readonly companyId: number | undefined;\n readonly scopeKey: <T extends readonly string[]>(\n baseKey: T,\n ) => readonly (string | number)[];\n} {\n const auth = useFluidAuthContext();\n const companyId = auth.user?.company_id;\n\n // Warn (once per component instance) when an authenticated user has no\n // company_id. This is a security-relevant condition: unscoped keys allow\n // cross-company cache collisions. The warning fires in all environments\n // so that it's visible in production logs if a misconfigured JWT is issued.\n const hasWarnedRef = useRef(false);\n if (auth.isAuthenticated && companyId == null && !hasWarnedRef.current) {\n hasWarnedRef.current = true;\n console.warn(\n \"[portal-sdk] Authenticated user has no company_id in JWT. \" +\n \"Query keys will fall back to unscoped keys, which may cause \" +\n \"cross-company cache collisions. Ensure the JWT includes company_id.\",\n );\n }\n\n const scopeKey = useCallback(\n <T extends readonly string[]>(baseKey: T): readonly (string | number)[] => {\n if (companyId != null) {\n return createCompanyQueryKey(companyId, ...baseKey);\n }\n return baseKey;\n },\n [companyId],\n );\n\n return { companyId, scopeKey } as const;\n}\n","import { useQuery, type UseQueryResult } from \"@tanstack/react-query\";\nimport { useFluidApi } from \"./use-fluid-api\";\nimport { useCompanyScopedQueryKey } from \"./query-keys\";\nimport type { UserMe } from \"../types/rep\";\n\n/**\n * Base query key for current user data.\n * Kept for backwards compatibility — the runtime key used by the hook\n * includes a company prefix via {@link useCompanyScopedQueryKey}.\n */\nexport const CURRENT_USER_QUERY_KEY = [\"fluid\", \"currentUser\"] as const;\n\n/**\n * Hook to fetch the currently authenticated user's full profile.\n * Returns company, country, and other fields from GET /api/me.\n *\n * @example\n * ```tsx\n * function ShopPage() {\n * const { data: user, isLoading } = useCurrentUser();\n * const subdomain = user?.company?.subdomain;\n * const countryIso = user?.country?.iso ?? \"US\";\n * // ...\n * }\n * ```\n */\nexport function useCurrentUser(): UseQueryResult<UserMe> {\n const api = useFluidApi();\n const { scopeKey } = useCompanyScopedQueryKey();\n\n return useQuery({\n queryKey: scopeKey(CURRENT_USER_QUERY_KEY),\n queryFn: () => api.users.me(),\n staleTime: 5 * 60 * 1000,\n });\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA2BA,SAAgB,sBACd,WACA,GAAG,SACwC;AAC3C,QAAO;EAAC;EAAW;EAAW,GAAG;EAAQ;;;;;;;;;;;;;;;;;AAkB3C,SAAgB,2BAKd;CACA,MAAM,OAAOA,sBAAAA,qBAAqB;CAClC,MAAM,YAAY,KAAK,MAAM;CAM7B,MAAM,gBAAA,GAAA,MAAA,QAAsB,MAAM;AAClC,KAAI,KAAK,mBAAmB,aAAa,QAAQ,CAAC,aAAa,SAAS;AACtE,eAAa,UAAU;AACvB,UAAQ,KACN,4LAGD;;AAaH,QAAO;EAAE;EAAW,WAAA,GAAA,MAAA,cATY,YAA6C;AACzE,OAAI,aAAa,KACf,QAAO,sBAAsB,WAAW,GAAG,QAAQ;AAErD,UAAO;KAET,CAAC,UAAU,CACZ;EAE6B;;;;;;;;;ACxEhC,MAAa,yBAAyB,CAAC,SAAS,cAAc;;;;;;;;;;;;;;;AAgB9D,SAAgB,iBAAyC;CACvD,MAAM,MAAMC,sBAAAA,aAAa;CACzB,MAAM,EAAE,aAAa,0BAA0B;AAE/C,SAAA,GAAA,sBAAA,UAAgB;EACd,UAAU,SAAS,uBAAuB;EAC1C,eAAe,IAAI,MAAM,IAAI;EAC7B,WAAW,MAAS;EACrB,CAAC"}
1
+ {"version":3,"file":"use-current-user-Bld9wMVT.cjs","names":["useFluidAuthContext","useFluidApi"],"sources":["../src/hooks/query-keys.ts","../src/hooks/use-current-user.ts"],"sourcesContent":["/**\n * Company-scoped query key factory for TanStack Query.\n *\n * All portal SDK query keys are prefixed with [\"company\", companyId, ...]\n * so that switching companies naturally invalidates the entire cache scope.\n *\n * The exported `*_QUERY_KEY` constants (e.g. PROFILE_QUERY_KEY) remain as\n * backwards-compatible base keys. The runtime keys used by hooks include the\n * company prefix via {@link createCompanyQueryKey}.\n */\n\nimport { useCallback, useRef } from \"react\";\nimport { useFluidAuthContext } from \"../providers/FluidAuthProvider\";\n\n/**\n * Create a company-scoped query key by prepending [\"company\", companyId].\n *\n * @param companyId - The company ID from the JWT payload\n * @param baseKey - The base query key segments (e.g. [\"fluid\", \"profile\"])\n * @returns A tuple like [\"company\", 42, \"fluid\", \"profile\"]\n *\n * @example\n * ```ts\n * const key = createCompanyQueryKey(42, \"fluid\", \"profile\");\n * // => [\"company\", 42, \"fluid\", \"profile\"]\n * ```\n */\nexport function createCompanyQueryKey(\n companyId: number,\n ...baseKey: readonly string[]\n): readonly [\"company\", number, ...string[]] {\n return [\"company\", companyId, ...baseKey] as const;\n}\n\n/**\n * Hook that returns a `scopeKey` function bound to the current company ID\n * from the auth context. If the user is not authenticated or has no\n * company_id, the base key is returned unscoped (graceful degradation).\n *\n * @example\n * ```tsx\n * function MyComponent() {\n * const { scopeKey } = useCompanyScopedQueryKey();\n * const queryKey = scopeKey(PROFILE_QUERY_KEY);\n * // => [\"company\", 42, \"fluid\", \"profile\"] (when authenticated)\n * // => [\"fluid\", \"profile\"] (fallback)\n * }\n * ```\n */\nexport function useCompanyScopedQueryKey(): {\n readonly companyId: number | undefined;\n readonly scopeKey: <T extends readonly string[]>(\n baseKey: T,\n ) => readonly (string | number)[];\n} {\n const auth = useFluidAuthContext();\n const companyId = auth.user?.company_id;\n\n // Warn (once per component instance) when an authenticated user has no\n // company_id. This is a security-relevant condition: unscoped keys allow\n // cross-company cache collisions. The warning fires in all environments\n // so that it's visible in production logs if a misconfigured JWT is issued.\n const hasWarnedRef = useRef(false);\n if (auth.isAuthenticated && companyId == null && !hasWarnedRef.current) {\n hasWarnedRef.current = true;\n console.warn(\n \"[portal-sdk] Authenticated user has no company_id in JWT. \" +\n \"Query keys will fall back to unscoped keys, which may cause \" +\n \"cross-company cache collisions. Ensure the JWT includes company_id.\",\n );\n }\n\n const scopeKey = useCallback(\n <T extends readonly string[]>(baseKey: T): readonly (string | number)[] => {\n if (companyId != null) {\n return createCompanyQueryKey(companyId, ...baseKey);\n }\n return baseKey;\n },\n [companyId],\n );\n\n return { companyId, scopeKey } as const;\n}\n","import { useQuery, type UseQueryResult } from \"@tanstack/react-query\";\nimport { useFluidApi } from \"./use-fluid-api\";\nimport { useCompanyScopedQueryKey } from \"./query-keys\";\nimport type { UserMe } from \"../types/rep\";\n\n/**\n * Base query key for current user data.\n * Kept for backwards compatibility — the runtime key used by the hook\n * includes a company prefix via {@link useCompanyScopedQueryKey}.\n */\nexport const CURRENT_USER_QUERY_KEY = [\"fluid\", \"currentUser\"] as const;\n\n/**\n * Hook to fetch the currently authenticated user's full profile.\n * Returns company, country, and other fields from GET /api/me.\n *\n * @example\n * ```tsx\n * function ShopPage() {\n * const { data: user, isLoading } = useCurrentUser();\n * const subdomain = user?.company?.subdomain;\n * const countryIso = user?.country?.iso ?? \"US\";\n * // ...\n * }\n * ```\n */\nexport function useCurrentUser(): UseQueryResult<UserMe> {\n const api = useFluidApi();\n const { scopeKey } = useCompanyScopedQueryKey();\n\n return useQuery({\n queryKey: scopeKey(CURRENT_USER_QUERY_KEY),\n queryFn: () => api.users.me(),\n staleTime: 5 * 60 * 1000,\n });\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA2BA,SAAgB,sBACd,WACA,GAAG,SACwC;AAC3C,QAAO;EAAC;EAAW;EAAW,GAAG;EAAQ;;;;;;;;;;;;;;;;;AAkB3C,SAAgB,2BAKd;CACA,MAAM,OAAOA,sBAAAA,qBAAqB;CAClC,MAAM,YAAY,KAAK,MAAM;CAM7B,MAAM,gBAAA,GAAA,MAAA,QAAsB,MAAM;AAClC,KAAI,KAAK,mBAAmB,aAAa,QAAQ,CAAC,aAAa,SAAS;AACtE,eAAa,UAAU;AACvB,UAAQ,KACN,4LAGD;;AAaH,QAAO;EAAE;EAAW,WAAA,GAAA,MAAA,cATY,YAA6C;AACzE,OAAI,aAAa,KACf,QAAO,sBAAsB,WAAW,GAAG,QAAQ;AAErD,UAAO;KAET,CAAC,UAAU,CACZ;EAE6B;;;;;;;;;ACxEhC,MAAa,yBAAyB,CAAC,SAAS,cAAc;;;;;;;;;;;;;;;AAgB9D,SAAgB,iBAAyC;CACvD,MAAM,MAAMC,sBAAAA,aAAa;CACzB,MAAM,EAAE,aAAa,0BAA0B;AAE/C,SAAA,GAAA,sBAAA,UAAgB;EACd,UAAU,SAAS,uBAAuB;EAC1C,eAAe,IAAI,MAAM,IAAI;EAC7B,WAAW,MAAS;EACrB,CAAC"}
@@ -1,5 +1,5 @@
1
- import { o as useFluidAuthContext } from "./FluidProvider-9ZC28GXK.mjs";
2
- import { t as useFluidApi } from "./use-fluid-api-BvakcAkY.mjs";
1
+ import { o as useFluidAuthContext } from "./FluidProvider-uuu90TSG.mjs";
2
+ import { t as useFluidApi } from "./use-fluid-api-CedscoxF.mjs";
3
3
  import { useCallback, useRef } from "react";
4
4
  import { useQuery } from "@tanstack/react-query";
5
5
  //#region src/hooks/query-keys.ts
@@ -98,4 +98,4 @@ function useCurrentUser() {
98
98
  //#endregion
99
99
  export { useCompanyScopedQueryKey as i, useCurrentUser as n, createCompanyQueryKey as r, CURRENT_USER_QUERY_KEY as t };
100
100
 
101
- //# sourceMappingURL=use-current-user-CyodELl8.mjs.map
101
+ //# sourceMappingURL=use-current-user-DnBpWIw6.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"use-current-user-CyodELl8.mjs","names":[],"sources":["../src/hooks/query-keys.ts","../src/hooks/use-current-user.ts"],"sourcesContent":["/**\n * Company-scoped query key factory for TanStack Query.\n *\n * All portal SDK query keys are prefixed with [\"company\", companyId, ...]\n * so that switching companies naturally invalidates the entire cache scope.\n *\n * The exported `*_QUERY_KEY` constants (e.g. PROFILE_QUERY_KEY) remain as\n * backwards-compatible base keys. The runtime keys used by hooks include the\n * company prefix via {@link createCompanyQueryKey}.\n */\n\nimport { useCallback, useRef } from \"react\";\nimport { useFluidAuthContext } from \"../providers/FluidAuthProvider\";\n\n/**\n * Create a company-scoped query key by prepending [\"company\", companyId].\n *\n * @param companyId - The company ID from the JWT payload\n * @param baseKey - The base query key segments (e.g. [\"fluid\", \"profile\"])\n * @returns A tuple like [\"company\", 42, \"fluid\", \"profile\"]\n *\n * @example\n * ```ts\n * const key = createCompanyQueryKey(42, \"fluid\", \"profile\");\n * // => [\"company\", 42, \"fluid\", \"profile\"]\n * ```\n */\nexport function createCompanyQueryKey(\n companyId: number,\n ...baseKey: readonly string[]\n): readonly [\"company\", number, ...string[]] {\n return [\"company\", companyId, ...baseKey] as const;\n}\n\n/**\n * Hook that returns a `scopeKey` function bound to the current company ID\n * from the auth context. If the user is not authenticated or has no\n * company_id, the base key is returned unscoped (graceful degradation).\n *\n * @example\n * ```tsx\n * function MyComponent() {\n * const { scopeKey } = useCompanyScopedQueryKey();\n * const queryKey = scopeKey(PROFILE_QUERY_KEY);\n * // => [\"company\", 42, \"fluid\", \"profile\"] (when authenticated)\n * // => [\"fluid\", \"profile\"] (fallback)\n * }\n * ```\n */\nexport function useCompanyScopedQueryKey(): {\n readonly companyId: number | undefined;\n readonly scopeKey: <T extends readonly string[]>(\n baseKey: T,\n ) => readonly (string | number)[];\n} {\n const auth = useFluidAuthContext();\n const companyId = auth.user?.company_id;\n\n // Warn (once per component instance) when an authenticated user has no\n // company_id. This is a security-relevant condition: unscoped keys allow\n // cross-company cache collisions. The warning fires in all environments\n // so that it's visible in production logs if a misconfigured JWT is issued.\n const hasWarnedRef = useRef(false);\n if (auth.isAuthenticated && companyId == null && !hasWarnedRef.current) {\n hasWarnedRef.current = true;\n console.warn(\n \"[portal-sdk] Authenticated user has no company_id in JWT. \" +\n \"Query keys will fall back to unscoped keys, which may cause \" +\n \"cross-company cache collisions. Ensure the JWT includes company_id.\",\n );\n }\n\n const scopeKey = useCallback(\n <T extends readonly string[]>(baseKey: T): readonly (string | number)[] => {\n if (companyId != null) {\n return createCompanyQueryKey(companyId, ...baseKey);\n }\n return baseKey;\n },\n [companyId],\n );\n\n return { companyId, scopeKey } as const;\n}\n","import { useQuery, type UseQueryResult } from \"@tanstack/react-query\";\nimport { useFluidApi } from \"./use-fluid-api\";\nimport { useCompanyScopedQueryKey } from \"./query-keys\";\nimport type { UserMe } from \"../types/rep\";\n\n/**\n * Base query key for current user data.\n * Kept for backwards compatibility — the runtime key used by the hook\n * includes a company prefix via {@link useCompanyScopedQueryKey}.\n */\nexport const CURRENT_USER_QUERY_KEY = [\"fluid\", \"currentUser\"] as const;\n\n/**\n * Hook to fetch the currently authenticated user's full profile.\n * Returns company, country, and other fields from GET /api/me.\n *\n * @example\n * ```tsx\n * function ShopPage() {\n * const { data: user, isLoading } = useCurrentUser();\n * const subdomain = user?.company?.subdomain;\n * const countryIso = user?.country?.iso ?? \"US\";\n * // ...\n * }\n * ```\n */\nexport function useCurrentUser(): UseQueryResult<UserMe> {\n const api = useFluidApi();\n const { scopeKey } = useCompanyScopedQueryKey();\n\n return useQuery({\n queryKey: scopeKey(CURRENT_USER_QUERY_KEY),\n queryFn: () => api.users.me(),\n staleTime: 5 * 60 * 1000,\n });\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AA2BA,SAAgB,sBACd,WACA,GAAG,SACwC;AAC3C,QAAO;EAAC;EAAW;EAAW,GAAG;EAAQ;;;;;;;;;;;;;;;;;AAkB3C,SAAgB,2BAKd;CACA,MAAM,OAAO,qBAAqB;CAClC,MAAM,YAAY,KAAK,MAAM;CAM7B,MAAM,eAAe,OAAO,MAAM;AAClC,KAAI,KAAK,mBAAmB,aAAa,QAAQ,CAAC,aAAa,SAAS;AACtE,eAAa,UAAU;AACvB,UAAQ,KACN,4LAGD;;AAaH,QAAO;EAAE;EAAW,UAVH,aACe,YAA6C;AACzE,OAAI,aAAa,KACf,QAAO,sBAAsB,WAAW,GAAG,QAAQ;AAErD,UAAO;KAET,CAAC,UAAU,CACZ;EAE6B;;;;;;;;;ACxEhC,MAAa,yBAAyB,CAAC,SAAS,cAAc;;;;;;;;;;;;;;;AAgB9D,SAAgB,iBAAyC;CACvD,MAAM,MAAM,aAAa;CACzB,MAAM,EAAE,aAAa,0BAA0B;AAE/C,QAAO,SAAS;EACd,UAAU,SAAS,uBAAuB;EAC1C,eAAe,IAAI,MAAM,IAAI;EAC7B,WAAW,MAAS;EACrB,CAAC"}
1
+ {"version":3,"file":"use-current-user-DnBpWIw6.mjs","names":[],"sources":["../src/hooks/query-keys.ts","../src/hooks/use-current-user.ts"],"sourcesContent":["/**\n * Company-scoped query key factory for TanStack Query.\n *\n * All portal SDK query keys are prefixed with [\"company\", companyId, ...]\n * so that switching companies naturally invalidates the entire cache scope.\n *\n * The exported `*_QUERY_KEY` constants (e.g. PROFILE_QUERY_KEY) remain as\n * backwards-compatible base keys. The runtime keys used by hooks include the\n * company prefix via {@link createCompanyQueryKey}.\n */\n\nimport { useCallback, useRef } from \"react\";\nimport { useFluidAuthContext } from \"../providers/FluidAuthProvider\";\n\n/**\n * Create a company-scoped query key by prepending [\"company\", companyId].\n *\n * @param companyId - The company ID from the JWT payload\n * @param baseKey - The base query key segments (e.g. [\"fluid\", \"profile\"])\n * @returns A tuple like [\"company\", 42, \"fluid\", \"profile\"]\n *\n * @example\n * ```ts\n * const key = createCompanyQueryKey(42, \"fluid\", \"profile\");\n * // => [\"company\", 42, \"fluid\", \"profile\"]\n * ```\n */\nexport function createCompanyQueryKey(\n companyId: number,\n ...baseKey: readonly string[]\n): readonly [\"company\", number, ...string[]] {\n return [\"company\", companyId, ...baseKey] as const;\n}\n\n/**\n * Hook that returns a `scopeKey` function bound to the current company ID\n * from the auth context. If the user is not authenticated or has no\n * company_id, the base key is returned unscoped (graceful degradation).\n *\n * @example\n * ```tsx\n * function MyComponent() {\n * const { scopeKey } = useCompanyScopedQueryKey();\n * const queryKey = scopeKey(PROFILE_QUERY_KEY);\n * // => [\"company\", 42, \"fluid\", \"profile\"] (when authenticated)\n * // => [\"fluid\", \"profile\"] (fallback)\n * }\n * ```\n */\nexport function useCompanyScopedQueryKey(): {\n readonly companyId: number | undefined;\n readonly scopeKey: <T extends readonly string[]>(\n baseKey: T,\n ) => readonly (string | number)[];\n} {\n const auth = useFluidAuthContext();\n const companyId = auth.user?.company_id;\n\n // Warn (once per component instance) when an authenticated user has no\n // company_id. This is a security-relevant condition: unscoped keys allow\n // cross-company cache collisions. The warning fires in all environments\n // so that it's visible in production logs if a misconfigured JWT is issued.\n const hasWarnedRef = useRef(false);\n if (auth.isAuthenticated && companyId == null && !hasWarnedRef.current) {\n hasWarnedRef.current = true;\n console.warn(\n \"[portal-sdk] Authenticated user has no company_id in JWT. \" +\n \"Query keys will fall back to unscoped keys, which may cause \" +\n \"cross-company cache collisions. Ensure the JWT includes company_id.\",\n );\n }\n\n const scopeKey = useCallback(\n <T extends readonly string[]>(baseKey: T): readonly (string | number)[] => {\n if (companyId != null) {\n return createCompanyQueryKey(companyId, ...baseKey);\n }\n return baseKey;\n },\n [companyId],\n );\n\n return { companyId, scopeKey } as const;\n}\n","import { useQuery, type UseQueryResult } from \"@tanstack/react-query\";\nimport { useFluidApi } from \"./use-fluid-api\";\nimport { useCompanyScopedQueryKey } from \"./query-keys\";\nimport type { UserMe } from \"../types/rep\";\n\n/**\n * Base query key for current user data.\n * Kept for backwards compatibility — the runtime key used by the hook\n * includes a company prefix via {@link useCompanyScopedQueryKey}.\n */\nexport const CURRENT_USER_QUERY_KEY = [\"fluid\", \"currentUser\"] as const;\n\n/**\n * Hook to fetch the currently authenticated user's full profile.\n * Returns company, country, and other fields from GET /api/me.\n *\n * @example\n * ```tsx\n * function ShopPage() {\n * const { data: user, isLoading } = useCurrentUser();\n * const subdomain = user?.company?.subdomain;\n * const countryIso = user?.country?.iso ?? \"US\";\n * // ...\n * }\n * ```\n */\nexport function useCurrentUser(): UseQueryResult<UserMe> {\n const api = useFluidApi();\n const { scopeKey } = useCompanyScopedQueryKey();\n\n return useQuery({\n queryKey: scopeKey(CURRENT_USER_QUERY_KEY),\n queryFn: () => api.users.me(),\n staleTime: 5 * 60 * 1000,\n });\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AA2BA,SAAgB,sBACd,WACA,GAAG,SACwC;AAC3C,QAAO;EAAC;EAAW;EAAW,GAAG;EAAQ;;;;;;;;;;;;;;;;;AAkB3C,SAAgB,2BAKd;CACA,MAAM,OAAO,qBAAqB;CAClC,MAAM,YAAY,KAAK,MAAM;CAM7B,MAAM,eAAe,OAAO,MAAM;AAClC,KAAI,KAAK,mBAAmB,aAAa,QAAQ,CAAC,aAAa,SAAS;AACtE,eAAa,UAAU;AACvB,UAAQ,KACN,4LAGD;;AAaH,QAAO;EAAE;EAAW,UAVH,aACe,YAA6C;AACzE,OAAI,aAAa,KACf,QAAO,sBAAsB,WAAW,GAAG,QAAQ;AAErD,UAAO;KAET,CAAC,UAAU,CACZ;EAE6B;;;;;;;;;ACxEhC,MAAa,yBAAyB,CAAC,SAAS,cAAc;;;;;;;;;;;;;;;AAgB9D,SAAgB,iBAAyC;CACvD,MAAM,MAAM,aAAa;CACzB,MAAM,EAAE,aAAa,0BAA0B;AAE/C,QAAO,SAAS;EACd,UAAU,SAAS,uBAAuB;EAC1C,eAAe,IAAI,MAAM,IAAI;EAC7B,WAAW,MAAS;EACrB,CAAC"}
@@ -1,5 +1,5 @@
1
- import { W as fetchCustomerAccount } from "./FluidProvider-9ZC28GXK.mjs";
2
- import { n as useFluidPayClient, o as useFluidAuth } from "./use-account-clients-CqC0etbc.mjs";
1
+ import { W as fetchCustomerAccount } from "./FluidProvider-uuu90TSG.mjs";
2
+ import { n as useFluidPayClient, o as useFluidAuth } from "./use-account-clients-FUcF1B-z.mjs";
3
3
  import { useQuery } from "@tanstack/react-query";
4
4
  //#region src/account/use-customer-account.ts
5
5
  function useCustomerAccount({ enabled = true } = {}) {
@@ -20,4 +20,4 @@ function useCustomerAccount({ enabled = true } = {}) {
20
20
  //#endregion
21
21
  export { useCustomerAccount as t };
22
22
 
23
- //# sourceMappingURL=use-customer-account-DODRyBye.mjs.map
23
+ //# sourceMappingURL=use-customer-account-Dix8Ja5O.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"use-customer-account-DODRyBye.mjs","names":["customersApi.fetchCustomerAccount"],"sources":["../src/account/use-customer-account.ts"],"sourcesContent":["import { useQuery } from \"@tanstack/react-query\";\nimport { customersApi } from \"@fluid-app/fluid-pay-api-client\";\nimport { useFluidAuth } from \"../hooks/use-fluid-auth\";\nimport { useFluidPayClient } from \"./use-account-clients\";\n\nexport function useCustomerAccount({\n enabled = true,\n}: { enabled?: boolean } = {}) {\n const { token, user } = useFluidAuth();\n const fluidPayClient = useFluidPayClient();\n const jwt = token ?? \"\";\n\n const query = useQuery({\n queryKey: [\"fluidPayAccount\", user?.id],\n queryFn: () => customersApi.fetchCustomerAccount(fluidPayClient, jwt),\n enabled: !!jwt && enabled,\n });\n\n return {\n customerId: query.data?.customer?.id,\n isLoadingCustomer: query.isLoading,\n isCustomerError: query.isError,\n };\n}\n"],"mappings":";;;;AAKA,SAAgB,mBAAmB,EACjC,UAAU,SACe,EAAE,EAAE;CAC7B,MAAM,EAAE,OAAO,SAAS,cAAc;CACtC,MAAM,iBAAiB,mBAAmB;CAC1C,MAAM,MAAM,SAAS;CAErB,MAAM,QAAQ,SAAS;EACrB,UAAU,CAAC,mBAAmB,MAAM,GAAG;EACvC,eAAeA,qBAAkC,gBAAgB,IAAI;EACrE,SAAS,CAAC,CAAC,OAAO;EACnB,CAAC;AAEF,QAAO;EACL,YAAY,MAAM,MAAM,UAAU;EAClC,mBAAmB,MAAM;EACzB,iBAAiB,MAAM;EACxB"}
1
+ {"version":3,"file":"use-customer-account-Dix8Ja5O.mjs","names":["customersApi.fetchCustomerAccount"],"sources":["../src/account/use-customer-account.ts"],"sourcesContent":["import { useQuery } from \"@tanstack/react-query\";\nimport { customersApi } from \"@fluid-app/fluid-pay-api-client\";\nimport { useFluidAuth } from \"../hooks/use-fluid-auth\";\nimport { useFluidPayClient } from \"./use-account-clients\";\n\nexport function useCustomerAccount({\n enabled = true,\n}: { enabled?: boolean } = {}) {\n const { token, user } = useFluidAuth();\n const fluidPayClient = useFluidPayClient();\n const jwt = token ?? \"\";\n\n const query = useQuery({\n queryKey: [\"fluidPayAccount\", user?.id],\n queryFn: () => customersApi.fetchCustomerAccount(fluidPayClient, jwt),\n enabled: !!jwt && enabled,\n });\n\n return {\n customerId: query.data?.customer?.id,\n isLoadingCustomer: query.isLoading,\n isCustomerError: query.isError,\n };\n}\n"],"mappings":";;;;AAKA,SAAgB,mBAAmB,EACjC,UAAU,SACe,EAAE,EAAE;CAC7B,MAAM,EAAE,OAAO,SAAS,cAAc;CACtC,MAAM,iBAAiB,mBAAmB;CAC1C,MAAM,MAAM,SAAS;CAErB,MAAM,QAAQ,SAAS;EACrB,UAAU,CAAC,mBAAmB,MAAM,GAAG;EACvC,eAAeA,qBAAkC,gBAAgB,IAAI;EACrE,SAAS,CAAC,CAAC,OAAO;EACnB,CAAC;AAEF,QAAO;EACL,YAAY,MAAM,MAAM,UAAU;EAClC,mBAAmB,MAAM;EACzB,iBAAiB,MAAM;EACxB"}
@@ -1,6 +1,6 @@
1
1
  require("./chunk-DAgNkxik.cjs");
2
- const require_FluidProvider = require("./FluidProvider-9JuTycML.cjs");
3
- const require_use_account_clients = require("./use-account-clients-cHyQEhPp.cjs");
2
+ const require_FluidProvider = require("./FluidProvider-SnHdl4ww.cjs");
3
+ const require_use_account_clients = require("./use-account-clients-Bem920_7.cjs");
4
4
  let _tanstack_react_query = require("@tanstack/react-query");
5
5
  //#region src/account/use-customer-account.ts
6
6
  function useCustomerAccount({ enabled = true } = {}) {
@@ -26,4 +26,4 @@ Object.defineProperty(exports, "useCustomerAccount", {
26
26
  }
27
27
  });
28
28
 
29
- //# sourceMappingURL=use-customer-account-DOmzp1sM.cjs.map
29
+ //# sourceMappingURL=use-customer-account-Rm2QXJiZ.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"use-customer-account-DOmzp1sM.cjs","names":["useFluidAuth","useFluidPayClient"],"sources":["../src/account/use-customer-account.ts"],"sourcesContent":["import { useQuery } from \"@tanstack/react-query\";\nimport { customersApi } from \"@fluid-app/fluid-pay-api-client\";\nimport { useFluidAuth } from \"../hooks/use-fluid-auth\";\nimport { useFluidPayClient } from \"./use-account-clients\";\n\nexport function useCustomerAccount({\n enabled = true,\n}: { enabled?: boolean } = {}) {\n const { token, user } = useFluidAuth();\n const fluidPayClient = useFluidPayClient();\n const jwt = token ?? \"\";\n\n const query = useQuery({\n queryKey: [\"fluidPayAccount\", user?.id],\n queryFn: () => customersApi.fetchCustomerAccount(fluidPayClient, jwt),\n enabled: !!jwt && enabled,\n });\n\n return {\n customerId: query.data?.customer?.id,\n isLoadingCustomer: query.isLoading,\n isCustomerError: query.isError,\n };\n}\n"],"mappings":";;;;;AAKA,SAAgB,mBAAmB,EACjC,UAAU,SACe,EAAE,EAAE;CAC7B,MAAM,EAAE,OAAO,SAASA,4BAAAA,cAAc;CACtC,MAAM,iBAAiBC,4BAAAA,mBAAmB;CAC1C,MAAM,MAAM,SAAS;CAErB,MAAM,SAAA,GAAA,sBAAA,UAAiB;EACrB,UAAU,CAAC,mBAAmB,MAAM,GAAG;EACvC,eAAA,sBAAA,qBAAiD,gBAAgB,IAAI;EACrE,SAAS,CAAC,CAAC,OAAO;EACnB,CAAC;AAEF,QAAO;EACL,YAAY,MAAM,MAAM,UAAU;EAClC,mBAAmB,MAAM;EACzB,iBAAiB,MAAM;EACxB"}
1
+ {"version":3,"file":"use-customer-account-Rm2QXJiZ.cjs","names":["useFluidAuth","useFluidPayClient"],"sources":["../src/account/use-customer-account.ts"],"sourcesContent":["import { useQuery } from \"@tanstack/react-query\";\nimport { customersApi } from \"@fluid-app/fluid-pay-api-client\";\nimport { useFluidAuth } from \"../hooks/use-fluid-auth\";\nimport { useFluidPayClient } from \"./use-account-clients\";\n\nexport function useCustomerAccount({\n enabled = true,\n}: { enabled?: boolean } = {}) {\n const { token, user } = useFluidAuth();\n const fluidPayClient = useFluidPayClient();\n const jwt = token ?? \"\";\n\n const query = useQuery({\n queryKey: [\"fluidPayAccount\", user?.id],\n queryFn: () => customersApi.fetchCustomerAccount(fluidPayClient, jwt),\n enabled: !!jwt && enabled,\n });\n\n return {\n customerId: query.data?.customer?.id,\n isLoadingCustomer: query.isLoading,\n isCustomerError: query.isError,\n };\n}\n"],"mappings":";;;;;AAKA,SAAgB,mBAAmB,EACjC,UAAU,SACe,EAAE,EAAE;CAC7B,MAAM,EAAE,OAAO,SAASA,4BAAAA,cAAc;CACtC,MAAM,iBAAiBC,4BAAAA,mBAAmB;CAC1C,MAAM,MAAM,SAAS;CAErB,MAAM,SAAA,GAAA,sBAAA,UAAiB;EACrB,UAAU,CAAC,mBAAmB,MAAM,GAAG;EACvC,eAAA,sBAAA,qBAAiD,gBAAgB,IAAI;EACrE,SAAS,CAAC,CAAC,OAAO;EACnB,CAAC;AAEF,QAAO;EACL,YAAY,MAAM,MAAM,UAAU;EAClC,mBAAmB,MAAM;EACzB,iBAAiB,MAAM;EACxB"}
@@ -1,4 +1,4 @@
1
- import { n as useFluidContext } from "./FluidProvider-9ZC28GXK.mjs";
1
+ import { n as useFluidContext } from "./FluidProvider-uuu90TSG.mjs";
2
2
  //#region src/hooks/use-fluid-api.ts
3
3
  /**
4
4
  * Hook to access the Fluid API client
@@ -24,4 +24,4 @@ function useFluidApi() {
24
24
  //#endregion
25
25
  export { useFluidApi as t };
26
26
 
27
- //# sourceMappingURL=use-fluid-api-BvakcAkY.mjs.map
27
+ //# sourceMappingURL=use-fluid-api-CedscoxF.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"use-fluid-api-BvakcAkY.mjs","names":[],"sources":["../src/hooks/use-fluid-api.ts"],"sourcesContent":["import { useFluidContext } from \"../providers/FluidProvider\";\nimport type { FluidClient } from \"../client/fluid-client\";\n\n/**\n * Hook to access the Fluid API client\n *\n * @example\n * ```tsx\n * function ProductList() {\n * const api = useFluidApi();\n *\n * const { data: products } = useQuery({\n * queryKey: [\"products\"],\n * queryFn: () => api.products.list(),\n * });\n *\n * return <ul>{products?.map(p => <li key={p.id}>{p.name}</li>)}</ul>;\n * }\n * ```\n */\nexport function useFluidApi(): FluidClient {\n const { client } = useFluidContext();\n return client;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;AAoBA,SAAgB,cAA2B;CACzC,MAAM,EAAE,WAAW,iBAAiB;AACpC,QAAO"}
1
+ {"version":3,"file":"use-fluid-api-CedscoxF.mjs","names":[],"sources":["../src/hooks/use-fluid-api.ts"],"sourcesContent":["import { useFluidContext } from \"../providers/FluidProvider\";\nimport type { FluidClient } from \"../client/fluid-client\";\n\n/**\n * Hook to access the Fluid API client\n *\n * @example\n * ```tsx\n * function ProductList() {\n * const api = useFluidApi();\n *\n * const { data: products } = useQuery({\n * queryKey: [\"products\"],\n * queryFn: () => api.products.list(),\n * });\n *\n * return <ul>{products?.map(p => <li key={p.id}>{p.name}</li>)}</ul>;\n * }\n * ```\n */\nexport function useFluidApi(): FluidClient {\n const { client } = useFluidContext();\n return client;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;AAoBA,SAAgB,cAA2B;CACzC,MAAM,EAAE,WAAW,iBAAiB;AACpC,QAAO"}
@@ -1,4 +1,4 @@
1
- const require_FluidProvider = require("./FluidProvider-9JuTycML.cjs");
1
+ const require_FluidProvider = require("./FluidProvider-SnHdl4ww.cjs");
2
2
  //#region src/hooks/use-fluid-api.ts
3
3
  /**
4
4
  * Hook to access the Fluid API client
@@ -29,4 +29,4 @@ Object.defineProperty(exports, "useFluidApi", {
29
29
  }
30
30
  });
31
31
 
32
- //# sourceMappingURL=use-fluid-api-CBm9h3s3.cjs.map
32
+ //# sourceMappingURL=use-fluid-api-DyI6LDsV.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"use-fluid-api-CBm9h3s3.cjs","names":["useFluidContext"],"sources":["../src/hooks/use-fluid-api.ts"],"sourcesContent":["import { useFluidContext } from \"../providers/FluidProvider\";\nimport type { FluidClient } from \"../client/fluid-client\";\n\n/**\n * Hook to access the Fluid API client\n *\n * @example\n * ```tsx\n * function ProductList() {\n * const api = useFluidApi();\n *\n * const { data: products } = useQuery({\n * queryKey: [\"products\"],\n * queryFn: () => api.products.list(),\n * });\n *\n * return <ul>{products?.map(p => <li key={p.id}>{p.name}</li>)}</ul>;\n * }\n * ```\n */\nexport function useFluidApi(): FluidClient {\n const { client } = useFluidContext();\n return client;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;AAoBA,SAAgB,cAA2B;CACzC,MAAM,EAAE,WAAWA,sBAAAA,iBAAiB;AACpC,QAAO"}
1
+ {"version":3,"file":"use-fluid-api-DyI6LDsV.cjs","names":["useFluidContext"],"sources":["../src/hooks/use-fluid-api.ts"],"sourcesContent":["import { useFluidContext } from \"../providers/FluidProvider\";\nimport type { FluidClient } from \"../client/fluid-client\";\n\n/**\n * Hook to access the Fluid API client\n *\n * @example\n * ```tsx\n * function ProductList() {\n * const api = useFluidApi();\n *\n * const { data: products } = useQuery({\n * queryKey: [\"products\"],\n * queryFn: () => api.products.list(),\n * });\n *\n * return <ul>{products?.map(p => <li key={p.id}>{p.name}</li>)}</ul>;\n * }\n * ```\n */\nexport function useFluidApi(): FluidClient {\n const { client } = useFluidContext();\n return client;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;AAoBA,SAAgB,cAA2B;CACzC,MAAM,EAAE,WAAWA,sBAAAA,iBAAiB;AACpC,QAAO"}