@fluid-app/rep-sdk 0.1.7 → 0.1.9

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 (64) hide show
  1. package/README.md +3 -1
  2. package/dist/ContactsScreen-7RGAMMGN.cjs +18 -0
  3. package/dist/{ContactsScreen-ATASCZO2.cjs.map → ContactsScreen-7RGAMMGN.cjs.map} +1 -1
  4. package/dist/ContactsScreen-XKZE5HTP.js +5 -0
  5. package/dist/{ContactsScreen-33AJ5XUB.js.map → ContactsScreen-XKZE5HTP.js.map} +1 -1
  6. package/dist/CustomersScreen-BBQ3YHI4.js +5 -0
  7. package/dist/{CustomersScreen-E4HXBKV7.js.map → CustomersScreen-BBQ3YHI4.js.map} +1 -1
  8. package/dist/CustomersScreen-EMGCQ2PV.cjs +18 -0
  9. package/dist/{CustomersScreen-XMPMKSQA.cjs.map → CustomersScreen-EMGCQ2PV.cjs.map} +1 -1
  10. package/dist/MessagingScreen-I3GVOGKY.js +4 -0
  11. package/dist/{MessagingScreen-6WDU3XE4.js.map → MessagingScreen-I3GVOGKY.js.map} +1 -1
  12. package/dist/MessagingScreen-ZRD4WEOE.cjs +17 -0
  13. package/dist/{MessagingScreen-XKOBLDWM.cjs.map → MessagingScreen-ZRD4WEOE.cjs.map} +1 -1
  14. package/dist/OrdersScreen-ANDGND6F.js +5 -0
  15. package/dist/{OrdersScreen-IPPZLEYF.js.map → OrdersScreen-ANDGND6F.js.map} +1 -1
  16. package/dist/OrdersScreen-NNE6OSRS.cjs +18 -0
  17. package/dist/{OrdersScreen-X7FYUROL.cjs.map → OrdersScreen-NNE6OSRS.cjs.map} +1 -1
  18. package/dist/ProductsScreen-5PMFLPWS.js +5 -0
  19. package/dist/{ProductsScreen-YTSOZW7B.js.map → ProductsScreen-5PMFLPWS.js.map} +1 -1
  20. package/dist/ProductsScreen-ALQYD7ID.cjs +18 -0
  21. package/dist/{ProductsScreen-4ZIUQNUU.cjs.map → ProductsScreen-ALQYD7ID.cjs.map} +1 -1
  22. package/dist/{chunk-5UBEM3AX.cjs → chunk-2RIDFKS3.cjs} +4 -4
  23. package/dist/{chunk-5UBEM3AX.cjs.map → chunk-2RIDFKS3.cjs.map} +1 -1
  24. package/dist/{chunk-QZMWG7EM.js → chunk-4LTH3NNT.js} +3 -3
  25. package/dist/{chunk-QZMWG7EM.js.map → chunk-4LTH3NNT.js.map} +1 -1
  26. package/dist/chunk-4PHR2M6A.js +14 -0
  27. package/dist/{chunk-RS4OSTES.js.map → chunk-4PHR2M6A.js.map} +1 -1
  28. package/dist/{chunk-MHPK7YQ2.cjs → chunk-EKMZ4NIA.cjs} +4 -4
  29. package/dist/{chunk-MHPK7YQ2.cjs.map → chunk-EKMZ4NIA.cjs.map} +1 -1
  30. package/dist/{chunk-EOXYOOWS.cjs → chunk-HFPPHLOO.cjs} +4 -4
  31. package/dist/{chunk-EOXYOOWS.cjs.map → chunk-HFPPHLOO.cjs.map} +1 -1
  32. package/dist/{chunk-FG2CI6HA.cjs → chunk-HMOWQQDX.cjs} +4 -4
  33. package/dist/{chunk-FG2CI6HA.cjs.map → chunk-HMOWQQDX.cjs.map} +1 -1
  34. package/dist/{chunk-WMBD65GH.js → chunk-JXEED3FK.js} +3 -3
  35. package/dist/{chunk-WMBD65GH.js.map → chunk-JXEED3FK.js.map} +1 -1
  36. package/dist/{chunk-NZSRE4IB.cjs → chunk-LU42Y4H3.cjs} +14 -14
  37. package/dist/{chunk-NZSRE4IB.cjs.map → chunk-LU42Y4H3.cjs.map} +1 -1
  38. package/dist/{chunk-CMF2FYTD.js → chunk-NGOEPTWZ.js} +3 -3
  39. package/dist/{chunk-CMF2FYTD.js.map → chunk-NGOEPTWZ.js.map} +1 -1
  40. package/dist/chunk-NNZKBXNB.cjs +16 -0
  41. package/dist/{chunk-B6S6BEPL.cjs.map → chunk-NNZKBXNB.cjs.map} +1 -1
  42. package/dist/{chunk-VIITMYKW.js → chunk-SYZUEL6B.js} +9 -9
  43. package/dist/{chunk-VIITMYKW.js.map → chunk-SYZUEL6B.js.map} +1 -1
  44. package/dist/{chunk-WFPYEYC7.js → chunk-TB6OK3WH.js} +3 -3
  45. package/dist/{chunk-WFPYEYC7.js.map → chunk-TB6OK3WH.js.map} +1 -1
  46. package/dist/index.cjs +101 -101
  47. package/dist/index.cjs.map +1 -1
  48. package/dist/index.d.cts +3 -3
  49. package/dist/index.d.ts +3 -3
  50. package/dist/index.js +34 -34
  51. package/dist/index.js.map +1 -1
  52. package/package.json +28 -29
  53. package/dist/ContactsScreen-33AJ5XUB.js +0 -5
  54. package/dist/ContactsScreen-ATASCZO2.cjs +0 -18
  55. package/dist/CustomersScreen-E4HXBKV7.js +0 -5
  56. package/dist/CustomersScreen-XMPMKSQA.cjs +0 -18
  57. package/dist/MessagingScreen-6WDU3XE4.js +0 -4
  58. package/dist/MessagingScreen-XKOBLDWM.cjs +0 -17
  59. package/dist/OrdersScreen-IPPZLEYF.js +0 -5
  60. package/dist/OrdersScreen-X7FYUROL.cjs +0 -18
  61. package/dist/ProductsScreen-4ZIUQNUU.cjs +0 -18
  62. package/dist/ProductsScreen-YTSOZW7B.js +0 -5
  63. package/dist/chunk-B6S6BEPL.cjs +0 -16
  64. package/dist/chunk-RS4OSTES.js +0 -14
@@ -1,4 +1,4 @@
1
- import { CoreScreenPlaceholder } from './chunk-RS4OSTES.js';
1
+ import { CoreScreenPlaceholder } from './chunk-4PHR2M6A.js';
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
 
4
4
  function OrdersScreen(_props) {
@@ -12,5 +12,5 @@ var ordersScreenPropertySchema = {
12
12
  };
13
13
 
14
14
  export { OrdersScreen, ordersScreenPropertySchema };
15
- //# sourceMappingURL=chunk-WFPYEYC7.js.map
16
- //# sourceMappingURL=chunk-WFPYEYC7.js.map
15
+ //# sourceMappingURL=chunk-TB6OK3WH.js.map
16
+ //# sourceMappingURL=chunk-TB6OK3WH.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/screens/OrdersScreen.tsx"],"names":[],"mappings":";;;AAmBO,SAAS,aAAa,MAAA,EAA2B;AACtD,EAAA,uBAAO,GAAA,CAAC,qBAAA,EAAA,EAAsB,IAAA,EAAK,QAAA,EAAS,CAAA;AAC9C;AAEO,IAAM,0BAAA,GAAmD;AAAA,EAC9D,UAAA,EAAY,cAAA;AAAA,EACZ,WAAA,EAAa,eAAA;AAAA,EACb,YAAY,CAAC,EAAE,IAAI,SAAA,EAAW,KAAA,EAAO,WAAW,CAAA;AAAA,EAChD,QAAQ;AACV","file":"chunk-WFPYEYC7.js","sourcesContent":["import type { ComponentProps } from \"react\";\nimport type {\n BackgroundValue,\n BorderRadiusOptions,\n ColorOptions,\n PaddingOptions,\n} from \"../types\";\nimport type { WidgetPropertySchema } from \"../registries/property-schema-types\";\nimport { CoreScreenPlaceholder } from \"./CoreScreenPlaceholder\";\n\ntype OrdersScreenProps = ComponentProps<\"div\"> & {\n background?: BackgroundValue;\n textColor?: ColorOptions;\n accentColor?: ColorOptions;\n padding?: PaddingOptions;\n borderRadius?: BorderRadiusOptions;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nexport function OrdersScreen(_props: OrdersScreenProps) {\n return <CoreScreenPlaceholder name=\"Orders\" />;\n}\n\nexport const ordersScreenPropertySchema: WidgetPropertySchema = {\n widgetType: \"OrdersScreen\",\n displayName: \"Orders Screen\",\n tabsConfig: [{ id: \"styling\", label: \"Styling\" }],\n fields: [],\n} as const satisfies WidgetPropertySchema;\n"]}
1
+ {"version":3,"sources":["../src/screens/OrdersScreen.tsx"],"names":[],"mappings":";;;AAmBO,SAAS,aAAa,MAAA,EAA2B;AACtD,EAAA,uBAAO,GAAA,CAAC,qBAAA,EAAA,EAAsB,IAAA,EAAK,QAAA,EAAS,CAAA;AAC9C;AAEO,IAAM,0BAAA,GAAmD;AAAA,EAC9D,UAAA,EAAY,cAAA;AAAA,EACZ,WAAA,EAAa,eAAA;AAAA,EACb,YAAY,CAAC,EAAE,IAAI,SAAA,EAAW,KAAA,EAAO,WAAW,CAAA;AAAA,EAChD,QAAQ;AACV","file":"chunk-TB6OK3WH.js","sourcesContent":["import type { ComponentProps } from \"react\";\nimport type {\n BackgroundValue,\n BorderRadiusOptions,\n ColorOptions,\n PaddingOptions,\n} from \"../types\";\nimport type { WidgetPropertySchema } from \"../registries/property-schema-types\";\nimport { CoreScreenPlaceholder } from \"./CoreScreenPlaceholder\";\n\ntype OrdersScreenProps = ComponentProps<\"div\"> & {\n background?: BackgroundValue;\n textColor?: ColorOptions;\n accentColor?: ColorOptions;\n padding?: PaddingOptions;\n borderRadius?: BorderRadiusOptions;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nexport function OrdersScreen(_props: OrdersScreenProps) {\n return <CoreScreenPlaceholder name=\"Orders\" />;\n}\n\nexport const ordersScreenPropertySchema: WidgetPropertySchema = {\n widgetType: \"OrdersScreen\",\n displayName: \"Orders Screen\",\n tabsConfig: [{ id: \"styling\", label: \"Styling\" }],\n fields: [],\n} as const satisfies WidgetPropertySchema;\n"]}
package/dist/index.cjs CHANGED
@@ -1,11 +1,11 @@
1
1
  'use strict';
2
2
 
3
- var chunkNZSRE4IB_cjs = require('./chunk-NZSRE4IB.cjs');
4
- var chunkEOXYOOWS_cjs = require('./chunk-EOXYOOWS.cjs');
5
- var chunkFG2CI6HA_cjs = require('./chunk-FG2CI6HA.cjs');
6
- var chunkMHPK7YQ2_cjs = require('./chunk-MHPK7YQ2.cjs');
7
- var chunk5UBEM3AX_cjs = require('./chunk-5UBEM3AX.cjs');
8
- var chunkB6S6BEPL_cjs = require('./chunk-B6S6BEPL.cjs');
3
+ var chunkLU42Y4H3_cjs = require('./chunk-LU42Y4H3.cjs');
4
+ var chunkHFPPHLOO_cjs = require('./chunk-HFPPHLOO.cjs');
5
+ var chunkHMOWQQDX_cjs = require('./chunk-HMOWQQDX.cjs');
6
+ var chunkEKMZ4NIA_cjs = require('./chunk-EKMZ4NIA.cjs');
7
+ var chunk2RIDFKS3_cjs = require('./chunk-2RIDFKS3.cjs');
8
+ var chunkNNZKBXNB_cjs = require('./chunk-NNZKBXNB.cjs');
9
9
  require('./chunk-HDQ2JUQT.cjs');
10
10
  var React2 = require('react');
11
11
  var jsxRuntime = require('react/jsx-runtime');
@@ -327,7 +327,7 @@ function useResolvedPages(navigation) {
327
327
  }
328
328
  var PROFILE_QUERY_KEY = ["fluid", "profile"];
329
329
  function useFluidProfile() {
330
- const api = chunkNZSRE4IB_cjs.useFluidApi();
330
+ const api = chunkLU42Y4H3_cjs.useFluidApi();
331
331
  return reactQuery.useQuery({
332
332
  queryKey: PROFILE_QUERY_KEY,
333
333
  queryFn: () => api.profile.get()
@@ -880,18 +880,18 @@ function createPersister() {
880
880
  var APP_DATA_QUERY_KEY = ["fluid", "app"];
881
881
  var appDataPersister = typeof window !== "undefined" ? createPersister() : void 0;
882
882
  function useFluidApp(options) {
883
- const api = chunkNZSRE4IB_cjs.useFluidApi();
883
+ const api = chunkLU42Y4H3_cjs.useFluidApi();
884
884
  return reactQuery.useQuery({
885
885
  queryKey: APP_DATA_QUERY_KEY,
886
886
  queryFn: () => api.app.getRaw(),
887
- select: chunkNZSRE4IB_cjs.transformManifestToRepAppData,
887
+ select: chunkLU42Y4H3_cjs.transformManifestToRepAppData,
888
888
  ...appDataPersister && { persister: appDataPersister.persisterFn },
889
889
  ...options?.enabled !== void 0 && { enabled: options.enabled }
890
890
  });
891
891
  }
892
892
  var PERMISSIONS_QUERY_KEY = ["fluid", "permissions"];
893
893
  function useFluidPermissions() {
894
- const api = chunkNZSRE4IB_cjs.useFluidApi();
894
+ const api = chunkLU42Y4H3_cjs.useFluidApi();
895
895
  const query = reactQuery.useQuery({
896
896
  queryKey: PERMISSIONS_QUERY_KEY,
897
897
  queryFn: () => api.permissions.get()
@@ -923,7 +923,7 @@ function useFluidPermissions() {
923
923
 
924
924
  // src/hooks/use-fluid-theme.ts
925
925
  function useFluidTheme() {
926
- const { currentTheme, setTheme, setThemeMode, mode } = chunkNZSRE4IB_cjs.useThemeContext();
926
+ const { currentTheme, setTheme, setThemeMode, mode } = chunkLU42Y4H3_cjs.useThemeContext();
927
927
  return {
928
928
  currentTheme,
929
929
  setTheme,
@@ -933,7 +933,7 @@ function useFluidTheme() {
933
933
  }
934
934
  var CURRENT_REP_QUERY_KEY = ["fluid", "currentRep"];
935
935
  function useCurrentRep() {
936
- const api = chunkNZSRE4IB_cjs.useFluidApi();
936
+ const api = chunkLU42Y4H3_cjs.useFluidApi();
937
937
  return reactQuery.useQuery({
938
938
  queryKey: CURRENT_REP_QUERY_KEY,
939
939
  queryFn: () => api.reps.current()
@@ -942,7 +942,7 @@ function useCurrentRep() {
942
942
 
943
943
  // src/hooks/use-fluid-auth.ts
944
944
  function useFluidAuth() {
945
- return chunkNZSRE4IB_cjs.useFluidAuthContext();
945
+ return chunkLU42Y4H3_cjs.useFluidAuthContext();
946
946
  }
947
947
 
948
948
  // src/hooks/demo-data/calendar-events.ts
@@ -1674,11 +1674,11 @@ function RequireAuth({
1674
1674
 
1675
1675
  // src/screens/index.ts
1676
1676
  var screenPropertySchemas = {
1677
- MessagingScreen: () => import('./MessagingScreen-XKOBLDWM.cjs').then((m) => m.messagingScreenPropertySchema),
1678
- ContactsScreen: () => import('./ContactsScreen-ATASCZO2.cjs').then((m) => m.contactsScreenPropertySchema),
1679
- OrdersScreen: () => import('./OrdersScreen-X7FYUROL.cjs').then((m) => m.ordersScreenPropertySchema),
1680
- CustomersScreen: () => import('./CustomersScreen-XMPMKSQA.cjs').then((m) => m.customersScreenPropertySchema),
1681
- ProductsScreen: () => import('./ProductsScreen-4ZIUQNUU.cjs').then((m) => m.productsScreenPropertySchema)
1677
+ MessagingScreen: () => import('./MessagingScreen-ZRD4WEOE.cjs').then((m) => m.messagingScreenPropertySchema),
1678
+ ContactsScreen: () => import('./ContactsScreen-7RGAMMGN.cjs').then((m) => m.contactsScreenPropertySchema),
1679
+ OrdersScreen: () => import('./OrdersScreen-NNE6OSRS.cjs').then((m) => m.ordersScreenPropertySchema),
1680
+ CustomersScreen: () => import('./CustomersScreen-EMGCQ2PV.cjs').then((m) => m.customersScreenPropertySchema),
1681
+ ProductsScreen: () => import('./ProductsScreen-ALQYD7ID.cjs').then((m) => m.productsScreenPropertySchema)
1682
1682
  };
1683
1683
  var CORE_PAGE_IDS = {
1684
1684
  MESSAGING: "core-messaging",
@@ -1814,7 +1814,7 @@ function SdkBottomNav({
1814
1814
  setMoreOpen(false);
1815
1815
  };
1816
1816
  return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
1817
- /* @__PURE__ */ jsxRuntime.jsxs("nav", { className: "fixed right-0 bottom-0 left-0 z-40 flex h-16 items-end justify-around border-t border-border bg-sidebar pb-[env(safe-area-inset-bottom)]", children: [
1817
+ /* @__PURE__ */ jsxRuntime.jsxs("nav", { className: "border-border bg-sidebar fixed right-0 bottom-0 left-0 z-40 flex h-16 items-end justify-around border-t pb-[env(safe-area-inset-bottom)]", children: [
1818
1818
  visibleItems.map((item) => {
1819
1819
  const isActive = isInSection(item, currentSlug);
1820
1820
  return /* @__PURE__ */ jsxRuntime.jsxs(
@@ -1853,15 +1853,15 @@ function SdkBottomNav({
1853
1853
  "aria-hidden": "true"
1854
1854
  }
1855
1855
  ),
1856
- /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "rounded-t-2xl bg-sidebar pb-[env(safe-area-inset-bottom)]", children: [
1856
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "bg-sidebar rounded-t-2xl pb-[env(safe-area-inset-bottom)]", children: [
1857
1857
  /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex items-center justify-between px-4 pt-4 pb-2", children: [
1858
- /* @__PURE__ */ jsxRuntime.jsx("span", { className: "text-sm font-semibold text-foreground", children: "More" }),
1858
+ /* @__PURE__ */ jsxRuntime.jsx("span", { className: "text-foreground text-sm font-semibold", children: "More" }),
1859
1859
  /* @__PURE__ */ jsxRuntime.jsx(
1860
1860
  "button",
1861
1861
  {
1862
1862
  type: "button",
1863
1863
  onClick: () => setMoreOpen(false),
1864
- className: "flex items-center justify-center rounded-full p-1 text-muted-foreground hover:bg-sidebar-accent",
1864
+ className: "text-muted-foreground hover:bg-sidebar-accent flex items-center justify-center rounded-full p-1",
1865
1865
  "aria-label": "Close",
1866
1866
  children: /* @__PURE__ */ jsxRuntime.jsx(reactFontawesome.FontAwesomeIcon, { icon: faXmark.faXmark, className: "size-5" })
1867
1867
  }
@@ -2042,7 +2042,7 @@ function QuickLinksDropdown({ onNavigate }) {
2042
2042
  ref: buttonRef,
2043
2043
  type: "button",
2044
2044
  onClick: () => setOpen((prev) => !prev),
2045
- className: "flex shrink-0 items-center justify-center rounded-md p-2 text-sidebar-foreground hover:bg-sidebar-accent hover:text-sidebar-accent-foreground",
2045
+ className: "text-sidebar-foreground hover:bg-sidebar-accent hover:text-sidebar-accent-foreground flex shrink-0 items-center justify-center rounded-md p-2",
2046
2046
  "aria-label": "Quick links",
2047
2047
  "aria-expanded": open,
2048
2048
  children: /* @__PURE__ */ jsxRuntime.jsx(reactFontawesome.FontAwesomeIcon, { icon: faTableCellsLarge.faTableCellsLarge, className: "h-4 w-4" })
@@ -2052,32 +2052,32 @@ function QuickLinksDropdown({ onNavigate }) {
2052
2052
  "div",
2053
2053
  {
2054
2054
  ref: panelRef,
2055
- className: "absolute top-full right-0 z-50 mt-1 w-[700px] max-w-[90vw] overflow-hidden rounded-lg border border-border bg-background shadow-lg",
2055
+ className: "border-border bg-background absolute top-full right-0 z-50 mt-1 w-[700px] max-w-[90vw] overflow-hidden rounded-lg border shadow-lg",
2056
2056
  children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex flex-col", children: [
2057
- /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex items-center gap-2 border-b bg-background p-4", children: [
2057
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "bg-background flex items-center gap-2 border-b p-4", children: [
2058
2058
  /* @__PURE__ */ jsxRuntime.jsx(
2059
2059
  reactFontawesome.FontAwesomeIcon,
2060
2060
  {
2061
2061
  icon: faTableCellsLarge.faTableCellsLarge,
2062
- className: "h-5 w-5 text-muted-foreground"
2062
+ className: "text-muted-foreground h-5 w-5"
2063
2063
  }
2064
2064
  ),
2065
- /* @__PURE__ */ jsxRuntime.jsx("h3", { className: "text-sm font-semibold text-foreground", children: "Shortcuts" })
2065
+ /* @__PURE__ */ jsxRuntime.jsx("h3", { className: "text-foreground text-sm font-semibold", children: "Shortcuts" })
2066
2066
  ] }),
2067
- /* @__PURE__ */ jsxRuntime.jsx("div", { className: "space-y-6 bg-muted p-6", children: Object.entries(sections).map(([sectionName, items]) => /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "space-y-3", children: [
2068
- /* @__PURE__ */ jsxRuntime.jsx("h3", { className: "text-sm font-semibold text-foreground", children: sectionName }),
2067
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: "bg-muted space-y-6 p-6", children: Object.entries(sections).map(([sectionName, items]) => /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "space-y-3", children: [
2068
+ /* @__PURE__ */ jsxRuntime.jsx("h3", { className: "text-foreground text-sm font-semibold", children: sectionName }),
2069
2069
  /* @__PURE__ */ jsxRuntime.jsx("div", { className: "grid grid-cols-4 gap-2", children: items.map((item) => /* @__PURE__ */ jsxRuntime.jsxs(
2070
2070
  "button",
2071
2071
  {
2072
2072
  type: "button",
2073
2073
  onClick: () => handleItemClick(item.slug),
2074
- className: "flex items-center gap-2 rounded-lg px-3 py-2 text-sm text-sidebar-foreground transition-colors hover:bg-sidebar-primary hover:text-sidebar-primary-foreground",
2074
+ className: "text-sidebar-foreground hover:bg-sidebar-primary hover:text-sidebar-primary-foreground flex items-center gap-2 rounded-lg px-3 py-2 text-sm transition-colors",
2075
2075
  children: [
2076
2076
  item.icon && /* @__PURE__ */ jsxRuntime.jsx(
2077
2077
  RepIcon.RepIcon,
2078
2078
  {
2079
2079
  name: item.icon,
2080
- className: "h-4 w-4 shrink-0 text-muted-foreground"
2080
+ className: "text-muted-foreground h-4 w-4 shrink-0"
2081
2081
  }
2082
2082
  ),
2083
2083
  /* @__PURE__ */ jsxRuntime.jsx("span", { className: "truncate", children: item.label })
@@ -2104,13 +2104,13 @@ function SdkHeader({
2104
2104
  const baseSlug = match?.matchedSlug ?? systemNavigationItems.normalizeSlug(currentSlug);
2105
2105
  const themeIcon = themeMode.mode === "dark" ? faMoon.faMoon : faSun.faSun;
2106
2106
  const activeTabs = sidebar$1.isMobile && sidebar$1.useBottomNav && mobileTabs ? mobileTabs : tabs;
2107
- return /* @__PURE__ */ jsxRuntime.jsxs("header", { className: "flex h-[52px] shrink-0 items-center gap-2 bg-sidebar px-6", children: [
2107
+ return /* @__PURE__ */ jsxRuntime.jsxs("header", { className: "bg-sidebar flex h-[52px] shrink-0 items-center gap-2 px-6", children: [
2108
2108
  sidebar$1.isMobile && !sidebar$1.useBottomNav && /* @__PURE__ */ jsxRuntime.jsx(
2109
2109
  "button",
2110
2110
  {
2111
2111
  type: "button",
2112
2112
  onClick: sidebar$1.toggleSidebar,
2113
- className: "mr-2 flex shrink-0 items-center justify-center rounded-md p-2 text-sidebar-foreground hover:bg-sidebar-accent hover:text-sidebar-accent-foreground",
2113
+ className: "text-sidebar-foreground hover:bg-sidebar-accent hover:text-sidebar-accent-foreground mr-2 flex shrink-0 items-center justify-center rounded-md p-2",
2114
2114
  "aria-label": "Toggle sidebar",
2115
2115
  children: /* @__PURE__ */ jsxRuntime.jsx(reactFontawesome.FontAwesomeIcon, { icon: faBars.faBars, className: "size-5" })
2116
2116
  }
@@ -2124,7 +2124,7 @@ function SdkHeader({
2124
2124
  {
2125
2125
  type: "button",
2126
2126
  onClick: () => onNavigate(tabSlug),
2127
- className: `border-b-2 px-4 py-3 text-sm font-medium whitespace-nowrap transition-colors ${isActive ? "border-primary text-foreground" : "border-transparent text-muted-foreground hover:border-border hover:text-foreground"}`,
2127
+ className: `border-b-2 px-4 py-3 text-sm font-medium whitespace-nowrap transition-colors ${isActive ? "border-primary text-foreground" : "text-muted-foreground hover:border-border hover:text-foreground border-transparent"}`,
2128
2128
  children: tab.label
2129
2129
  },
2130
2130
  tab.id ?? tabSlug
@@ -2136,7 +2136,7 @@ function SdkHeader({
2136
2136
  {
2137
2137
  type: "button",
2138
2138
  onClick: themeMode.cycleMode,
2139
- className: "ml-2 flex shrink-0 items-center justify-center rounded-md p-2 text-sidebar-foreground hover:bg-sidebar-accent hover:text-sidebar-accent-foreground",
2139
+ className: "text-sidebar-foreground hover:bg-sidebar-accent hover:text-sidebar-accent-foreground ml-2 flex shrink-0 items-center justify-center rounded-md p-2",
2140
2140
  "aria-label": `Switch theme (current: ${themeMode.mode})`,
2141
2141
  children: /* @__PURE__ */ jsxRuntime.jsx(reactFontawesome.FontAwesomeIcon, { icon: themeIcon, className: "size-3" })
2142
2142
  }
@@ -2160,7 +2160,7 @@ function WidgetRenderer({ widget, index }) {
2160
2160
  function BuilderScreenViewImpl({ screen, className }) {
2161
2161
  const widgets = screen.component_tree;
2162
2162
  if (!widgets || widgets.length === 0) {
2163
- return /* @__PURE__ */ jsxRuntime.jsx("div", { className: className ?? "h-full w-full", children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: "flex h-full items-center justify-center text-muted-foreground", children: /* @__PURE__ */ jsxRuntime.jsx("p", { children: "This screen has no content yet." }) }) });
2163
+ return /* @__PURE__ */ jsxRuntime.jsx("div", { className: className ?? "h-full w-full", children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: "text-muted-foreground flex h-full items-center justify-center", children: /* @__PURE__ */ jsxRuntime.jsx("p", { children: "This screen has no content yet." }) }) });
2164
2164
  }
2165
2165
  return /* @__PURE__ */ jsxRuntime.jsx("div", { className: className ?? "h-full w-full", children: widgets.map((widget, index) => {
2166
2166
  if (!widget) return null;
@@ -2176,11 +2176,11 @@ function BuilderScreenViewImpl({ screen, className }) {
2176
2176
  }
2177
2177
  var BuilderScreenView = React2.memo(BuilderScreenViewImpl);
2178
2178
  var SYSTEM_SLUG_SCREEN_MAP = {
2179
- messages: chunkNZSRE4IB_cjs.MessagingScreen,
2180
- contacts: chunkEOXYOOWS_cjs.ContactsScreen,
2181
- shop: chunkFG2CI6HA_cjs.OrdersScreen,
2182
- customers: chunkMHPK7YQ2_cjs.CustomersScreen,
2183
- products: chunk5UBEM3AX_cjs.ProductsScreen
2179
+ messages: chunkLU42Y4H3_cjs.MessagingScreen,
2180
+ contacts: chunkHFPPHLOO_cjs.ContactsScreen,
2181
+ shop: chunkHMOWQQDX_cjs.OrdersScreen,
2182
+ customers: chunkEKMZ4NIA_cjs.CustomersScreen,
2183
+ products: chunk2RIDFKS3_cjs.ProductsScreen
2184
2184
  };
2185
2185
  function PageRouter({
2186
2186
  currentSlug,
@@ -2219,7 +2219,7 @@ function PageRouter({
2219
2219
  return /* @__PURE__ */ jsxRuntime.jsx(SystemScreen, {});
2220
2220
  }
2221
2221
  if (systemNavigationItems.isSystemNavigationItem(baseSlug)) {
2222
- return /* @__PURE__ */ jsxRuntime.jsx(chunkB6S6BEPL_cjs.CoreScreenPlaceholder, { name: currentNavItem?.label ?? baseSlug });
2222
+ return /* @__PURE__ */ jsxRuntime.jsx(chunkNNZKBXNB_cjs.CoreScreenPlaceholder, { name: currentNavItem?.label ?? baseSlug });
2223
2223
  }
2224
2224
  const ExactCustomPage = customPages?.[currentSlug];
2225
2225
  if (ExactCustomPage) {
@@ -2234,7 +2234,7 @@ function PageRouter({
2234
2234
  if (builderScreen) {
2235
2235
  return /* @__PURE__ */ jsxRuntime.jsx(BuilderScreenView, { screen: builderScreen });
2236
2236
  }
2237
- return /* @__PURE__ */ jsxRuntime.jsx(chunkB6S6BEPL_cjs.CoreScreenPlaceholder, { name: currentNavItem?.label ?? currentSlug });
2237
+ return /* @__PURE__ */ jsxRuntime.jsx(chunkNNZKBXNB_cjs.CoreScreenPlaceholder, { name: currentNavItem?.label ?? currentSlug });
2238
2238
  }
2239
2239
  var AppNavigationContext = React2.createContext(
2240
2240
  null
@@ -2520,163 +2520,163 @@ var AppLink = React2.forwardRef(
2520
2520
  return /* @__PURE__ */ jsxRuntime.jsx("a", { ref, href: buildHref(to), onClick: handleClick, ...rest, children });
2521
2521
  }
2522
2522
  );
2523
- var export_DEFAULT_COLORS = chunkNZSRE4IB_cjs.themes_exports.DEFAULT_COLORS;
2524
- var export_DEFAULT_FONT_FAMILIES = chunkNZSRE4IB_cjs.themes_exports.DEFAULT_FONT_FAMILIES;
2525
- var export_DEFAULT_FONT_SIZES = chunkNZSRE4IB_cjs.themes_exports.DEFAULT_FONT_SIZES;
2526
- var export_DEFAULT_RADII = chunkNZSRE4IB_cjs.themes_exports.DEFAULT_RADII;
2527
- var export_DEFAULT_SPACING = chunkNZSRE4IB_cjs.themes_exports.DEFAULT_SPACING;
2528
- var export_DEFAULT_THEME_ID = chunkNZSRE4IB_cjs.themes_exports.DEFAULT_THEME_ID;
2529
- var export_DEFAULT_THEME_NAME = chunkNZSRE4IB_cjs.themes_exports.DEFAULT_THEME_NAME;
2530
- var export_FONT_FAMILY_KEYS = chunkNZSRE4IB_cjs.themes_exports.FONT_FAMILY_KEYS;
2531
- var export_FONT_SIZE_KEYS = chunkNZSRE4IB_cjs.themes_exports.FONT_SIZE_KEYS;
2532
- var export_RADIUS_KEYS = chunkNZSRE4IB_cjs.themes_exports.RADIUS_KEYS;
2533
- var export_SEMANTIC_COLOR_NAMES = chunkNZSRE4IB_cjs.themes_exports.SEMANTIC_COLOR_NAMES;
2534
- var export_SHADE_STEPS = chunkNZSRE4IB_cjs.themes_exports.SHADE_STEPS;
2535
- var export_applyTheme = chunkNZSRE4IB_cjs.themes_exports.applyTheme;
2536
- var export_deriveDarkVariant = chunkNZSRE4IB_cjs.themes_exports.deriveDarkVariant;
2537
- var export_deserialiseTheme = chunkNZSRE4IB_cjs.themes_exports.deserialiseTheme;
2538
- var export_generateShades = chunkNZSRE4IB_cjs.themes_exports.generateShades;
2539
- var export_generateThemeCSS = chunkNZSRE4IB_cjs.themes_exports.generateThemeCSS;
2540
- var export_getDefaultThemeDefinition = chunkNZSRE4IB_cjs.themes_exports.getDefaultThemeDefinition;
2541
- var export_getForegroundColor = chunkNZSRE4IB_cjs.themes_exports.getForegroundColor;
2542
- var export_mergeDarkOverrides = chunkNZSRE4IB_cjs.themes_exports.mergeDarkOverrides;
2543
- var export_parseColor = chunkNZSRE4IB_cjs.themes_exports.parseColor;
2544
- var export_removeAllThemes = chunkNZSRE4IB_cjs.themes_exports.removeAllThemes;
2545
- var export_removeTheme = chunkNZSRE4IB_cjs.themes_exports.removeTheme;
2546
- var export_resolveTheme = chunkNZSRE4IB_cjs.themes_exports.resolveTheme;
2547
- var export_serialiseTheme = chunkNZSRE4IB_cjs.themes_exports.serialiseTheme;
2523
+ var export_DEFAULT_COLORS = chunkLU42Y4H3_cjs.themes_exports.DEFAULT_COLORS;
2524
+ var export_DEFAULT_FONT_FAMILIES = chunkLU42Y4H3_cjs.themes_exports.DEFAULT_FONT_FAMILIES;
2525
+ var export_DEFAULT_FONT_SIZES = chunkLU42Y4H3_cjs.themes_exports.DEFAULT_FONT_SIZES;
2526
+ var export_DEFAULT_RADII = chunkLU42Y4H3_cjs.themes_exports.DEFAULT_RADII;
2527
+ var export_DEFAULT_SPACING = chunkLU42Y4H3_cjs.themes_exports.DEFAULT_SPACING;
2528
+ var export_DEFAULT_THEME_ID = chunkLU42Y4H3_cjs.themes_exports.DEFAULT_THEME_ID;
2529
+ var export_DEFAULT_THEME_NAME = chunkLU42Y4H3_cjs.themes_exports.DEFAULT_THEME_NAME;
2530
+ var export_FONT_FAMILY_KEYS = chunkLU42Y4H3_cjs.themes_exports.FONT_FAMILY_KEYS;
2531
+ var export_FONT_SIZE_KEYS = chunkLU42Y4H3_cjs.themes_exports.FONT_SIZE_KEYS;
2532
+ var export_RADIUS_KEYS = chunkLU42Y4H3_cjs.themes_exports.RADIUS_KEYS;
2533
+ var export_SEMANTIC_COLOR_NAMES = chunkLU42Y4H3_cjs.themes_exports.SEMANTIC_COLOR_NAMES;
2534
+ var export_SHADE_STEPS = chunkLU42Y4H3_cjs.themes_exports.SHADE_STEPS;
2535
+ var export_applyTheme = chunkLU42Y4H3_cjs.themes_exports.applyTheme;
2536
+ var export_deriveDarkVariant = chunkLU42Y4H3_cjs.themes_exports.deriveDarkVariant;
2537
+ var export_deserialiseTheme = chunkLU42Y4H3_cjs.themes_exports.deserialiseTheme;
2538
+ var export_generateShades = chunkLU42Y4H3_cjs.themes_exports.generateShades;
2539
+ var export_generateThemeCSS = chunkLU42Y4H3_cjs.themes_exports.generateThemeCSS;
2540
+ var export_getDefaultThemeDefinition = chunkLU42Y4H3_cjs.themes_exports.getDefaultThemeDefinition;
2541
+ var export_getForegroundColor = chunkLU42Y4H3_cjs.themes_exports.getForegroundColor;
2542
+ var export_mergeDarkOverrides = chunkLU42Y4H3_cjs.themes_exports.mergeDarkOverrides;
2543
+ var export_parseColor = chunkLU42Y4H3_cjs.themes_exports.parseColor;
2544
+ var export_removeAllThemes = chunkLU42Y4H3_cjs.themes_exports.removeAllThemes;
2545
+ var export_removeTheme = chunkLU42Y4H3_cjs.themes_exports.removeTheme;
2546
+ var export_resolveTheme = chunkLU42Y4H3_cjs.themes_exports.resolveTheme;
2547
+ var export_serialiseTheme = chunkLU42Y4H3_cjs.themes_exports.serialiseTheme;
2548
2548
 
2549
2549
  Object.defineProperty(exports, "ApiError", {
2550
2550
  enumerable: true,
2551
- get: function () { return chunkNZSRE4IB_cjs.ApiError; }
2551
+ get: function () { return chunkLU42Y4H3_cjs.ApiError; }
2552
2552
  });
2553
2553
  Object.defineProperty(exports, "DEFAULT_AUTH_URL", {
2554
2554
  enumerable: true,
2555
- get: function () { return chunkNZSRE4IB_cjs.DEFAULT_AUTH_URL; }
2555
+ get: function () { return chunkLU42Y4H3_cjs.DEFAULT_AUTH_URL; }
2556
2556
  });
2557
2557
  Object.defineProperty(exports, "DEFAULT_SDK_WIDGET_REGISTRY", {
2558
2558
  enumerable: true,
2559
- get: function () { return chunkNZSRE4IB_cjs.DEFAULT_SDK_WIDGET_REGISTRY; }
2559
+ get: function () { return chunkLU42Y4H3_cjs.DEFAULT_SDK_WIDGET_REGISTRY; }
2560
2560
  });
2561
2561
  Object.defineProperty(exports, "FluidAuthProvider", {
2562
2562
  enumerable: true,
2563
- get: function () { return chunkNZSRE4IB_cjs.FluidAuthProvider; }
2563
+ get: function () { return chunkLU42Y4H3_cjs.FluidAuthProvider; }
2564
2564
  });
2565
2565
  Object.defineProperty(exports, "FluidProvider", {
2566
2566
  enumerable: true,
2567
- get: function () { return chunkNZSRE4IB_cjs.FluidProvider; }
2567
+ get: function () { return chunkLU42Y4H3_cjs.FluidProvider; }
2568
2568
  });
2569
2569
  Object.defineProperty(exports, "FluidThemeProvider", {
2570
2570
  enumerable: true,
2571
- get: function () { return chunkNZSRE4IB_cjs.FluidThemeProvider; }
2571
+ get: function () { return chunkLU42Y4H3_cjs.FluidThemeProvider; }
2572
2572
  });
2573
2573
  Object.defineProperty(exports, "MessagingScreen", {
2574
2574
  enumerable: true,
2575
- get: function () { return chunkNZSRE4IB_cjs.MessagingScreen; }
2575
+ get: function () { return chunkLU42Y4H3_cjs.MessagingScreen; }
2576
2576
  });
2577
2577
  Object.defineProperty(exports, "buildThemeDefinition", {
2578
2578
  enumerable: true,
2579
- get: function () { return chunkNZSRE4IB_cjs.buildThemeDefinition; }
2579
+ get: function () { return chunkLU42Y4H3_cjs.buildThemeDefinition; }
2580
2580
  });
2581
2581
  Object.defineProperty(exports, "createDefaultAuthRedirect", {
2582
2582
  enumerable: true,
2583
- get: function () { return chunkNZSRE4IB_cjs.createDefaultAuthRedirect; }
2583
+ get: function () { return chunkLU42Y4H3_cjs.createDefaultAuthRedirect; }
2584
2584
  });
2585
2585
  Object.defineProperty(exports, "createFluidClient", {
2586
2586
  enumerable: true,
2587
- get: function () { return chunkNZSRE4IB_cjs.createFluidClient; }
2587
+ get: function () { return chunkLU42Y4H3_cjs.createFluidClient; }
2588
2588
  });
2589
2589
  Object.defineProperty(exports, "createFluidFileUploader", {
2590
2590
  enumerable: true,
2591
- get: function () { return chunkNZSRE4IB_cjs.createFluidFileUploader; }
2591
+ get: function () { return chunkLU42Y4H3_cjs.createFluidFileUploader; }
2592
2592
  });
2593
2593
  Object.defineProperty(exports, "getActiveThemeId", {
2594
2594
  enumerable: true,
2595
- get: function () { return chunkNZSRE4IB_cjs.getActiveThemeId; }
2595
+ get: function () { return chunkLU42Y4H3_cjs.getActiveThemeId; }
2596
2596
  });
2597
2597
  Object.defineProperty(exports, "isApiError", {
2598
2598
  enumerable: true,
2599
- get: function () { return chunkNZSRE4IB_cjs.isApiError; }
2599
+ get: function () { return chunkLU42Y4H3_cjs.isApiError; }
2600
2600
  });
2601
2601
  Object.defineProperty(exports, "messagingScreenPropertySchema", {
2602
2602
  enumerable: true,
2603
- get: function () { return chunkNZSRE4IB_cjs.messagingScreenPropertySchema; }
2603
+ get: function () { return chunkLU42Y4H3_cjs.messagingScreenPropertySchema; }
2604
2604
  });
2605
2605
  Object.defineProperty(exports, "normalizeComponentTree", {
2606
2606
  enumerable: true,
2607
- get: function () { return chunkNZSRE4IB_cjs.normalizeComponentTree; }
2607
+ get: function () { return chunkLU42Y4H3_cjs.normalizeComponentTree; }
2608
2608
  });
2609
2609
  Object.defineProperty(exports, "toNavigationItem", {
2610
2610
  enumerable: true,
2611
- get: function () { return chunkNZSRE4IB_cjs.toNavigationItem; }
2611
+ get: function () { return chunkLU42Y4H3_cjs.toNavigationItem; }
2612
2612
  });
2613
2613
  Object.defineProperty(exports, "toScreenDefinition", {
2614
2614
  enumerable: true,
2615
- get: function () { return chunkNZSRE4IB_cjs.toScreenDefinition; }
2615
+ get: function () { return chunkLU42Y4H3_cjs.toScreenDefinition; }
2616
2616
  });
2617
2617
  Object.defineProperty(exports, "transformManifestToRepAppData", {
2618
2618
  enumerable: true,
2619
- get: function () { return chunkNZSRE4IB_cjs.transformManifestToRepAppData; }
2619
+ get: function () { return chunkLU42Y4H3_cjs.transformManifestToRepAppData; }
2620
2620
  });
2621
2621
  Object.defineProperty(exports, "transformThemes", {
2622
2622
  enumerable: true,
2623
- get: function () { return chunkNZSRE4IB_cjs.transformThemes; }
2623
+ get: function () { return chunkLU42Y4H3_cjs.transformThemes; }
2624
2624
  });
2625
2625
  Object.defineProperty(exports, "useFluidApi", {
2626
2626
  enumerable: true,
2627
- get: function () { return chunkNZSRE4IB_cjs.useFluidApi; }
2627
+ get: function () { return chunkLU42Y4H3_cjs.useFluidApi; }
2628
2628
  });
2629
2629
  Object.defineProperty(exports, "useFluidAuthContext", {
2630
2630
  enumerable: true,
2631
- get: function () { return chunkNZSRE4IB_cjs.useFluidAuthContext; }
2631
+ get: function () { return chunkLU42Y4H3_cjs.useFluidAuthContext; }
2632
2632
  });
2633
2633
  Object.defineProperty(exports, "useFluidContext", {
2634
2634
  enumerable: true,
2635
- get: function () { return chunkNZSRE4IB_cjs.useFluidContext; }
2635
+ get: function () { return chunkLU42Y4H3_cjs.useFluidContext; }
2636
2636
  });
2637
2637
  Object.defineProperty(exports, "useMessagingAuth", {
2638
2638
  enumerable: true,
2639
- get: function () { return chunkNZSRE4IB_cjs.useMessagingAuth; }
2639
+ get: function () { return chunkLU42Y4H3_cjs.useMessagingAuth; }
2640
2640
  });
2641
2641
  Object.defineProperty(exports, "useMessagingConfig", {
2642
2642
  enumerable: true,
2643
- get: function () { return chunkNZSRE4IB_cjs.useMessagingConfig; }
2643
+ get: function () { return chunkLU42Y4H3_cjs.useMessagingConfig; }
2644
2644
  });
2645
2645
  Object.defineProperty(exports, "useThemeContext", {
2646
2646
  enumerable: true,
2647
- get: function () { return chunkNZSRE4IB_cjs.useThemeContext; }
2647
+ get: function () { return chunkLU42Y4H3_cjs.useThemeContext; }
2648
2648
  });
2649
2649
  Object.defineProperty(exports, "ContactsScreen", {
2650
2650
  enumerable: true,
2651
- get: function () { return chunkEOXYOOWS_cjs.ContactsScreen; }
2651
+ get: function () { return chunkHFPPHLOO_cjs.ContactsScreen; }
2652
2652
  });
2653
2653
  Object.defineProperty(exports, "contactsScreenPropertySchema", {
2654
2654
  enumerable: true,
2655
- get: function () { return chunkEOXYOOWS_cjs.contactsScreenPropertySchema; }
2655
+ get: function () { return chunkHFPPHLOO_cjs.contactsScreenPropertySchema; }
2656
2656
  });
2657
2657
  Object.defineProperty(exports, "OrdersScreen", {
2658
2658
  enumerable: true,
2659
- get: function () { return chunkFG2CI6HA_cjs.OrdersScreen; }
2659
+ get: function () { return chunkHMOWQQDX_cjs.OrdersScreen; }
2660
2660
  });
2661
2661
  Object.defineProperty(exports, "ordersScreenPropertySchema", {
2662
2662
  enumerable: true,
2663
- get: function () { return chunkFG2CI6HA_cjs.ordersScreenPropertySchema; }
2663
+ get: function () { return chunkHMOWQQDX_cjs.ordersScreenPropertySchema; }
2664
2664
  });
2665
2665
  Object.defineProperty(exports, "CustomersScreen", {
2666
2666
  enumerable: true,
2667
- get: function () { return chunkMHPK7YQ2_cjs.CustomersScreen; }
2667
+ get: function () { return chunkEKMZ4NIA_cjs.CustomersScreen; }
2668
2668
  });
2669
2669
  Object.defineProperty(exports, "customersScreenPropertySchema", {
2670
2670
  enumerable: true,
2671
- get: function () { return chunkMHPK7YQ2_cjs.customersScreenPropertySchema; }
2671
+ get: function () { return chunkEKMZ4NIA_cjs.customersScreenPropertySchema; }
2672
2672
  });
2673
2673
  Object.defineProperty(exports, "ProductsScreen", {
2674
2674
  enumerable: true,
2675
- get: function () { return chunk5UBEM3AX_cjs.ProductsScreen; }
2675
+ get: function () { return chunk2RIDFKS3_cjs.ProductsScreen; }
2676
2676
  });
2677
2677
  Object.defineProperty(exports, "productsScreenPropertySchema", {
2678
2678
  enumerable: true,
2679
- get: function () { return chunk5UBEM3AX_cjs.productsScreenPropertySchema; }
2679
+ get: function () { return chunk2RIDFKS3_cjs.productsScreenPropertySchema; }
2680
2680
  });
2681
2681
  Object.defineProperty(exports, "AUTH_CONSTANTS", {
2682
2682
  enumerable: true,