@superbright/indexeddb-orm 1.0.2 → 1.0.4
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.
- package/README.md +5 -5
- package/dist/adapters/structured-store.cjs +1 -1
- package/dist/adapters/structured-store.cjs.map +1 -1
- package/dist/adapters/structured-store.d.ts +1 -1
- package/dist/adapters/structured-store.mjs +1 -1
- package/dist/adapters/structured-store.mjs.map +1 -1
- package/dist/adapters/zustand-store.cjs +1 -1
- package/dist/adapters/zustand-store.cjs.map +1 -1
- package/dist/adapters/zustand-store.mjs +12 -11
- package/dist/adapters/zustand-store.mjs.map +1 -1
- package/dist/base/property.d.ts +2 -2
- package/dist/base/unit.d.ts +12 -12
- package/dist/base/user.d.ts +4 -4
- package/dist/features/analytics/MixpanelProvider.cjs +1 -1
- package/dist/features/analytics/MixpanelProvider.cjs.map +1 -1
- package/dist/features/analytics/MixpanelProvider.mjs +22 -20
- package/dist/features/analytics/MixpanelProvider.mjs.map +1 -1
- package/dist/features/filters/transformers.cjs +2 -0
- package/dist/features/filters/transformers.cjs.map +1 -0
- package/dist/features/filters/transformers.d.ts +31 -0
- package/dist/features/filters/transformers.mjs +110 -0
- package/dist/features/filters/transformers.mjs.map +1 -0
- package/dist/features/units/transformers.cjs +1 -1
- package/dist/features/units/transformers.cjs.map +1 -1
- package/dist/features/units/transformers.d.ts +12 -10
- package/dist/features/units/transformers.mjs +42 -38
- package/dist/features/units/transformers.mjs.map +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.mjs +80 -76
- package/dist/index.mjs.map +1 -1
- package/dist/schema.cjs +1 -1
- package/dist/schema.cjs.map +1 -1
- package/dist/schema.d.ts +754 -715
- package/dist/schema.mjs +104 -101
- package/dist/schema.mjs.map +1 -1
- package/dist/stores/store.cjs +1 -1
- package/dist/stores/store.cjs.map +1 -1
- package/dist/stores/store.mjs +229 -240
- package/dist/stores/store.mjs.map +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -81,7 +81,7 @@ function MyComponent() {
|
|
|
81
81
|
|
|
82
82
|
// Filter actions
|
|
83
83
|
const updateFilters = async () => {
|
|
84
|
-
await store.filters.set({
|
|
84
|
+
await store.filters.set({ qty_bedrooms: [1, 2] });
|
|
85
85
|
await store.filters.submit();
|
|
86
86
|
};
|
|
87
87
|
|
|
@@ -153,7 +153,7 @@ store.filters.set(filters: Partial<Filters>)
|
|
|
153
153
|
store.filters.setTemp(filters: Partial<Filters>)
|
|
154
154
|
store.filters.setToDefault()
|
|
155
155
|
store.filters.commitTemp(key, defaultValue)
|
|
156
|
-
store.filters.
|
|
156
|
+
store.filters.commitDateAvailability()
|
|
157
157
|
store.filters.submit()
|
|
158
158
|
```
|
|
159
159
|
|
|
@@ -189,8 +189,8 @@ await store.setUnitResults(transformedUnits.hits);
|
|
|
189
189
|
await store.clearUnitResults();
|
|
190
190
|
|
|
191
191
|
// Filters
|
|
192
|
-
await store.setFilters({
|
|
193
|
-
await store.setTempFilters({
|
|
192
|
+
await store.setFilters({ qty_bedrooms: [1, 2] });
|
|
193
|
+
await store.setTempFilters({ base_price: 2500 });
|
|
194
194
|
await store.submitFilterUpdate();
|
|
195
195
|
```
|
|
196
196
|
|
|
@@ -244,7 +244,7 @@ pnpm dev
|
|
|
244
244
|
1. **Start with Database Operations**: Click "Initialize Database" to set up the ORM
|
|
245
245
|
2. **Create a Property**: Enter a property ID and slug, then click "Initialize Property"
|
|
246
246
|
3. **Test Unit Actions**: Enter a unit ID and try toggling favorites or marking as viewed
|
|
247
|
-
4. **Experiment with Filters**: Set bedroom counts and
|
|
247
|
+
4. **Experiment with Filters**: Set bedroom counts and base price filters, then submit them
|
|
248
248
|
5. **View State Changes**: Watch the real-time state updates and action logs
|
|
249
249
|
6. **Inspect Database**: Open browser DevTools to see the actual IndexedDB storage
|
|
250
250
|
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("./zustand-store.cjs");function u(t,i){return{property:{unit:{favorites:{toggle:t.toggleFavorite.bind(t)},viewed:{mark:t.markUnitAsViewed.bind(t)}},questionnaire:{setResults:t.setQuestionnaireResults.bind(t)},tour:{setContactedOn:t.setTourContactedOn.bind(t),getContactedOn:t.getTourContactedOn.bind(t),setContactData:t.setTourContactData.bind(t)}},filters:{set:t.setFilters.bind(t),setTemp:t.setTempFilters.bind(t),setToDefault:t.setFiltersToDefault.bind(t),commitTemp:async(e,n)=>{const c=(i?i():t).tempFilters[e]??n;await t.handleTempFilterChange(e,c),await t.submitFilterUpdate()},
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("./zustand-store.cjs");function u(t,i){return{property:{unit:{favorites:{toggle:t.toggleFavorite.bind(t)},viewed:{mark:t.markUnitAsViewed.bind(t)}},questionnaire:{setResults:t.setQuestionnaireResults.bind(t)},tour:{setContactedOn:t.setTourContactedOn.bind(t),getContactedOn:t.getTourContactedOn.bind(t),setContactData:t.setTourContactData.bind(t)}},filters:{set:t.setFilters.bind(t),setTemp:t.setTempFilters.bind(t),setToDefault:t.setFiltersToDefault.bind(t),commitTemp:async(e,n)=>{const c=(i?i():t).tempFilters[e]??n;await t.handleTempFilterChange(e,c),await t.submitFilterUpdate()},commitDateAvailability:async()=>{await t.submitFilterUpdate()},submit:t.submitFilterUpdate.bind(t)}}}function d(t){return(i,e)=>{const n=r.createZustandUnifiedStore(t)(i,e),a=u(n,e);return{...n,...a}}}exports.createStructuredStore=d;exports.createStructuredStoreActions=u;
|
|
2
2
|
//# sourceMappingURL=structured-store.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"structured-store.cjs","sources":["../../src/adapters/structured-store.ts"],"sourcesContent":["/**\n * Structured store wrapper (preferred DX)\n *\n * This layer wraps the flat Zustand adapter with domain‑grouped actions\n * for a more discoverable API in apps. It does not add new behavior —\n * it simply organizes calls like:\n * - `property.unit.favorites.toggle` → `toggleFavorite`\n * - `property.unit.viewed.mark` → `markUnitAsViewed`\n * - `filters.set/submit/...` → filter methods\n */\nimport {\n type ZustandUnifiedStoreState,\n createZustandUnifiedStore,\n type Filters,\n type UnitData,\n type TourContactData,\n type QueryParams\n} from \"./zustand-store\";\n\nexport interface StructuredStoreActions {\n property: {\n unit: {\n favorites: {\n toggle: (unitId: string) => Promise<void>;\n };\n viewed: {\n mark: (unitId: string, slug: string) => Promise<void>;\n };\n };\n questionnaire: {\n setResults: (results: unknown) => Promise<void>;\n };\n tour: {\n setContactedOn: () => Promise<void>;\n getContactedOn: () => Promise<string | null>;\n setContactData: (data: TourContactData) => Promise<void>;\n };\n };\n\n filters: {\n set: (filters: Partial<Filters>) => Promise<void>;\n setTemp: (filters: Partial<Filters>) => Promise<void>;\n setToDefault: () => Promise<void>;\n commitTemp: <K extends keyof Filters>(key: K, defaultValue: Filters[K]) => Promise<void>;\n
|
|
1
|
+
{"version":3,"file":"structured-store.cjs","sources":["../../src/adapters/structured-store.ts"],"sourcesContent":["/**\n * Structured store wrapper (preferred DX)\n *\n * This layer wraps the flat Zustand adapter with domain‑grouped actions\n * for a more discoverable API in apps. It does not add new behavior —\n * it simply organizes calls like:\n * - `property.unit.favorites.toggle` → `toggleFavorite`\n * - `property.unit.viewed.mark` → `markUnitAsViewed`\n * - `filters.set/submit/...` → filter methods\n */\nimport {\n type ZustandUnifiedStoreState,\n createZustandUnifiedStore,\n type Filters,\n type UnitData,\n type TourContactData,\n type QueryParams\n} from \"./zustand-store\";\n\nexport interface StructuredStoreActions {\n property: {\n unit: {\n favorites: {\n toggle: (unitId: string) => Promise<void>;\n };\n viewed: {\n mark: (unitId: string, slug: string) => Promise<void>;\n };\n };\n questionnaire: {\n setResults: (results: unknown) => Promise<void>;\n };\n tour: {\n setContactedOn: () => Promise<void>;\n getContactedOn: () => Promise<string | null>;\n setContactData: (data: TourContactData) => Promise<void>;\n };\n };\n\n filters: {\n set: (filters: Partial<Filters>) => Promise<void>;\n setTemp: (filters: Partial<Filters>) => Promise<void>;\n setToDefault: () => Promise<void>;\n commitTemp: <K extends keyof Filters>(key: K, defaultValue: Filters[K]) => Promise<void>;\n commitDateAvailability: () => Promise<void>;\n submit: () => Promise<void>;\n };\n}\n\nexport function createStructuredStoreActions(store: ZustandUnifiedStoreState, get?: () => ZustandUnifiedStoreState): StructuredStoreActions {\n return {\n property: {\n unit: {\n favorites: {\n toggle: store.toggleFavorite.bind(store),\n },\n viewed: {\n mark: store.markUnitAsViewed.bind(store),\n },\n },\n questionnaire: {\n setResults: store.setQuestionnaireResults.bind(store),\n },\n tour: {\n setContactedOn: store.setTourContactedOn.bind(store),\n getContactedOn: store.getTourContactedOn.bind(store),\n setContactData: store.setTourContactData.bind(store),\n },\n },\n filters: {\n set: store.setFilters.bind(store),\n setTemp: store.setTempFilters.bind(store),\n setToDefault: store.setFiltersToDefault.bind(store),\n commitTemp: async (key, defaultValue) => {\n const state = get ? get() : (store as unknown as ZustandUnifiedStoreState);\n const value = (state.tempFilters as Filters)[key] ?? defaultValue;\n await store.handleTempFilterChange(key, value as any);\n await store.submitFilterUpdate();\n },\n commitDateAvailability: async () => {\n await store.submitFilterUpdate();\n },\n submit: store.submitFilterUpdate.bind(store),\n },\n };\n}\n\nexport type StructuredStore = ZustandUnifiedStoreState & StructuredStoreActions;\n\nexport function createStructuredStore(options?: {\n onFilterUpdate?: (apiParams: QueryParams) => void;\n}) {\n return (set: any, get: any): StructuredStore => {\n const baseStore = createZustandUnifiedStore(options)(set, get);\n const actions = createStructuredStoreActions(baseStore, get);\n\n return {\n ...baseStore,\n ...actions,\n };\n };\n}\n"],"names":["createStructuredStoreActions","store","get","key","defaultValue","value","createStructuredStore","options","set","baseStore","createZustandUnifiedStore","actions"],"mappings":"uHAiDO,SAASA,EAA6BC,EAAiCC,EAA8D,CAC1I,MAAO,CACL,SAAU,CACR,KAAM,CACJ,UAAW,CACT,OAAQD,EAAM,eAAe,KAAKA,CAAK,CAAA,EAEzC,OAAQ,CACN,KAAMA,EAAM,iBAAiB,KAAKA,CAAK,CAAA,CACzC,EAEF,cAAe,CACb,WAAYA,EAAM,wBAAwB,KAAKA,CAAK,CAAA,EAEtD,KAAM,CACJ,eAAgBA,EAAM,mBAAmB,KAAKA,CAAK,EACnD,eAAgBA,EAAM,mBAAmB,KAAKA,CAAK,EACnD,eAAgBA,EAAM,mBAAmB,KAAKA,CAAK,CAAA,CACrD,EAEF,QAAS,CACP,IAAKA,EAAM,WAAW,KAAKA,CAAK,EAChC,QAASA,EAAM,eAAe,KAAKA,CAAK,EACxC,aAAcA,EAAM,oBAAoB,KAAKA,CAAK,EAClD,WAAY,MAAOE,EAAKC,IAAiB,CAEvC,MAAMC,GADQH,EAAMA,EAAA,EAASD,GACR,YAAwBE,CAAG,GAAKC,EACrD,MAAMH,EAAM,uBAAuBE,EAAKE,CAAY,EACpD,MAAMJ,EAAM,mBAAA,CACd,EACA,uBAAwB,SAAY,CAClC,MAAMA,EAAM,mBAAA,CACd,EACA,OAAQA,EAAM,mBAAmB,KAAKA,CAAK,CAAA,CAC7C,CAEJ,CAIO,SAASK,EAAsBC,EAEnC,CACD,MAAO,CAACC,EAAUN,IAA8B,CAC9C,MAAMO,EAAYC,EAAAA,0BAA0BH,CAAO,EAAEC,EAAKN,CAAG,EACvDS,EAAUX,EAA6BS,EAAWP,CAAG,EAE3D,MAAO,CACL,GAAGO,EACH,GAAGE,CAAA,CAEP,CACF"}
|
|
@@ -33,7 +33,7 @@ export interface StructuredStoreActions {
|
|
|
33
33
|
setTemp: (filters: Partial<Filters>) => Promise<void>;
|
|
34
34
|
setToDefault: () => Promise<void>;
|
|
35
35
|
commitTemp: <K extends keyof Filters>(key: K, defaultValue: Filters[K]) => Promise<void>;
|
|
36
|
-
|
|
36
|
+
commitDateAvailability: () => Promise<void>;
|
|
37
37
|
submit: () => Promise<void>;
|
|
38
38
|
};
|
|
39
39
|
}
|
|
@@ -27,7 +27,7 @@ function c(t, i) {
|
|
|
27
27
|
const u = (i ? i() : t).tempFilters[e] ?? n;
|
|
28
28
|
await t.handleTempFilterChange(e, u), await t.submitFilterUpdate();
|
|
29
29
|
},
|
|
30
|
-
|
|
30
|
+
commitDateAvailability: async () => {
|
|
31
31
|
await t.submitFilterUpdate();
|
|
32
32
|
},
|
|
33
33
|
submit: t.submitFilterUpdate.bind(t)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"structured-store.mjs","sources":["../../src/adapters/structured-store.ts"],"sourcesContent":["/**\n * Structured store wrapper (preferred DX)\n *\n * This layer wraps the flat Zustand adapter with domain‑grouped actions\n * for a more discoverable API in apps. It does not add new behavior —\n * it simply organizes calls like:\n * - `property.unit.favorites.toggle` → `toggleFavorite`\n * - `property.unit.viewed.mark` → `markUnitAsViewed`\n * - `filters.set/submit/...` → filter methods\n */\nimport {\n type ZustandUnifiedStoreState,\n createZustandUnifiedStore,\n type Filters,\n type UnitData,\n type TourContactData,\n type QueryParams\n} from \"./zustand-store\";\n\nexport interface StructuredStoreActions {\n property: {\n unit: {\n favorites: {\n toggle: (unitId: string) => Promise<void>;\n };\n viewed: {\n mark: (unitId: string, slug: string) => Promise<void>;\n };\n };\n questionnaire: {\n setResults: (results: unknown) => Promise<void>;\n };\n tour: {\n setContactedOn: () => Promise<void>;\n getContactedOn: () => Promise<string | null>;\n setContactData: (data: TourContactData) => Promise<void>;\n };\n };\n\n filters: {\n set: (filters: Partial<Filters>) => Promise<void>;\n setTemp: (filters: Partial<Filters>) => Promise<void>;\n setToDefault: () => Promise<void>;\n commitTemp: <K extends keyof Filters>(key: K, defaultValue: Filters[K]) => Promise<void>;\n
|
|
1
|
+
{"version":3,"file":"structured-store.mjs","sources":["../../src/adapters/structured-store.ts"],"sourcesContent":["/**\n * Structured store wrapper (preferred DX)\n *\n * This layer wraps the flat Zustand adapter with domain‑grouped actions\n * for a more discoverable API in apps. It does not add new behavior —\n * it simply organizes calls like:\n * - `property.unit.favorites.toggle` → `toggleFavorite`\n * - `property.unit.viewed.mark` → `markUnitAsViewed`\n * - `filters.set/submit/...` → filter methods\n */\nimport {\n type ZustandUnifiedStoreState,\n createZustandUnifiedStore,\n type Filters,\n type UnitData,\n type TourContactData,\n type QueryParams\n} from \"./zustand-store\";\n\nexport interface StructuredStoreActions {\n property: {\n unit: {\n favorites: {\n toggle: (unitId: string) => Promise<void>;\n };\n viewed: {\n mark: (unitId: string, slug: string) => Promise<void>;\n };\n };\n questionnaire: {\n setResults: (results: unknown) => Promise<void>;\n };\n tour: {\n setContactedOn: () => Promise<void>;\n getContactedOn: () => Promise<string | null>;\n setContactData: (data: TourContactData) => Promise<void>;\n };\n };\n\n filters: {\n set: (filters: Partial<Filters>) => Promise<void>;\n setTemp: (filters: Partial<Filters>) => Promise<void>;\n setToDefault: () => Promise<void>;\n commitTemp: <K extends keyof Filters>(key: K, defaultValue: Filters[K]) => Promise<void>;\n commitDateAvailability: () => Promise<void>;\n submit: () => Promise<void>;\n };\n}\n\nexport function createStructuredStoreActions(store: ZustandUnifiedStoreState, get?: () => ZustandUnifiedStoreState): StructuredStoreActions {\n return {\n property: {\n unit: {\n favorites: {\n toggle: store.toggleFavorite.bind(store),\n },\n viewed: {\n mark: store.markUnitAsViewed.bind(store),\n },\n },\n questionnaire: {\n setResults: store.setQuestionnaireResults.bind(store),\n },\n tour: {\n setContactedOn: store.setTourContactedOn.bind(store),\n getContactedOn: store.getTourContactedOn.bind(store),\n setContactData: store.setTourContactData.bind(store),\n },\n },\n filters: {\n set: store.setFilters.bind(store),\n setTemp: store.setTempFilters.bind(store),\n setToDefault: store.setFiltersToDefault.bind(store),\n commitTemp: async (key, defaultValue) => {\n const state = get ? get() : (store as unknown as ZustandUnifiedStoreState);\n const value = (state.tempFilters as Filters)[key] ?? defaultValue;\n await store.handleTempFilterChange(key, value as any);\n await store.submitFilterUpdate();\n },\n commitDateAvailability: async () => {\n await store.submitFilterUpdate();\n },\n submit: store.submitFilterUpdate.bind(store),\n },\n };\n}\n\nexport type StructuredStore = ZustandUnifiedStoreState & StructuredStoreActions;\n\nexport function createStructuredStore(options?: {\n onFilterUpdate?: (apiParams: QueryParams) => void;\n}) {\n return (set: any, get: any): StructuredStore => {\n const baseStore = createZustandUnifiedStore(options)(set, get);\n const actions = createStructuredStoreActions(baseStore, get);\n\n return {\n ...baseStore,\n ...actions,\n };\n };\n}\n"],"names":["createStructuredStoreActions","store","get","key","defaultValue","value","createStructuredStore","options","set","baseStore","createZustandUnifiedStore","actions"],"mappings":";AAiDO,SAASA,EAA6BC,GAAiCC,GAA8D;AAC1I,SAAO;AAAA,IACL,UAAU;AAAA,MACR,MAAM;AAAA,QACJ,WAAW;AAAA,UACT,QAAQD,EAAM,eAAe,KAAKA,CAAK;AAAA,QAAA;AAAA,QAEzC,QAAQ;AAAA,UACN,MAAMA,EAAM,iBAAiB,KAAKA,CAAK;AAAA,QAAA;AAAA,MACzC;AAAA,MAEF,eAAe;AAAA,QACb,YAAYA,EAAM,wBAAwB,KAAKA,CAAK;AAAA,MAAA;AAAA,MAEtD,MAAM;AAAA,QACJ,gBAAgBA,EAAM,mBAAmB,KAAKA,CAAK;AAAA,QACnD,gBAAgBA,EAAM,mBAAmB,KAAKA,CAAK;AAAA,QACnD,gBAAgBA,EAAM,mBAAmB,KAAKA,CAAK;AAAA,MAAA;AAAA,IACrD;AAAA,IAEF,SAAS;AAAA,MACP,KAAKA,EAAM,WAAW,KAAKA,CAAK;AAAA,MAChC,SAASA,EAAM,eAAe,KAAKA,CAAK;AAAA,MACxC,cAAcA,EAAM,oBAAoB,KAAKA,CAAK;AAAA,MAClD,YAAY,OAAOE,GAAKC,MAAiB;AAEvC,cAAMC,KADQH,IAAMA,EAAA,IAASD,GACR,YAAwBE,CAAG,KAAKC;AACrD,cAAMH,EAAM,uBAAuBE,GAAKE,CAAY,GACpD,MAAMJ,EAAM,mBAAA;AAAA,MACd;AAAA,MACA,wBAAwB,YAAY;AAClC,cAAMA,EAAM,mBAAA;AAAA,MACd;AAAA,MACA,QAAQA,EAAM,mBAAmB,KAAKA,CAAK;AAAA,IAAA;AAAA,EAC7C;AAEJ;AAIO,SAASK,EAAsBC,GAEnC;AACD,SAAO,CAACC,GAAUN,MAA8B;AAC9C,UAAMO,IAAYC,EAA0BH,CAAO,EAAEC,GAAKN,CAAG,GACvDS,IAAUX,EAA6BS,GAAWP,CAAG;AAE3D,WAAO;AAAA,MACL,GAAGO;AAAA,MACH,GAAGE;AAAA,IAAA;AAAA,EAEP;AACF;"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("../stores/store.cjs");function d(n){return(
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("../stores/store.cjs");function d(n){return(a,o)=>{const s=async()=>{const t=await e.store.getFullState();a({properties:t.properties,currentPropertyId:t.currentPropertyId,currentPropertySlug:t.currentPropertySlug,hasPreviouslySearched:t.hasPreviouslySearched,unitResults:t.unitResults,filters:t.filters,tempFilters:t.tempFilters,apiFilters:t.apiFilters,resultsMode:t.resultsMode,resolvedQuestionnaireValues:t.resolvedQuestionnaireValues,sortBy:t.sortBy})},u=async()=>{if(n!=null&&n.onFilterUpdate){const t=(await e.store.getFullState()).apiFilters;n.onFilterUpdate(t)}};return{properties:{},currentPropertyId:null,currentPropertySlug:null,hasPreviouslySearched:[],unitResults:[],filters:{date_availability:void 0,qty_bedrooms:void 0,base_price:void 0,highlights:void 0},tempFilters:{date_availability:void 0,qty_bedrooms:void 0,base_price:void 0,highlights:void 0},apiFilters:{limit:10,page:1,sortBy:"relevance"},resultsMode:"all",resolvedQuestionnaireValues:{},sortBy:"relevance",filtersLoaded:!1,async initializeProperty(t,r){await e.store.initializeProperty(t,r),await s()},async setCurrentProperty(t,r){await e.store.setCurrentProperty(t,r),a({currentPropertyId:t,...r&&{currentPropertySlug:r}})},async setCurrentPropertySlug(t){await e.store.setCurrentPropertySlug(t),a({currentPropertySlug:t})},async setHasPreviouslySearched(t){await e.store.setHasPreviouslySearched(t),await s()},async toggleFavorite(t){await e.store.toggleFavorite(t),await s()},async markUnitAsViewed(t,r){await e.store.markUnitAsViewed(t,r),await s()},async setTourContactedOn(){await e.store.setTourContactedOn(),await s()},getTourContactedOn:e.store.getTourContactedOn.bind(e.store),async setQuestionnaireResults(t){await e.store.setQuestionnaireResults(t),await s()},async setTourContactData(t){await e.store.setTourContactData(t),await s()},async setUnitResults(t){await e.store.setUnitResults(t),await s()},async clearUnitResults(){await e.store.clearUnitResults(),await s()},async setFilters(t){await e.store.setFilters(t);const r=o();a({filters:{...r.filters,...t}})},async setTempFilters(t){await e.store.setTempFilters(t);const r=o();a({tempFilters:{...r.tempFilters,...t}})},async setFiltersToDefault(){await e.store.setFiltersToDefault(),a({filters:{date_availability:void 0,qty_bedrooms:void 0,base_price:void 0,highlights:void 0}})},async setApiFilters(t){await e.store.setApiFilters(t);const r=o();a({apiFilters:{...r.apiFilters,...t}})},async handleTempFilterChange(t,r){await e.store.handleTempFilterChange(t,r);const i=o();a({tempFilters:{...i.tempFilters,[t]:r}})},async submitFilterUpdate(){await e.store.submitFilterUpdate(),await s(),await u()},async setResultsMode(t){await e.store.setResultsMode(t),a({resultsMode:t})},async setSortBy(t){await e.store.setSortBy(t),a({sortBy:t})},async setResolvedQuestionnaireValues(t,r){await e.store.setResolvedQuestionnaireValues(t,r);const i=o();a({resolvedQuestionnaireValues:{...i.resolvedQuestionnaireValues,[t]:r}})},getUnitState(t){var l;const r=o(),i=r.currentPropertyId?r.properties[r.currentPropertyId]:null;return{isFavorite:(i==null?void 0:i.favoritedUnits.includes(t))??!1,viewedDate:((l=i==null?void 0:i.viewedUnits.find(c=>c.unitId===t))==null?void 0:l.viewedDate)??""}},getResultsUrl:e.store.getResultsUrl.bind(e.store),getCurrentProperty:e.store.getCurrentProperty.bind(e.store),getPropertyData:e.store.getPropertyData.bind(e.store),async _hydrate(){await s()},async _initialize(){await e.store.initialize(),await s(),a({filtersLoaded:!0})}}}}function y(){return n=>a=>n(o=>o.getUnitState(a))}exports.createUseUnitState=y;exports.createZustandUnifiedStore=d;
|
|
2
2
|
//# sourceMappingURL=zustand-store.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"zustand-store.cjs","sources":["../../src/adapters/zustand-store.ts"],"sourcesContent":["/**\n * Zustand adapter (flat API)\n *\n * This file exposes a flat, unified Zustand store that mirrors the underlying\n * ORM store and keeps React state in sync. It is the low-level bridge.\n *\n * For a friendlier, domain-grouped API, use `createStructuredStore` from\n * `./structured-store`, which wraps this adapter and exposes nested actions\n * like `property.unit.favorites.toggle`, `filters.set`, etc.\n */\nimport { store } from \"../stores/store\";\nimport type { UnifiedStoreData, UserPropertyState, Filters, QueryParams, ResultsMode, SortBy, TourContactData, Unit } from \"../schema\";\n\n// Unified Zustand store interface\nexport interface ZustandUnifiedStoreState {\n // Property data\n properties: Record<string, UserPropertyState>;\n currentPropertyId: string | null;\n currentPropertySlug: string | null;\n hasPreviouslySearched: string[];\n\n // App data\n unitResults: Unit[];\n filters: Filters;\n tempFilters: Filters;\n apiFilters: QueryParams;\n resultsMode: ResultsMode;\n resolvedQuestionnaireValues: Record<string, string[]>;\n sortBy: SortBy;\n filtersLoaded: boolean;\n\n // === PROPERTY OPERATIONS ===\n initializeProperty: (propertyId: string, slug: string) => Promise<void>;\n setCurrentProperty: (propertyId: string, slug?: string) => Promise<void>;\n setCurrentPropertySlug: (slug: string) => Promise<void>;\n setHasPreviouslySearched: (slug: string) => Promise<void>;\n toggleFavorite: (unitId: string) => Promise<void>;\n markUnitAsViewed: (unitId: string, slug: string) => Promise<void>;\n setTourContactedOn: () => Promise<void>;\n getTourContactedOn: () => Promise<string | null>;\n setQuestionnaireResults: (results: unknown) => Promise<void>;\n setTourContactData: (data: TourContactData) => Promise<void>;\n setUnitResults: (units: unknown) => Promise<void>;\n clearUnitResults: () => Promise<void>;\n\n\n // === FILTER OPERATIONS ===\n setFilters: (filters: Partial<Filters>) => Promise<void>;\n setTempFilters: (filters: Partial<Filters>) => Promise<void>;\n setFiltersToDefault: () => Promise<void>;\n setApiFilters: (filters: Partial<QueryParams>) => Promise<void>;\n handleTempFilterChange: <K extends keyof Filters>(key: K, value: Filters[K]) => Promise<void>;\n submitFilterUpdate: () => Promise<void>;\n\n // === RESULTS AND SORTING ===\n setResultsMode: (mode: ResultsMode) => Promise<void>;\n setSortBy: (sortBy: SortBy) => Promise<void>;\n\n // === QUESTIONNAIRE ===\n setResolvedQuestionnaireValues: (name: string, values: string[]) => Promise<void>;\n\n // === UTILITY METHODS ===\n getUnitState: (unitId: string) => {\n isFavorite: boolean;\n viewedDate: string;\n };\n getResultsUrl: () => Promise<string | null>;\n getCurrentProperty: () => Promise<UserPropertyState | null>;\n getPropertyData: (propertyId?: string) => Promise<UserPropertyState | null>;\n\n // === INTERNAL ===\n _hydrate: () => Promise<void>;\n _initialize: () => Promise<void>;\n}\n\n/**\n * @deprecated For new apps, use `createStructuredStore` from `./structured-store`.\n * This flat adapter remains for migration/advanced cases.\n */\nexport function createZustandUnifiedStore(options?: {\n onFilterUpdate?: (apiParams: QueryParams) => void;\n}) {\n return (set: any, get: any): ZustandUnifiedStoreState => {\n // Helper to update local state after ORM operations\n const syncState = async () => {\n const ormState = await store.getFullState();\n set({\n properties: ormState.properties,\n currentPropertyId: ormState.currentPropertyId,\n currentPropertySlug: ormState.currentPropertySlug,\n hasPreviouslySearched: ormState.hasPreviouslySearched,\n unitResults: ormState.unitResults,\n filters: ormState.filters,\n tempFilters: ormState.tempFilters,\n apiFilters: ormState.apiFilters,\n resultsMode: ormState.resultsMode,\n resolvedQuestionnaireValues: ormState.resolvedQuestionnaireValues,\n sortBy: ormState.sortBy,\n });\n };\n\n // Helper to notify of filter updates\n const notifyFilterUpdate = async () => {\n if (options?.onFilterUpdate) {\n const apiFilters = (await store.getFullState()).apiFilters;\n options.onFilterUpdate(apiFilters);\n }\n };\n\n return {\n // Initial state\n properties: {},\n currentPropertyId: null,\n currentPropertySlug: null,\n hasPreviouslySearched: [],\n unitResults: [],\n filters: {\n availability: undefined,\n bedrooms: undefined,\n cost: undefined,\n highlights: undefined,\n },\n tempFilters: {\n availability: undefined,\n bedrooms: undefined,\n cost: undefined,\n highlights: undefined,\n },\n apiFilters: {\n limit: 10,\n page: 1,\n },\n resultsMode: \"all\",\n resolvedQuestionnaireValues: {},\n sortBy: \"relevance\",\n filtersLoaded: false,\n\n // === PROPERTY OPERATIONS ===\n async initializeProperty(propertyId, slug) {\n await store.initializeProperty(propertyId, slug);\n await syncState();\n },\n\n async setCurrentProperty(propertyId, slug) {\n await store.setCurrentProperty(propertyId, slug);\n set({\n currentPropertyId: propertyId,\n ...(slug && { currentPropertySlug: slug })\n });\n },\n\n async setCurrentPropertySlug(slug) {\n await store.setCurrentPropertySlug(slug);\n set({ currentPropertySlug: slug });\n },\n\n async setHasPreviouslySearched(slug) {\n await store.setHasPreviouslySearched(slug);\n await syncState();\n },\n\n async toggleFavorite(unitId) {\n await store.toggleFavorite(unitId);\n await syncState();\n },\n\n async markUnitAsViewed(unitId, slug) {\n await store.markUnitAsViewed(unitId, slug);\n await syncState();\n },\n\n async setTourContactedOn() {\n await store.setTourContactedOn();\n await syncState();\n },\n\n getTourContactedOn: store.getTourContactedOn.bind(store),\n\n async setQuestionnaireResults(results) {\n await store.setQuestionnaireResults(results);\n await syncState();\n },\n\n async setTourContactData(data) {\n await store.setTourContactData(data);\n await syncState();\n },\n\n async setUnitResults(units) {\n await store.setUnitResults(units);\n await syncState();\n },\n\n async clearUnitResults() {\n await store.clearUnitResults();\n await syncState();\n },\n\n\n // === FILTER OPERATIONS ===\n async setFilters(filters) {\n await store.setFilters(filters);\n const state = get();\n set({ filters: { ...state.filters, ...filters } });\n },\n\n async setTempFilters(filters) {\n await store.setTempFilters(filters);\n const state = get();\n set({ tempFilters: { ...state.tempFilters, ...filters } });\n },\n\n async setFiltersToDefault() {\n await store.setFiltersToDefault();\n const defaultFilters = {\n availability: undefined,\n bedrooms: undefined,\n cost: undefined,\n highlights: undefined,\n };\n set({ filters: defaultFilters });\n },\n\n async setApiFilters(filters) {\n await store.setApiFilters(filters);\n const state = get();\n set({ apiFilters: { ...state.apiFilters, ...filters } });\n },\n\n async handleTempFilterChange(key, value) {\n await store.handleTempFilterChange(key, value);\n const state = get();\n set({ tempFilters: { ...state.tempFilters, [key]: value } });\n },\n\n async submitFilterUpdate() {\n await store.submitFilterUpdate();\n await syncState();\n await notifyFilterUpdate();\n },\n\n // === RESULTS AND SORTING ===\n async setResultsMode(mode) {\n await store.setResultsMode(mode);\n set({ resultsMode: mode });\n },\n\n async setSortBy(sortBy) {\n await store.setSortBy(sortBy);\n set({ sortBy });\n },\n\n // === QUESTIONNAIRE ===\n async setResolvedQuestionnaireValues(name, values) {\n await store.setResolvedQuestionnaireValues(name, values);\n const state = get();\n set({\n resolvedQuestionnaireValues: {\n ...state.resolvedQuestionnaireValues,\n [name]: values,\n }\n });\n },\n\n // === UTILITY METHODS ===\n getUnitState(unitId: string) {\n const state = get();\n const property = state.currentPropertyId ? state.properties[state.currentPropertyId] : null;\n\n return {\n isFavorite: property?.favoritedUnits.includes(unitId) ?? false,\n viewedDate:\n property?.viewedUnits.find((u: any) => u.unitId === unitId)?.viewedDate ?? \"\",\n };\n },\n\n getResultsUrl: store.getResultsUrl.bind(store),\n getCurrentProperty: store.getCurrentProperty.bind(store),\n getPropertyData: store.getPropertyData.bind(store),\n\n // === INTERNAL ===\n async _hydrate() {\n await syncState();\n },\n\n async _initialize() {\n await store.initialize();\n await syncState();\n set({ filtersLoaded: true });\n },\n };\n };\n}\n\n// Helper hook factory for unit state\nexport function createUseUnitState() {\n return (useStore: any) => (unitId: string) =>\n useStore((state: ZustandUnifiedStoreState) => state.getUnitState(unitId));\n}\n\n// Export types for consuming apps\nexport type { UnitData, UserPropertyState, Filters, QueryParams, ResultsMode, SortBy, TourContactData, Unit } from \"../schema\";\n\n// Intentionally no alias exports in vNext; use `createStructuredStore` or `createZustandUnifiedStore` explicitly.\n"],"names":["createZustandUnifiedStore","options","set","get","syncState","ormState","store","notifyFilterUpdate","apiFilters","propertyId","slug","unitId","results","data","units","filters","state","key","value","mode","sortBy","name","values","property","_a","u","createUseUnitState","useStore"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"zustand-store.cjs","sources":["../../src/adapters/zustand-store.ts"],"sourcesContent":["/**\n * Zustand adapter (flat API)\n *\n * This file exposes a flat, unified Zustand store that mirrors the underlying\n * ORM store and keeps React state in sync. It is the low-level bridge.\n *\n * For a friendlier, domain-grouped API, use `createStructuredStore` from\n * `./structured-store`, which wraps this adapter and exposes nested actions\n * like `property.unit.favorites.toggle`, `filters.set`, etc.\n */\nimport { store } from \"../stores/store\";\nimport type { UnifiedStoreData, UserPropertyState, Filters, QueryParams, ResultsMode, SortBy, TourContactData, Unit } from \"../schema\";\n\n// Unified Zustand store interface\nexport interface ZustandUnifiedStoreState {\n // Property data\n properties: Record<string, UserPropertyState>;\n currentPropertyId: string | null;\n currentPropertySlug: string | null;\n hasPreviouslySearched: string[];\n\n // App data\n unitResults: Unit[];\n filters: Filters;\n tempFilters: Filters;\n apiFilters: QueryParams;\n resultsMode: ResultsMode;\n resolvedQuestionnaireValues: Record<string, string[]>;\n sortBy: SortBy;\n filtersLoaded: boolean;\n\n // === PROPERTY OPERATIONS ===\n initializeProperty: (propertyId: string, slug: string) => Promise<void>;\n setCurrentProperty: (propertyId: string, slug?: string) => Promise<void>;\n setCurrentPropertySlug: (slug: string) => Promise<void>;\n setHasPreviouslySearched: (slug: string) => Promise<void>;\n toggleFavorite: (unitId: string) => Promise<void>;\n markUnitAsViewed: (unitId: string, slug: string) => Promise<void>;\n setTourContactedOn: () => Promise<void>;\n getTourContactedOn: () => Promise<string | null>;\n setQuestionnaireResults: (results: unknown) => Promise<void>;\n setTourContactData: (data: TourContactData) => Promise<void>;\n setUnitResults: (units: unknown) => Promise<void>;\n clearUnitResults: () => Promise<void>;\n\n\n // === FILTER OPERATIONS ===\n setFilters: (filters: Partial<Filters>) => Promise<void>;\n setTempFilters: (filters: Partial<Filters>) => Promise<void>;\n setFiltersToDefault: () => Promise<void>;\n setApiFilters: (filters: Partial<QueryParams>) => Promise<void>;\n handleTempFilterChange: <K extends keyof Filters>(key: K, value: Filters[K]) => Promise<void>;\n submitFilterUpdate: () => Promise<void>;\n\n // === RESULTS AND SORTING ===\n setResultsMode: (mode: ResultsMode) => Promise<void>;\n setSortBy: (sortBy: SortBy) => Promise<void>;\n\n // === QUESTIONNAIRE ===\n setResolvedQuestionnaireValues: (name: string, values: string[]) => Promise<void>;\n\n // === UTILITY METHODS ===\n getUnitState: (unitId: string) => {\n isFavorite: boolean;\n viewedDate: string;\n };\n getResultsUrl: () => Promise<string | null>;\n getCurrentProperty: () => Promise<UserPropertyState | null>;\n getPropertyData: (propertyId?: string) => Promise<UserPropertyState | null>;\n\n // === INTERNAL ===\n _hydrate: () => Promise<void>;\n _initialize: () => Promise<void>;\n}\n\n/**\n * @deprecated For new apps, use `createStructuredStore` from `./structured-store`.\n * This flat adapter remains for migration/advanced cases.\n */\nexport function createZustandUnifiedStore(options?: {\n onFilterUpdate?: (apiParams: QueryParams) => void;\n}) {\n return (set: any, get: any): ZustandUnifiedStoreState => {\n // Helper to update local state after ORM operations\n const syncState = async () => {\n const ormState = await store.getFullState();\n set({\n properties: ormState.properties,\n currentPropertyId: ormState.currentPropertyId,\n currentPropertySlug: ormState.currentPropertySlug,\n hasPreviouslySearched: ormState.hasPreviouslySearched,\n unitResults: ormState.unitResults,\n filters: ormState.filters,\n tempFilters: ormState.tempFilters,\n apiFilters: ormState.apiFilters,\n resultsMode: ormState.resultsMode,\n resolvedQuestionnaireValues: ormState.resolvedQuestionnaireValues,\n sortBy: ormState.sortBy,\n });\n };\n\n // Helper to notify of filter updates\n const notifyFilterUpdate = async () => {\n if (options?.onFilterUpdate) {\n const apiFilters = (await store.getFullState()).apiFilters;\n options.onFilterUpdate(apiFilters);\n }\n };\n\n return {\n // Initial state\n properties: {},\n currentPropertyId: null,\n currentPropertySlug: null,\n hasPreviouslySearched: [],\n unitResults: [],\n filters: {\n date_availability: undefined,\n qty_bedrooms: undefined,\n base_price: undefined,\n highlights: undefined,\n },\n tempFilters: {\n date_availability: undefined,\n qty_bedrooms: undefined,\n base_price: undefined,\n highlights: undefined,\n },\n apiFilters: {\n limit: 10,\n page: 1,\n sortBy: \"relevance\",\n },\n resultsMode: \"all\",\n resolvedQuestionnaireValues: {},\n sortBy: \"relevance\",\n filtersLoaded: false,\n\n // === PROPERTY OPERATIONS ===\n async initializeProperty(propertyId, slug) {\n await store.initializeProperty(propertyId, slug);\n await syncState();\n },\n\n async setCurrentProperty(propertyId, slug) {\n await store.setCurrentProperty(propertyId, slug);\n set({\n currentPropertyId: propertyId,\n ...(slug && { currentPropertySlug: slug })\n });\n },\n\n async setCurrentPropertySlug(slug) {\n await store.setCurrentPropertySlug(slug);\n set({ currentPropertySlug: slug });\n },\n\n async setHasPreviouslySearched(slug) {\n await store.setHasPreviouslySearched(slug);\n await syncState();\n },\n\n async toggleFavorite(unitId) {\n await store.toggleFavorite(unitId);\n await syncState();\n },\n\n async markUnitAsViewed(unitId, slug) {\n await store.markUnitAsViewed(unitId, slug);\n await syncState();\n },\n\n async setTourContactedOn() {\n await store.setTourContactedOn();\n await syncState();\n },\n\n getTourContactedOn: store.getTourContactedOn.bind(store),\n\n async setQuestionnaireResults(results) {\n await store.setQuestionnaireResults(results);\n await syncState();\n },\n\n async setTourContactData(data) {\n await store.setTourContactData(data);\n await syncState();\n },\n\n async setUnitResults(units) {\n await store.setUnitResults(units);\n await syncState();\n },\n\n async clearUnitResults() {\n await store.clearUnitResults();\n await syncState();\n },\n\n\n // === FILTER OPERATIONS ===\n async setFilters(filters) {\n await store.setFilters(filters);\n const state = get();\n set({ filters: { ...state.filters, ...filters } });\n },\n\n async setTempFilters(filters) {\n await store.setTempFilters(filters);\n const state = get();\n set({ tempFilters: { ...state.tempFilters, ...filters } });\n },\n\n async setFiltersToDefault() {\n await store.setFiltersToDefault();\n const defaultFilters = {\n date_availability: undefined,\n qty_bedrooms: undefined,\n base_price: undefined,\n highlights: undefined,\n };\n set({ filters: defaultFilters });\n },\n\n async setApiFilters(filters) {\n await store.setApiFilters(filters);\n const state = get();\n set({ apiFilters: { ...state.apiFilters, ...filters } });\n },\n\n async handleTempFilterChange(key, value) {\n await store.handleTempFilterChange(key, value);\n const state = get();\n set({ tempFilters: { ...state.tempFilters, [key]: value } });\n },\n\n async submitFilterUpdate() {\n await store.submitFilterUpdate();\n await syncState();\n await notifyFilterUpdate();\n },\n\n // === RESULTS AND SORTING ===\n async setResultsMode(mode) {\n await store.setResultsMode(mode);\n set({ resultsMode: mode });\n },\n\n async setSortBy(sortBy) {\n await store.setSortBy(sortBy);\n set({ sortBy });\n },\n\n // === QUESTIONNAIRE ===\n async setResolvedQuestionnaireValues(name, values) {\n await store.setResolvedQuestionnaireValues(name, values);\n const state = get();\n set({\n resolvedQuestionnaireValues: {\n ...state.resolvedQuestionnaireValues,\n [name]: values,\n }\n });\n },\n\n // === UTILITY METHODS ===\n getUnitState(unitId: string) {\n const state = get();\n const property = state.currentPropertyId ? state.properties[state.currentPropertyId] : null;\n\n return {\n isFavorite: property?.favoritedUnits.includes(unitId) ?? false,\n viewedDate:\n property?.viewedUnits.find((u: any) => u.unitId === unitId)?.viewedDate ?? \"\",\n };\n },\n\n getResultsUrl: store.getResultsUrl.bind(store),\n getCurrentProperty: store.getCurrentProperty.bind(store),\n getPropertyData: store.getPropertyData.bind(store),\n\n // === INTERNAL ===\n async _hydrate() {\n await syncState();\n },\n\n async _initialize() {\n await store.initialize();\n await syncState();\n set({ filtersLoaded: true });\n },\n };\n };\n}\n\n// Helper hook factory for unit state\nexport function createUseUnitState() {\n return (useStore: any) => (unitId: string) =>\n useStore((state: ZustandUnifiedStoreState) => state.getUnitState(unitId));\n}\n\n// Export types for consuming apps\nexport type { UnitData, UserPropertyState, Filters, QueryParams, ResultsMode, SortBy, TourContactData, Unit } from \"../schema\";\n\n// Intentionally no alias exports in vNext; use `createStructuredStore` or `createZustandUnifiedStore` explicitly.\n"],"names":["createZustandUnifiedStore","options","set","get","syncState","ormState","store","notifyFilterUpdate","apiFilters","propertyId","slug","unitId","results","data","units","filters","state","key","value","mode","sortBy","name","values","property","_a","u","createUseUnitState","useStore"],"mappings":"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"}
|
|
@@ -30,20 +30,21 @@ function y(l) {
|
|
|
30
30
|
hasPreviouslySearched: [],
|
|
31
31
|
unitResults: [],
|
|
32
32
|
filters: {
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
33
|
+
date_availability: void 0,
|
|
34
|
+
qty_bedrooms: void 0,
|
|
35
|
+
base_price: void 0,
|
|
36
36
|
highlights: void 0
|
|
37
37
|
},
|
|
38
38
|
tempFilters: {
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
39
|
+
date_availability: void 0,
|
|
40
|
+
qty_bedrooms: void 0,
|
|
41
|
+
base_price: void 0,
|
|
42
42
|
highlights: void 0
|
|
43
43
|
},
|
|
44
44
|
apiFilters: {
|
|
45
45
|
limit: 10,
|
|
46
|
-
page: 1
|
|
46
|
+
page: 1,
|
|
47
|
+
sortBy: "relevance"
|
|
47
48
|
},
|
|
48
49
|
resultsMode: "all",
|
|
49
50
|
resolvedQuestionnaireValues: {},
|
|
@@ -100,9 +101,9 @@ function y(l) {
|
|
|
100
101
|
},
|
|
101
102
|
async setFiltersToDefault() {
|
|
102
103
|
await e.setFiltersToDefault(), i({ filters: {
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
104
|
+
date_availability: void 0,
|
|
105
|
+
qty_bedrooms: void 0,
|
|
106
|
+
base_price: void 0,
|
|
106
107
|
highlights: void 0
|
|
107
108
|
} });
|
|
108
109
|
},
|
|
@@ -143,7 +144,7 @@ function y(l) {
|
|
|
143
144
|
const a = n(), s = a.currentPropertyId ? a.properties[a.currentPropertyId] : null;
|
|
144
145
|
return {
|
|
145
146
|
isFavorite: (s == null ? void 0 : s.favoritedUnits.includes(t)) ?? !1,
|
|
146
|
-
viewedDate: ((o = s == null ? void 0 : s.viewedUnits.find((
|
|
147
|
+
viewedDate: ((o = s == null ? void 0 : s.viewedUnits.find((d) => d.unitId === t)) == null ? void 0 : o.viewedDate) ?? ""
|
|
147
148
|
};
|
|
148
149
|
},
|
|
149
150
|
getResultsUrl: e.getResultsUrl.bind(e),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"zustand-store.mjs","sources":["../../src/adapters/zustand-store.ts"],"sourcesContent":["/**\n * Zustand adapter (flat API)\n *\n * This file exposes a flat, unified Zustand store that mirrors the underlying\n * ORM store and keeps React state in sync. It is the low-level bridge.\n *\n * For a friendlier, domain-grouped API, use `createStructuredStore` from\n * `./structured-store`, which wraps this adapter and exposes nested actions\n * like `property.unit.favorites.toggle`, `filters.set`, etc.\n */\nimport { store } from \"../stores/store\";\nimport type { UnifiedStoreData, UserPropertyState, Filters, QueryParams, ResultsMode, SortBy, TourContactData, Unit } from \"../schema\";\n\n// Unified Zustand store interface\nexport interface ZustandUnifiedStoreState {\n // Property data\n properties: Record<string, UserPropertyState>;\n currentPropertyId: string | null;\n currentPropertySlug: string | null;\n hasPreviouslySearched: string[];\n\n // App data\n unitResults: Unit[];\n filters: Filters;\n tempFilters: Filters;\n apiFilters: QueryParams;\n resultsMode: ResultsMode;\n resolvedQuestionnaireValues: Record<string, string[]>;\n sortBy: SortBy;\n filtersLoaded: boolean;\n\n // === PROPERTY OPERATIONS ===\n initializeProperty: (propertyId: string, slug: string) => Promise<void>;\n setCurrentProperty: (propertyId: string, slug?: string) => Promise<void>;\n setCurrentPropertySlug: (slug: string) => Promise<void>;\n setHasPreviouslySearched: (slug: string) => Promise<void>;\n toggleFavorite: (unitId: string) => Promise<void>;\n markUnitAsViewed: (unitId: string, slug: string) => Promise<void>;\n setTourContactedOn: () => Promise<void>;\n getTourContactedOn: () => Promise<string | null>;\n setQuestionnaireResults: (results: unknown) => Promise<void>;\n setTourContactData: (data: TourContactData) => Promise<void>;\n setUnitResults: (units: unknown) => Promise<void>;\n clearUnitResults: () => Promise<void>;\n\n\n // === FILTER OPERATIONS ===\n setFilters: (filters: Partial<Filters>) => Promise<void>;\n setTempFilters: (filters: Partial<Filters>) => Promise<void>;\n setFiltersToDefault: () => Promise<void>;\n setApiFilters: (filters: Partial<QueryParams>) => Promise<void>;\n handleTempFilterChange: <K extends keyof Filters>(key: K, value: Filters[K]) => Promise<void>;\n submitFilterUpdate: () => Promise<void>;\n\n // === RESULTS AND SORTING ===\n setResultsMode: (mode: ResultsMode) => Promise<void>;\n setSortBy: (sortBy: SortBy) => Promise<void>;\n\n // === QUESTIONNAIRE ===\n setResolvedQuestionnaireValues: (name: string, values: string[]) => Promise<void>;\n\n // === UTILITY METHODS ===\n getUnitState: (unitId: string) => {\n isFavorite: boolean;\n viewedDate: string;\n };\n getResultsUrl: () => Promise<string | null>;\n getCurrentProperty: () => Promise<UserPropertyState | null>;\n getPropertyData: (propertyId?: string) => Promise<UserPropertyState | null>;\n\n // === INTERNAL ===\n _hydrate: () => Promise<void>;\n _initialize: () => Promise<void>;\n}\n\n/**\n * @deprecated For new apps, use `createStructuredStore` from `./structured-store`.\n * This flat adapter remains for migration/advanced cases.\n */\nexport function createZustandUnifiedStore(options?: {\n onFilterUpdate?: (apiParams: QueryParams) => void;\n}) {\n return (set: any, get: any): ZustandUnifiedStoreState => {\n // Helper to update local state after ORM operations\n const syncState = async () => {\n const ormState = await store.getFullState();\n set({\n properties: ormState.properties,\n currentPropertyId: ormState.currentPropertyId,\n currentPropertySlug: ormState.currentPropertySlug,\n hasPreviouslySearched: ormState.hasPreviouslySearched,\n unitResults: ormState.unitResults,\n filters: ormState.filters,\n tempFilters: ormState.tempFilters,\n apiFilters: ormState.apiFilters,\n resultsMode: ormState.resultsMode,\n resolvedQuestionnaireValues: ormState.resolvedQuestionnaireValues,\n sortBy: ormState.sortBy,\n });\n };\n\n // Helper to notify of filter updates\n const notifyFilterUpdate = async () => {\n if (options?.onFilterUpdate) {\n const apiFilters = (await store.getFullState()).apiFilters;\n options.onFilterUpdate(apiFilters);\n }\n };\n\n return {\n // Initial state\n properties: {},\n currentPropertyId: null,\n currentPropertySlug: null,\n hasPreviouslySearched: [],\n unitResults: [],\n filters: {\n availability: undefined,\n bedrooms: undefined,\n cost: undefined,\n highlights: undefined,\n },\n tempFilters: {\n availability: undefined,\n bedrooms: undefined,\n cost: undefined,\n highlights: undefined,\n },\n apiFilters: {\n limit: 10,\n page: 1,\n },\n resultsMode: \"all\",\n resolvedQuestionnaireValues: {},\n sortBy: \"relevance\",\n filtersLoaded: false,\n\n // === PROPERTY OPERATIONS ===\n async initializeProperty(propertyId, slug) {\n await store.initializeProperty(propertyId, slug);\n await syncState();\n },\n\n async setCurrentProperty(propertyId, slug) {\n await store.setCurrentProperty(propertyId, slug);\n set({\n currentPropertyId: propertyId,\n ...(slug && { currentPropertySlug: slug })\n });\n },\n\n async setCurrentPropertySlug(slug) {\n await store.setCurrentPropertySlug(slug);\n set({ currentPropertySlug: slug });\n },\n\n async setHasPreviouslySearched(slug) {\n await store.setHasPreviouslySearched(slug);\n await syncState();\n },\n\n async toggleFavorite(unitId) {\n await store.toggleFavorite(unitId);\n await syncState();\n },\n\n async markUnitAsViewed(unitId, slug) {\n await store.markUnitAsViewed(unitId, slug);\n await syncState();\n },\n\n async setTourContactedOn() {\n await store.setTourContactedOn();\n await syncState();\n },\n\n getTourContactedOn: store.getTourContactedOn.bind(store),\n\n async setQuestionnaireResults(results) {\n await store.setQuestionnaireResults(results);\n await syncState();\n },\n\n async setTourContactData(data) {\n await store.setTourContactData(data);\n await syncState();\n },\n\n async setUnitResults(units) {\n await store.setUnitResults(units);\n await syncState();\n },\n\n async clearUnitResults() {\n await store.clearUnitResults();\n await syncState();\n },\n\n\n // === FILTER OPERATIONS ===\n async setFilters(filters) {\n await store.setFilters(filters);\n const state = get();\n set({ filters: { ...state.filters, ...filters } });\n },\n\n async setTempFilters(filters) {\n await store.setTempFilters(filters);\n const state = get();\n set({ tempFilters: { ...state.tempFilters, ...filters } });\n },\n\n async setFiltersToDefault() {\n await store.setFiltersToDefault();\n const defaultFilters = {\n availability: undefined,\n bedrooms: undefined,\n cost: undefined,\n highlights: undefined,\n };\n set({ filters: defaultFilters });\n },\n\n async setApiFilters(filters) {\n await store.setApiFilters(filters);\n const state = get();\n set({ apiFilters: { ...state.apiFilters, ...filters } });\n },\n\n async handleTempFilterChange(key, value) {\n await store.handleTempFilterChange(key, value);\n const state = get();\n set({ tempFilters: { ...state.tempFilters, [key]: value } });\n },\n\n async submitFilterUpdate() {\n await store.submitFilterUpdate();\n await syncState();\n await notifyFilterUpdate();\n },\n\n // === RESULTS AND SORTING ===\n async setResultsMode(mode) {\n await store.setResultsMode(mode);\n set({ resultsMode: mode });\n },\n\n async setSortBy(sortBy) {\n await store.setSortBy(sortBy);\n set({ sortBy });\n },\n\n // === QUESTIONNAIRE ===\n async setResolvedQuestionnaireValues(name, values) {\n await store.setResolvedQuestionnaireValues(name, values);\n const state = get();\n set({\n resolvedQuestionnaireValues: {\n ...state.resolvedQuestionnaireValues,\n [name]: values,\n }\n });\n },\n\n // === UTILITY METHODS ===\n getUnitState(unitId: string) {\n const state = get();\n const property = state.currentPropertyId ? state.properties[state.currentPropertyId] : null;\n\n return {\n isFavorite: property?.favoritedUnits.includes(unitId) ?? false,\n viewedDate:\n property?.viewedUnits.find((u: any) => u.unitId === unitId)?.viewedDate ?? \"\",\n };\n },\n\n getResultsUrl: store.getResultsUrl.bind(store),\n getCurrentProperty: store.getCurrentProperty.bind(store),\n getPropertyData: store.getPropertyData.bind(store),\n\n // === INTERNAL ===\n async _hydrate() {\n await syncState();\n },\n\n async _initialize() {\n await store.initialize();\n await syncState();\n set({ filtersLoaded: true });\n },\n };\n };\n}\n\n// Helper hook factory for unit state\nexport function createUseUnitState() {\n return (useStore: any) => (unitId: string) =>\n useStore((state: ZustandUnifiedStoreState) => state.getUnitState(unitId));\n}\n\n// Export types for consuming apps\nexport type { UnitData, UserPropertyState, Filters, QueryParams, ResultsMode, SortBy, TourContactData, Unit } from \"../schema\";\n\n// Intentionally no alias exports in vNext; use `createStructuredStore` or `createZustandUnifiedStore` explicitly.\n"],"names":["createZustandUnifiedStore","options","set","get","syncState","ormState","store","notifyFilterUpdate","apiFilters","propertyId","slug","unitId","results","data","units","filters","state","key","value","mode","sortBy","name","values","property","_a","u","createUseUnitState","useStore"],"mappings":";AA+EO,SAASA,EAA0BC,GAEvC;AACD,SAAO,CAACC,GAAUC,MAAuC;AAEvD,UAAMC,IAAY,YAAY;AAC5B,YAAMC,IAAW,MAAMC,EAAM,aAAA;AAC7B,MAAAJ,EAAI;AAAA,QACF,YAAYG,EAAS;AAAA,QACrB,mBAAmBA,EAAS;AAAA,QAC5B,qBAAqBA,EAAS;AAAA,QAC9B,uBAAuBA,EAAS;AAAA,QAChC,aAAaA,EAAS;AAAA,QACtB,SAASA,EAAS;AAAA,QAClB,aAAaA,EAAS;AAAA,QACtB,YAAYA,EAAS;AAAA,QACrB,aAAaA,EAAS;AAAA,QACtB,6BAA6BA,EAAS;AAAA,QACtC,QAAQA,EAAS;AAAA,MAAA,CAClB;AAAA,IACH,GAGME,IAAqB,YAAY;AACrC,UAAIN,KAAA,QAAAA,EAAS,gBAAgB;AAC3B,cAAMO,KAAc,MAAMF,EAAM,aAAA,GAAgB;AAChD,QAAAL,EAAQ,eAAeO,CAAU;AAAA,MACnC;AAAA,IACF;AAEA,WAAO;AAAA;AAAA,MAEL,YAAY,CAAA;AAAA,MACZ,mBAAmB;AAAA,MACnB,qBAAqB;AAAA,MACrB,uBAAuB,CAAA;AAAA,MACvB,aAAa,CAAA;AAAA,MACb,SAAS;AAAA,QACP,cAAc;AAAA,QACd,UAAU;AAAA,QACV,MAAM;AAAA,QACN,YAAY;AAAA,MAAA;AAAA,MAEd,aAAa;AAAA,QACX,cAAc;AAAA,QACd,UAAU;AAAA,QACV,MAAM;AAAA,QACN,YAAY;AAAA,MAAA;AAAA,MAEd,YAAY;AAAA,QACV,OAAO;AAAA,QACP,MAAM;AAAA,MAAA;AAAA,MAER,aAAa;AAAA,MACb,6BAA6B,CAAA;AAAA,MAC7B,QAAQ;AAAA,MACR,eAAe;AAAA;AAAA,MAGf,MAAM,mBAAmBC,GAAYC,GAAM;AACzC,cAAMJ,EAAM,mBAAmBG,GAAYC,CAAI,GAC/C,MAAMN,EAAA;AAAA,MACR;AAAA,MAEA,MAAM,mBAAmBK,GAAYC,GAAM;AACzC,cAAMJ,EAAM,mBAAmBG,GAAYC,CAAI,GAC/CR,EAAI;AAAA,UACF,mBAAmBO;AAAA,UACnB,GAAIC,KAAQ,EAAE,qBAAqBA,EAAA;AAAA,QAAK,CACzC;AAAA,MACH;AAAA,MAEA,MAAM,uBAAuBA,GAAM;AACjC,cAAMJ,EAAM,uBAAuBI,CAAI,GACvCR,EAAI,EAAE,qBAAqBQ,GAAM;AAAA,MACnC;AAAA,MAEA,MAAM,yBAAyBA,GAAM;AACnC,cAAMJ,EAAM,yBAAyBI,CAAI,GACzC,MAAMN,EAAA;AAAA,MACR;AAAA,MAEA,MAAM,eAAeO,GAAQ;AAC3B,cAAML,EAAM,eAAeK,CAAM,GACjC,MAAMP,EAAA;AAAA,MACR;AAAA,MAEA,MAAM,iBAAiBO,GAAQD,GAAM;AACnC,cAAMJ,EAAM,iBAAiBK,GAAQD,CAAI,GACzC,MAAMN,EAAA;AAAA,MACR;AAAA,MAEA,MAAM,qBAAqB;AACzB,cAAME,EAAM,mBAAA,GACZ,MAAMF,EAAA;AAAA,MACR;AAAA,MAEA,oBAAoBE,EAAM,mBAAmB,KAAKA,CAAK;AAAA,MAEvD,MAAM,wBAAwBM,GAAS;AACrC,cAAMN,EAAM,wBAAwBM,CAAO,GAC3C,MAAMR,EAAA;AAAA,MACR;AAAA,MAEA,MAAM,mBAAmBS,GAAM;AAC7B,cAAMP,EAAM,mBAAmBO,CAAI,GACnC,MAAMT,EAAA;AAAA,MACR;AAAA,MAEA,MAAM,eAAeU,GAAO;AAC1B,cAAMR,EAAM,eAAeQ,CAAK,GAChC,MAAMV,EAAA;AAAA,MACR;AAAA,MAEA,MAAM,mBAAmB;AACvB,cAAME,EAAM,iBAAA,GACZ,MAAMF,EAAA;AAAA,MACR;AAAA;AAAA,MAIA,MAAM,WAAWW,GAAS;AACxB,cAAMT,EAAM,WAAWS,CAAO;AAC9B,cAAMC,IAAQb,EAAA;AACd,QAAAD,EAAI,EAAE,SAAS,EAAE,GAAGc,EAAM,SAAS,GAAGD,EAAA,GAAW;AAAA,MACnD;AAAA,MAEA,MAAM,eAAeA,GAAS;AAC5B,cAAMT,EAAM,eAAeS,CAAO;AAClC,cAAMC,IAAQb,EAAA;AACd,QAAAD,EAAI,EAAE,aAAa,EAAE,GAAGc,EAAM,aAAa,GAAGD,EAAA,GAAW;AAAA,MAC3D;AAAA,MAEA,MAAM,sBAAsB;AAC1B,cAAMT,EAAM,oBAAA,GAOZJ,EAAI,EAAE,SANiB;AAAA,UACrB,cAAc;AAAA,UACd,UAAU;AAAA,UACV,MAAM;AAAA,UACN,YAAY;AAAA,QAAA,GAEiB;AAAA,MACjC;AAAA,MAEA,MAAM,cAAca,GAAS;AAC3B,cAAMT,EAAM,cAAcS,CAAO;AACjC,cAAMC,IAAQb,EAAA;AACd,QAAAD,EAAI,EAAE,YAAY,EAAE,GAAGc,EAAM,YAAY,GAAGD,EAAA,GAAW;AAAA,MACzD;AAAA,MAEA,MAAM,uBAAuBE,GAAKC,GAAO;AACvC,cAAMZ,EAAM,uBAAuBW,GAAKC,CAAK;AAC7C,cAAMF,IAAQb,EAAA;AACd,QAAAD,EAAI,EAAE,aAAa,EAAE,GAAGc,EAAM,aAAa,CAACC,CAAG,GAAGC,EAAA,GAAS;AAAA,MAC7D;AAAA,MAEA,MAAM,qBAAqB;AACzB,cAAMZ,EAAM,mBAAA,GACZ,MAAMF,EAAA,GACN,MAAMG,EAAA;AAAA,MACR;AAAA;AAAA,MAGA,MAAM,eAAeY,GAAM;AACzB,cAAMb,EAAM,eAAea,CAAI,GAC/BjB,EAAI,EAAE,aAAaiB,GAAM;AAAA,MAC3B;AAAA,MAEA,MAAM,UAAUC,GAAQ;AACtB,cAAMd,EAAM,UAAUc,CAAM,GAC5BlB,EAAI,EAAE,QAAAkB,GAAQ;AAAA,MAChB;AAAA;AAAA,MAGA,MAAM,+BAA+BC,GAAMC,GAAQ;AACjD,cAAMhB,EAAM,+BAA+Be,GAAMC,CAAM;AACvD,cAAMN,IAAQb,EAAA;AACd,QAAAD,EAAI;AAAA,UACF,6BAA6B;AAAA,YAC3B,GAAGc,EAAM;AAAA,YACT,CAACK,CAAI,GAAGC;AAAA,UAAA;AAAA,QACV,CACD;AAAA,MACH;AAAA;AAAA,MAGA,aAAaX,GAAgB;;AAC3B,cAAMK,IAAQb,EAAA,GACRoB,IAAWP,EAAM,oBAAoBA,EAAM,WAAWA,EAAM,iBAAiB,IAAI;AAEvF,eAAO;AAAA,UACL,aAAYO,KAAA,gBAAAA,EAAU,eAAe,SAASZ,OAAW;AAAA,UACzD,cACEa,IAAAD,KAAA,gBAAAA,EAAU,YAAY,KAAK,CAACE,MAAWA,EAAE,WAAWd,OAApD,gBAAAa,EAA6D,eAAc;AAAA,QAAA;AAAA,MAEjF;AAAA,MAEA,eAAelB,EAAM,cAAc,KAAKA,CAAK;AAAA,MAC7C,oBAAoBA,EAAM,mBAAmB,KAAKA,CAAK;AAAA,MACvD,iBAAiBA,EAAM,gBAAgB,KAAKA,CAAK;AAAA;AAAA,MAGjD,MAAM,WAAW;AACf,cAAMF,EAAA;AAAA,MACR;AAAA,MAEA,MAAM,cAAc;AAClB,cAAME,EAAM,WAAA,GACZ,MAAMF,EAAA,GACNF,EAAI,EAAE,eAAe,IAAM;AAAA,MAC7B;AAAA,IAAA;AAAA,EAEJ;AACF;AAGO,SAASwB,IAAqB;AACnC,SAAO,CAACC,MAAkB,CAAChB,MACzBgB,EAAS,CAACX,MAAoCA,EAAM,aAAaL,CAAM,CAAC;AAC5E;"}
|
|
1
|
+
{"version":3,"file":"zustand-store.mjs","sources":["../../src/adapters/zustand-store.ts"],"sourcesContent":["/**\n * Zustand adapter (flat API)\n *\n * This file exposes a flat, unified Zustand store that mirrors the underlying\n * ORM store and keeps React state in sync. It is the low-level bridge.\n *\n * For a friendlier, domain-grouped API, use `createStructuredStore` from\n * `./structured-store`, which wraps this adapter and exposes nested actions\n * like `property.unit.favorites.toggle`, `filters.set`, etc.\n */\nimport { store } from \"../stores/store\";\nimport type { UnifiedStoreData, UserPropertyState, Filters, QueryParams, ResultsMode, SortBy, TourContactData, Unit } from \"../schema\";\n\n// Unified Zustand store interface\nexport interface ZustandUnifiedStoreState {\n // Property data\n properties: Record<string, UserPropertyState>;\n currentPropertyId: string | null;\n currentPropertySlug: string | null;\n hasPreviouslySearched: string[];\n\n // App data\n unitResults: Unit[];\n filters: Filters;\n tempFilters: Filters;\n apiFilters: QueryParams;\n resultsMode: ResultsMode;\n resolvedQuestionnaireValues: Record<string, string[]>;\n sortBy: SortBy;\n filtersLoaded: boolean;\n\n // === PROPERTY OPERATIONS ===\n initializeProperty: (propertyId: string, slug: string) => Promise<void>;\n setCurrentProperty: (propertyId: string, slug?: string) => Promise<void>;\n setCurrentPropertySlug: (slug: string) => Promise<void>;\n setHasPreviouslySearched: (slug: string) => Promise<void>;\n toggleFavorite: (unitId: string) => Promise<void>;\n markUnitAsViewed: (unitId: string, slug: string) => Promise<void>;\n setTourContactedOn: () => Promise<void>;\n getTourContactedOn: () => Promise<string | null>;\n setQuestionnaireResults: (results: unknown) => Promise<void>;\n setTourContactData: (data: TourContactData) => Promise<void>;\n setUnitResults: (units: unknown) => Promise<void>;\n clearUnitResults: () => Promise<void>;\n\n\n // === FILTER OPERATIONS ===\n setFilters: (filters: Partial<Filters>) => Promise<void>;\n setTempFilters: (filters: Partial<Filters>) => Promise<void>;\n setFiltersToDefault: () => Promise<void>;\n setApiFilters: (filters: Partial<QueryParams>) => Promise<void>;\n handleTempFilterChange: <K extends keyof Filters>(key: K, value: Filters[K]) => Promise<void>;\n submitFilterUpdate: () => Promise<void>;\n\n // === RESULTS AND SORTING ===\n setResultsMode: (mode: ResultsMode) => Promise<void>;\n setSortBy: (sortBy: SortBy) => Promise<void>;\n\n // === QUESTIONNAIRE ===\n setResolvedQuestionnaireValues: (name: string, values: string[]) => Promise<void>;\n\n // === UTILITY METHODS ===\n getUnitState: (unitId: string) => {\n isFavorite: boolean;\n viewedDate: string;\n };\n getResultsUrl: () => Promise<string | null>;\n getCurrentProperty: () => Promise<UserPropertyState | null>;\n getPropertyData: (propertyId?: string) => Promise<UserPropertyState | null>;\n\n // === INTERNAL ===\n _hydrate: () => Promise<void>;\n _initialize: () => Promise<void>;\n}\n\n/**\n * @deprecated For new apps, use `createStructuredStore` from `./structured-store`.\n * This flat adapter remains for migration/advanced cases.\n */\nexport function createZustandUnifiedStore(options?: {\n onFilterUpdate?: (apiParams: QueryParams) => void;\n}) {\n return (set: any, get: any): ZustandUnifiedStoreState => {\n // Helper to update local state after ORM operations\n const syncState = async () => {\n const ormState = await store.getFullState();\n set({\n properties: ormState.properties,\n currentPropertyId: ormState.currentPropertyId,\n currentPropertySlug: ormState.currentPropertySlug,\n hasPreviouslySearched: ormState.hasPreviouslySearched,\n unitResults: ormState.unitResults,\n filters: ormState.filters,\n tempFilters: ormState.tempFilters,\n apiFilters: ormState.apiFilters,\n resultsMode: ormState.resultsMode,\n resolvedQuestionnaireValues: ormState.resolvedQuestionnaireValues,\n sortBy: ormState.sortBy,\n });\n };\n\n // Helper to notify of filter updates\n const notifyFilterUpdate = async () => {\n if (options?.onFilterUpdate) {\n const apiFilters = (await store.getFullState()).apiFilters;\n options.onFilterUpdate(apiFilters);\n }\n };\n\n return {\n // Initial state\n properties: {},\n currentPropertyId: null,\n currentPropertySlug: null,\n hasPreviouslySearched: [],\n unitResults: [],\n filters: {\n date_availability: undefined,\n qty_bedrooms: undefined,\n base_price: undefined,\n highlights: undefined,\n },\n tempFilters: {\n date_availability: undefined,\n qty_bedrooms: undefined,\n base_price: undefined,\n highlights: undefined,\n },\n apiFilters: {\n limit: 10,\n page: 1,\n sortBy: \"relevance\",\n },\n resultsMode: \"all\",\n resolvedQuestionnaireValues: {},\n sortBy: \"relevance\",\n filtersLoaded: false,\n\n // === PROPERTY OPERATIONS ===\n async initializeProperty(propertyId, slug) {\n await store.initializeProperty(propertyId, slug);\n await syncState();\n },\n\n async setCurrentProperty(propertyId, slug) {\n await store.setCurrentProperty(propertyId, slug);\n set({\n currentPropertyId: propertyId,\n ...(slug && { currentPropertySlug: slug })\n });\n },\n\n async setCurrentPropertySlug(slug) {\n await store.setCurrentPropertySlug(slug);\n set({ currentPropertySlug: slug });\n },\n\n async setHasPreviouslySearched(slug) {\n await store.setHasPreviouslySearched(slug);\n await syncState();\n },\n\n async toggleFavorite(unitId) {\n await store.toggleFavorite(unitId);\n await syncState();\n },\n\n async markUnitAsViewed(unitId, slug) {\n await store.markUnitAsViewed(unitId, slug);\n await syncState();\n },\n\n async setTourContactedOn() {\n await store.setTourContactedOn();\n await syncState();\n },\n\n getTourContactedOn: store.getTourContactedOn.bind(store),\n\n async setQuestionnaireResults(results) {\n await store.setQuestionnaireResults(results);\n await syncState();\n },\n\n async setTourContactData(data) {\n await store.setTourContactData(data);\n await syncState();\n },\n\n async setUnitResults(units) {\n await store.setUnitResults(units);\n await syncState();\n },\n\n async clearUnitResults() {\n await store.clearUnitResults();\n await syncState();\n },\n\n\n // === FILTER OPERATIONS ===\n async setFilters(filters) {\n await store.setFilters(filters);\n const state = get();\n set({ filters: { ...state.filters, ...filters } });\n },\n\n async setTempFilters(filters) {\n await store.setTempFilters(filters);\n const state = get();\n set({ tempFilters: { ...state.tempFilters, ...filters } });\n },\n\n async setFiltersToDefault() {\n await store.setFiltersToDefault();\n const defaultFilters = {\n date_availability: undefined,\n qty_bedrooms: undefined,\n base_price: undefined,\n highlights: undefined,\n };\n set({ filters: defaultFilters });\n },\n\n async setApiFilters(filters) {\n await store.setApiFilters(filters);\n const state = get();\n set({ apiFilters: { ...state.apiFilters, ...filters } });\n },\n\n async handleTempFilterChange(key, value) {\n await store.handleTempFilterChange(key, value);\n const state = get();\n set({ tempFilters: { ...state.tempFilters, [key]: value } });\n },\n\n async submitFilterUpdate() {\n await store.submitFilterUpdate();\n await syncState();\n await notifyFilterUpdate();\n },\n\n // === RESULTS AND SORTING ===\n async setResultsMode(mode) {\n await store.setResultsMode(mode);\n set({ resultsMode: mode });\n },\n\n async setSortBy(sortBy) {\n await store.setSortBy(sortBy);\n set({ sortBy });\n },\n\n // === QUESTIONNAIRE ===\n async setResolvedQuestionnaireValues(name, values) {\n await store.setResolvedQuestionnaireValues(name, values);\n const state = get();\n set({\n resolvedQuestionnaireValues: {\n ...state.resolvedQuestionnaireValues,\n [name]: values,\n }\n });\n },\n\n // === UTILITY METHODS ===\n getUnitState(unitId: string) {\n const state = get();\n const property = state.currentPropertyId ? state.properties[state.currentPropertyId] : null;\n\n return {\n isFavorite: property?.favoritedUnits.includes(unitId) ?? false,\n viewedDate:\n property?.viewedUnits.find((u: any) => u.unitId === unitId)?.viewedDate ?? \"\",\n };\n },\n\n getResultsUrl: store.getResultsUrl.bind(store),\n getCurrentProperty: store.getCurrentProperty.bind(store),\n getPropertyData: store.getPropertyData.bind(store),\n\n // === INTERNAL ===\n async _hydrate() {\n await syncState();\n },\n\n async _initialize() {\n await store.initialize();\n await syncState();\n set({ filtersLoaded: true });\n },\n };\n };\n}\n\n// Helper hook factory for unit state\nexport function createUseUnitState() {\n return (useStore: any) => (unitId: string) =>\n useStore((state: ZustandUnifiedStoreState) => state.getUnitState(unitId));\n}\n\n// Export types for consuming apps\nexport type { UnitData, UserPropertyState, Filters, QueryParams, ResultsMode, SortBy, TourContactData, Unit } from \"../schema\";\n\n// Intentionally no alias exports in vNext; use `createStructuredStore` or `createZustandUnifiedStore` explicitly.\n"],"names":["createZustandUnifiedStore","options","set","get","syncState","ormState","store","notifyFilterUpdate","apiFilters","propertyId","slug","unitId","results","data","units","filters","state","key","value","mode","sortBy","name","values","property","_a","u","createUseUnitState","useStore"],"mappings":"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"}
|
package/dist/base/property.d.ts
CHANGED
|
@@ -33,11 +33,11 @@ export declare const PropertyModel: z.ZodObject<{
|
|
|
33
33
|
address_zip: string;
|
|
34
34
|
address_country: string;
|
|
35
35
|
slug?: string | null | undefined;
|
|
36
|
-
ingestionFileName?: string | null | undefined;
|
|
37
36
|
contact_name?: string | null | undefined;
|
|
38
37
|
contact_phone?: string | null | undefined;
|
|
39
38
|
notification_email?: string | null | undefined;
|
|
40
39
|
address_state?: string | null | undefined;
|
|
40
|
+
ingestionFileName?: string | null | undefined;
|
|
41
41
|
}, {
|
|
42
42
|
createdAt: Date;
|
|
43
43
|
status: Status;
|
|
@@ -52,9 +52,9 @@ export declare const PropertyModel: z.ZodObject<{
|
|
|
52
52
|
address_zip: string;
|
|
53
53
|
address_country: string;
|
|
54
54
|
slug?: string | null | undefined;
|
|
55
|
-
ingestionFileName?: string | null | undefined;
|
|
56
55
|
contact_name?: string | null | undefined;
|
|
57
56
|
contact_phone?: string | null | undefined;
|
|
58
57
|
notification_email?: string | null | undefined;
|
|
59
58
|
address_state?: string | null | undefined;
|
|
59
|
+
ingestionFileName?: string | null | undefined;
|
|
60
60
|
}>;
|
package/dist/base/unit.d.ts
CHANGED
|
@@ -21,37 +21,37 @@ export declare const UnitModel: z.ZodObject<{
|
|
|
21
21
|
}, "strip", z.ZodTypeAny, {
|
|
22
22
|
createdAt: Date;
|
|
23
23
|
status: Status;
|
|
24
|
+
qty_bedrooms: number;
|
|
25
|
+
base_price: number;
|
|
24
26
|
id: number;
|
|
25
27
|
title: string;
|
|
26
|
-
propertyId: number;
|
|
27
|
-
updatedAt: Date;
|
|
28
|
-
userId: number;
|
|
29
|
-
qty_bedrooms: number;
|
|
30
28
|
qty_bathrooms: number;
|
|
31
|
-
base_price: number;
|
|
32
29
|
dim_sq_ft: number;
|
|
30
|
+
propertyId: number;
|
|
33
31
|
is_available: boolean;
|
|
32
|
+
updatedAt: Date;
|
|
33
|
+
userId: number;
|
|
34
|
+
date_availability?: Date | null | undefined;
|
|
34
35
|
slug?: string | null | undefined;
|
|
35
36
|
unitSetAvailableOn?: Date | null | undefined;
|
|
36
37
|
floorPlanId?: number | null | undefined;
|
|
37
|
-
date_availability?: Date | null | undefined;
|
|
38
38
|
external_id?: string | null | undefined;
|
|
39
39
|
}, {
|
|
40
40
|
createdAt: Date;
|
|
41
41
|
status: Status;
|
|
42
|
+
qty_bedrooms: number;
|
|
43
|
+
base_price: number;
|
|
42
44
|
id: number;
|
|
43
45
|
title: string;
|
|
44
|
-
propertyId: number;
|
|
45
|
-
updatedAt: Date;
|
|
46
|
-
userId: number;
|
|
47
|
-
qty_bedrooms: number;
|
|
48
46
|
qty_bathrooms: number;
|
|
49
|
-
base_price: number;
|
|
50
47
|
dim_sq_ft: number;
|
|
48
|
+
propertyId: number;
|
|
51
49
|
is_available: boolean;
|
|
50
|
+
updatedAt: Date;
|
|
51
|
+
userId: number;
|
|
52
|
+
date_availability?: Date | null | undefined;
|
|
52
53
|
slug?: string | null | undefined;
|
|
53
54
|
unitSetAvailableOn?: Date | null | undefined;
|
|
54
55
|
floorPlanId?: number | null | undefined;
|
|
55
|
-
date_availability?: Date | null | undefined;
|
|
56
56
|
external_id?: string | null | undefined;
|
|
57
57
|
}>;
|
package/dist/base/user.d.ts
CHANGED
|
@@ -11,17 +11,17 @@ export declare const UserModel: z.ZodObject<{
|
|
|
11
11
|
}, "strip", z.ZodTypeAny, {
|
|
12
12
|
id: number;
|
|
13
13
|
email: string;
|
|
14
|
+
first_name: string;
|
|
15
|
+
last_name: string;
|
|
14
16
|
password: string;
|
|
15
17
|
salt: string;
|
|
16
18
|
role: UserRole;
|
|
17
|
-
first_name: string;
|
|
18
|
-
last_name: string;
|
|
19
19
|
}, {
|
|
20
20
|
id: number;
|
|
21
21
|
email: string;
|
|
22
|
+
first_name: string;
|
|
23
|
+
last_name: string;
|
|
22
24
|
password: string;
|
|
23
25
|
salt: string;
|
|
24
26
|
role: UserRole;
|
|
25
|
-
first_name: string;
|
|
26
|
-
last_name: string;
|
|
27
27
|
}>;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var M=Object.create;var
|
|
1
|
+
"use strict";var M=Object.create;var l=Object.defineProperty;var f=Object.getOwnPropertyDescriptor;var m=Object.getOwnPropertyNames;var v=Object.getPrototypeOf,P=Object.prototype.hasOwnProperty;var b=(e,t,r,i)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of m(t))!P.call(e,o)&&o!==r&&l(e,o,{get:()=>t[o],enumerable:!(i=f(t,o))||i.enumerable});return e};var y=(e,t,r)=>(r=e!=null?M(v(e)):{},b(t||!e||!e.__esModule?l(r,"default",{value:e,enumerable:!0}):r,e));Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const E=require("react/jsx-runtime"),a=require("react"),U=require("./generateUserUUID.cjs"),u=()=>({track:()=>{},identify:()=>{}}),p=a.createContext(u()),w=({children:e,token:t,envMode:r})=>{const[i,o]=a.useState(u());return a.useEffect(()=>{const s=(r??"production").toLowerCase(),d=s==="development"||s==="staging",x=s==="development",c="Mixpanel token not set. Pass a token prop to MixpanelProvider or define VITE_MIXPANEL_TOKEN.";if(!t){d?console.error(`❌ ${c}`):console.warn(`⚠️ ${c}`);return}(async()=>{try{const{default:n}=await import("mixpanel-browser");n.init(t,{debug:x,persistence:"localStorage",autocapture:{pageview:"full-url",click:!0,input:!0,rage_click:!0,scroll:!0,submit:!0,capture_text_content:!1}}),o(n);const g=await U.generateUserUUID;n.identify(g)}catch(n){console.error("❌ Failed to initialize Mixpanel:",n)}})()},[r,t]),E.jsx(p.Provider,{value:i,children:e})},_=()=>a.useContext(p);exports.MixpanelProvider=w;exports.useMixpanel=_;
|
|
2
2
|
//# sourceMappingURL=MixpanelProvider.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MixpanelProvider.cjs","sources":["../../../src/features/analytics/MixpanelProvider.tsx"],"sourcesContent":["import React, { createContext, useContext, useEffect, useState } from \"react\";\n\nimport { generateUserUUID } from \"./generateUserUUID\";\n\n// Hold the default export instance type from mixpanel-browser, not the module namespace\ntype MixpanelInstance = typeof import(\"mixpanel-browser\")[\"default\"];\nconst MixpanelContext = createContext<MixpanelInstance
|
|
1
|
+
{"version":3,"file":"MixpanelProvider.cjs","sources":["../../../src/features/analytics/MixpanelProvider.tsx"],"sourcesContent":["import React, { createContext, useContext, useEffect, useState } from \"react\";\n\nimport { generateUserUUID } from \"./generateUserUUID\";\n\n// Hold the default export instance type from mixpanel-browser, not the module namespace\ntype MixpanelInstance = typeof import(\"mixpanel-browser\")[\"default\"];\n\n// Provide a safe no-op mixpanel instance until real one is ready\nconst createNoopMixpanel = (): MixpanelInstance =>\n ({\n // minimal surface used by the app\n track: () => undefined,\n identify: () => undefined,\n } as unknown as MixpanelInstance);\n\nconst MixpanelContext = createContext<MixpanelInstance>(createNoopMixpanel());\n\ninterface MixpanelProviderProps {\n children: React.ReactNode;\n token?: string;\n envMode?: string;\n}\n\nexport const MixpanelProvider = ({ children, token, envMode }: MixpanelProviderProps) => {\n const [mp, setMp] = useState<MixpanelInstance>(createNoopMixpanel());\n\n useEffect(() => {\n const normalizedMode = (envMode ?? \"production\").toLowerCase();\n const shouldError =\n normalizedMode === \"development\" || normalizedMode === \"staging\";\n const debugEnabled = normalizedMode === \"development\";\n\n const message =\n \"Mixpanel token not set. Pass a token prop to MixpanelProvider or define VITE_MIXPANEL_TOKEN.\";\n\n if (!token) {\n if (shouldError) {\n console.error(`❌ ${message}`);\n } else {\n console.warn(`⚠️ ${message}`);\n }\n return;\n }\n (async () => {\n try {\n const { default: mixpanel } = await import(\"mixpanel-browser\");\n mixpanel.init(token, {\n debug: debugEnabled,\n persistence: \"localStorage\",\n autocapture: {\n pageview: \"full-url\",\n click: true,\n input: true,\n rage_click: true,\n scroll: true,\n submit: true,\n capture_text_content: false,\n },\n });\n setMp(mixpanel);\n\n const uuid = await generateUserUUID;\n mixpanel.identify(uuid);\n } catch (err) {\n console.error(\"❌ Failed to initialize Mixpanel:\", err);\n }\n })();\n }, [envMode, token]);\n\n return <MixpanelContext.Provider value={mp}>{children}</MixpanelContext.Provider>;\n};\n\nexport const useMixpanel = () => {\n // Always returns a valid instance (noop before real init)\n return useContext(MixpanelContext);\n};\n"],"names":["createNoopMixpanel","MixpanelContext","createContext","MixpanelProvider","children","token","envMode","mp","setMp","useState","useEffect","normalizedMode","shouldError","debugEnabled","message","mixpanel","uuid","generateUserUUID","err","useMixpanel","useContext"],"mappings":"unBAQMA,EAAqB,KACxB,CAEC,MAAO,IAAA,GACP,SAAU,IAAA,EACZ,GAEIC,EAAkBC,EAAAA,cAAgCF,GAAoB,EAQ/DG,EAAmB,CAAC,CAAE,SAAAC,EAAU,MAAAC,EAAO,QAAAC,KAAqC,CACvF,KAAM,CAACC,EAAIC,CAAK,EAAIC,EAAAA,SAA2BT,GAAoB,EAEnEU,OAAAA,EAAAA,UAAU,IAAM,CACd,MAAMC,GAAkBL,GAAW,cAAc,YAAA,EAC3CM,EACJD,IAAmB,eAAiBA,IAAmB,UACnDE,EAAeF,IAAmB,cAElCG,EACJ,+FAEF,GAAI,CAACT,EAAO,CACNO,EACF,QAAQ,MAAM,KAAKE,CAAO,EAAE,EAE5B,QAAQ,KAAK,MAAMA,CAAO,EAAE,EAE9B,MACF,EACC,SAAY,CACX,GAAI,CACF,KAAM,CAAE,QAASC,GAAa,KAAM,QAAO,kBAAkB,EAC7DA,EAAS,KAAKV,EAAO,CACnB,MAAOQ,EACP,YAAa,eACb,YAAa,CACX,SAAU,WACV,MAAO,GACP,MAAO,GACP,WAAY,GACZ,OAAQ,GACR,OAAQ,GACR,qBAAsB,EAAA,CACxB,CACD,EACDL,EAAMO,CAAQ,EAEd,MAAMC,EAAO,MAAMC,EAAAA,iBACnBF,EAAS,SAASC,CAAI,CACxB,OAASE,EAAK,CACZ,QAAQ,MAAM,mCAAoCA,CAAG,CACvD,CACF,GAAA,CACF,EAAG,CAACZ,EAASD,CAAK,CAAC,QAEXJ,EAAgB,SAAhB,CAAyB,MAAOM,EAAK,SAAAH,EAAS,CACxD,EAEae,EAAc,IAElBC,EAAAA,WAAWnB,CAAe"}
|
|
@@ -1,19 +1,25 @@
|
|
|
1
|
-
import { jsx as
|
|
2
|
-
import { useState as x, useEffect as
|
|
3
|
-
import { generateUserUUID as
|
|
4
|
-
const
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
1
|
+
import { jsx as m } from "react/jsx-runtime";
|
|
2
|
+
import { useState as x, useEffect as f, createContext as g, useContext as M } from "react";
|
|
3
|
+
import { generateUserUUID as v } from "./generateUserUUID.mjs";
|
|
4
|
+
const i = () => ({
|
|
5
|
+
// minimal surface used by the app
|
|
6
|
+
track: () => {
|
|
7
|
+
},
|
|
8
|
+
identify: () => {
|
|
9
|
+
}
|
|
10
|
+
}), a = g(i()), _ = ({ children: s, token: t, envMode: r }) => {
|
|
11
|
+
const [c, l] = x(i());
|
|
12
|
+
return f(() => {
|
|
13
|
+
const o = (r ?? "production").toLowerCase(), u = o === "development" || o === "staging", p = o === "development", n = "Mixpanel token not set. Pass a token prop to MixpanelProvider or define VITE_MIXPANEL_TOKEN.";
|
|
14
|
+
if (!t) {
|
|
15
|
+
u ? console.error(`❌ ${n}`) : console.warn(`⚠️ ${n}`);
|
|
10
16
|
return;
|
|
11
17
|
}
|
|
12
18
|
(async () => {
|
|
13
19
|
try {
|
|
14
20
|
const { default: e } = await import("mixpanel-browser");
|
|
15
|
-
e.init(
|
|
16
|
-
debug:
|
|
21
|
+
e.init(t, {
|
|
22
|
+
debug: p,
|
|
17
23
|
persistence: "localStorage",
|
|
18
24
|
autocapture: {
|
|
19
25
|
pageview: "full-url",
|
|
@@ -25,20 +31,16 @@ const s = f(null), P = ({ children: t, token: r, envMode: n }) => {
|
|
|
25
31
|
capture_text_content: !1
|
|
26
32
|
}
|
|
27
33
|
}), l(e);
|
|
28
|
-
const
|
|
29
|
-
e.identify(
|
|
34
|
+
const d = await v;
|
|
35
|
+
e.identify(d);
|
|
30
36
|
} catch (e) {
|
|
31
37
|
console.error("❌ Failed to initialize Mixpanel:", e);
|
|
32
38
|
}
|
|
33
39
|
})();
|
|
34
|
-
}, [
|
|
35
|
-
}, b = () =>
|
|
36
|
-
const t = M(s);
|
|
37
|
-
if (!t) throw new Error("useMixpanel must be used within MixpanelProvider");
|
|
38
|
-
return t;
|
|
39
|
-
};
|
|
40
|
+
}, [r, t]), /* @__PURE__ */ m(a.Provider, { value: c, children: s });
|
|
41
|
+
}, b = () => M(a);
|
|
40
42
|
export {
|
|
41
|
-
|
|
43
|
+
_ as MixpanelProvider,
|
|
42
44
|
b as useMixpanel
|
|
43
45
|
};
|
|
44
46
|
//# sourceMappingURL=MixpanelProvider.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MixpanelProvider.mjs","sources":["../../../src/features/analytics/MixpanelProvider.tsx"],"sourcesContent":["import React, { createContext, useContext, useEffect, useState } from \"react\";\n\nimport { generateUserUUID } from \"./generateUserUUID\";\n\n// Hold the default export instance type from mixpanel-browser, not the module namespace\ntype MixpanelInstance = typeof import(\"mixpanel-browser\")[\"default\"];\nconst MixpanelContext = createContext<MixpanelInstance
|
|
1
|
+
{"version":3,"file":"MixpanelProvider.mjs","sources":["../../../src/features/analytics/MixpanelProvider.tsx"],"sourcesContent":["import React, { createContext, useContext, useEffect, useState } from \"react\";\n\nimport { generateUserUUID } from \"./generateUserUUID\";\n\n// Hold the default export instance type from mixpanel-browser, not the module namespace\ntype MixpanelInstance = typeof import(\"mixpanel-browser\")[\"default\"];\n\n// Provide a safe no-op mixpanel instance until real one is ready\nconst createNoopMixpanel = (): MixpanelInstance =>\n ({\n // minimal surface used by the app\n track: () => undefined,\n identify: () => undefined,\n } as unknown as MixpanelInstance);\n\nconst MixpanelContext = createContext<MixpanelInstance>(createNoopMixpanel());\n\ninterface MixpanelProviderProps {\n children: React.ReactNode;\n token?: string;\n envMode?: string;\n}\n\nexport const MixpanelProvider = ({ children, token, envMode }: MixpanelProviderProps) => {\n const [mp, setMp] = useState<MixpanelInstance>(createNoopMixpanel());\n\n useEffect(() => {\n const normalizedMode = (envMode ?? \"production\").toLowerCase();\n const shouldError =\n normalizedMode === \"development\" || normalizedMode === \"staging\";\n const debugEnabled = normalizedMode === \"development\";\n\n const message =\n \"Mixpanel token not set. Pass a token prop to MixpanelProvider or define VITE_MIXPANEL_TOKEN.\";\n\n if (!token) {\n if (shouldError) {\n console.error(`❌ ${message}`);\n } else {\n console.warn(`⚠️ ${message}`);\n }\n return;\n }\n (async () => {\n try {\n const { default: mixpanel } = await import(\"mixpanel-browser\");\n mixpanel.init(token, {\n debug: debugEnabled,\n persistence: \"localStorage\",\n autocapture: {\n pageview: \"full-url\",\n click: true,\n input: true,\n rage_click: true,\n scroll: true,\n submit: true,\n capture_text_content: false,\n },\n });\n setMp(mixpanel);\n\n const uuid = await generateUserUUID;\n mixpanel.identify(uuid);\n } catch (err) {\n console.error(\"❌ Failed to initialize Mixpanel:\", err);\n }\n })();\n }, [envMode, token]);\n\n return <MixpanelContext.Provider value={mp}>{children}</MixpanelContext.Provider>;\n};\n\nexport const useMixpanel = () => {\n // Always returns a valid instance (noop before real init)\n return useContext(MixpanelContext);\n};\n"],"names":["createNoopMixpanel","MixpanelContext","createContext","MixpanelProvider","children","token","envMode","mp","setMp","useState","useEffect","normalizedMode","shouldError","debugEnabled","message","mixpanel","uuid","generateUserUUID","err","useMixpanel","useContext"],"mappings":";;;AAQA,MAAMA,IAAqB,OACxB;AAAA;AAAA,EAEC,OAAO,MAAA;AAAA;AAAA,EACP,UAAU,MAAA;AAAA;AACZ,IAEIC,IAAkBC,EAAgCF,GAAoB,GAQ/DG,IAAmB,CAAC,EAAE,UAAAC,GAAU,OAAAC,GAAO,SAAAC,QAAqC;AACvF,QAAM,CAACC,GAAIC,CAAK,IAAIC,EAA2BT,GAAoB;AAEnE,SAAAU,EAAU,MAAM;AACd,UAAMC,KAAkBL,KAAW,cAAc,YAAA,GAC3CM,IACJD,MAAmB,iBAAiBA,MAAmB,WACnDE,IAAeF,MAAmB,eAElCG,IACJ;AAEF,QAAI,CAACT,GAAO;AACV,MAAIO,IACF,QAAQ,MAAM,KAAKE,CAAO,EAAE,IAE5B,QAAQ,KAAK,MAAMA,CAAO,EAAE;AAE9B;AAAA,IACF;AACA,KAAC,YAAY;AACX,UAAI;AACF,cAAM,EAAE,SAASC,MAAa,MAAM,OAAO,kBAAkB;AAC7D,QAAAA,EAAS,KAAKV,GAAO;AAAA,UACnB,OAAOQ;AAAA,UACP,aAAa;AAAA,UACb,aAAa;AAAA,YACX,UAAU;AAAA,YACV,OAAO;AAAA,YACP,OAAO;AAAA,YACP,YAAY;AAAA,YACZ,QAAQ;AAAA,YACR,QAAQ;AAAA,YACR,sBAAsB;AAAA,UAAA;AAAA,QACxB,CACD,GACDL,EAAMO,CAAQ;AAEd,cAAMC,IAAO,MAAMC;AACnB,QAAAF,EAAS,SAASC,CAAI;AAAA,MACxB,SAASE,GAAK;AACZ,gBAAQ,MAAM,oCAAoCA,CAAG;AAAA,MACvD;AAAA,IACF,GAAA;AAAA,EACF,GAAG,CAACZ,GAASD,CAAK,CAAC,qBAEXJ,EAAgB,UAAhB,EAAyB,OAAOM,GAAK,UAAAH,GAAS;AACxD,GAEae,IAAc,MAElBC,EAAWnB,CAAe;"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const w={priceLowToHigh:"cost_low_to_high",priceHighToLow:"cost_high_to_low",cost_low_to_high:"cost_low_to_high",cost_high_to_low:"cost_high_to_low",newest:"newest",relevance:"relevance"},E=10,L=1,M="relevance",b=r=>r!=null&&typeof r=="object"&&"value"in r,P=r=>Array.isArray(r)?r.flat():r!=null?[r]:[],h=r=>{const t=P(r).map(e=>{if(e!=null){if(typeof e=="string")return e;if(typeof e=="number"||typeof e=="boolean")return String(e)}}).filter(e=>typeof e=="string"&&e.length>0);return t.length?Array.from(new Set(t)):void 0},T=r=>{const t=P(r).map(e=>{if(typeof e=="number"&&Number.isFinite(e))return e;if(typeof e=="string"&&e.trim()!==""){const o=Number.parseInt(e,10);return Number.isFinite(o)?o:void 0}}).filter(e=>typeof e=="number");return t.length?Array.from(new Set(t)):void 0},g=r=>{if(typeof r=="number"&&Number.isFinite(r))return r;if(typeof r=="string"&&r.trim()!==""){const t=Number.parseFloat(r);if(Number.isFinite(t))return t}return null},A=r=>{const t=r.flatMap(e=>h(e)??[]).filter(e=>e.length>0);return t.length?Array.from(new Set(t)):void 0},N=r=>{const t={};return Object.entries(r??{}).forEach(([e,o])=>{if(!["page","sortBy","limit"].includes(e))if(Array.isArray(o))if(o.every(n=>b(n))){const n=o.map(l=>l.value);t[e]=n.some(Array.isArray)?n.flat():n}else t[e]=o.flat();else b(o)?t[e]=o.value:t[e]=e==="base_price"&&o==null?15e3:o}),t},F=(r,{dropSource:t=!0}={})=>{const e={...r};return Object.entries(r??{}).forEach(([o,n])=>{if(!Array.isArray(n))return;const l=n.filter(i=>b(i)&&i.bodyKey);l.length&&(l.forEach(i=>{const a=String(i.bodyKey??"");if(!a||a===o)return;const s=Array.isArray(i.value)?i.value:i.value!==void 0?[i.value]:[],f=e[a],d=Array.from(new Set([...Array.isArray(f)?f:f!=null?[f]:[],...s]));e[a]=d}),t&&delete e[o])}),e},O=(r,t,e)=>{if(typeof r=="string"&&r.length>0){const o=t[r];if(o)return o;if(r==="relevance"||r==="newest"||r==="cost_low_to_high"||r==="cost_high_to_low")return r}return e},U=r=>{const t=N(F(r)),e=A([t.date_availability]),o=T(t.qty_bedrooms);return{base_price:g(t.base_price),date_availability:e,qty_bedrooms:o,highlights:h(t.highlights)}},v=(r,t={})=>{const{defaultLimit:e,defaultPage:o,defaultSort:n,sortParamMap:l}=t,i={...w,...l??{}},a=F(r),s=N(a),f=g(r.limit)??g(a.limit),d=g(r.page)??g(a.page),u=A([s.highlights,s.preferredEnvironment,s.spaceUsage]),y=T(s.qty_bedrooms),S=g(s.base_price),m=A([s.date_availability]),B=O(r.sortBy,i,n??M),c={limit:f??e??E,page:d??o??L,sortBy:B};S!=null&&(c.base_price=S),m&&m.length>0&&(c.date_availability=m),y&&y.length>0&&(c.qty_bedrooms=y),u&&u.length>0&&(c.highlights=u);const p=h(s.nearBuilding);p&&p.length>0&&(c.nearBuilding=p);const _=h(s.nearNeighbourhood);return _&&_.length>0&&(c.nearNeighbourhood=_),c},j={...w};exports.defaultSortParamMap=j;exports.transformFiltersToPreferences=U;exports.transformFiltersToUnitsSearchParams=v;
|
|
2
|
+
//# sourceMappingURL=transformers.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transformers.cjs","sources":["../../../src/features/filters/transformers.ts"],"sourcesContent":["import type { SortBy } from \"../../schema\";\n\ntype RawFilters = Record<string, unknown>;\n\nconst DEFAULT_SORT_PARAM_MAP: Record<string, SortBy> = {\n priceLowToHigh: \"cost_low_to_high\",\n priceHighToLow: \"cost_high_to_low\",\n cost_low_to_high: \"cost_low_to_high\",\n cost_high_to_low: \"cost_high_to_low\",\n newest: \"newest\",\n relevance: \"relevance\",\n};\n\nconst DEFAULT_LIMIT = 10;\nconst DEFAULT_PAGE = 1;\nconst DEFAULT_SORT: SortBy = \"relevance\";\n\nconst isObjectWithValue = (\n value: unknown,\n): value is { value: unknown; bodyKey?: unknown } =>\n value != null && typeof value === \"object\" && \"value\" in value;\n\nconst toArray = (value: unknown): unknown[] => {\n if (Array.isArray(value)) return value.flat();\n return value != null ? [value] : [];\n};\n\nconst toStringArray = (value: unknown): string[] | undefined => {\n const mapped = toArray(value)\n .map((item) => {\n if (item == null) return undefined;\n if (typeof item === \"string\") return item;\n if (typeof item === \"number\" || typeof item === \"boolean\") {\n return String(item);\n }\n return undefined;\n })\n .filter((item): item is string => typeof item === \"string\" && item.length > 0);\n return mapped.length ? Array.from(new Set(mapped)) : undefined;\n};\n\nconst toNumberArray = (value: unknown): number[] | undefined => {\n const mapped = toArray(value)\n .map((item) => {\n if (typeof item === \"number\" && Number.isFinite(item)) return item;\n if (typeof item === \"string\" && item.trim() !== \"\") {\n const parsed = Number.parseInt(item, 10);\n return Number.isFinite(parsed) ? parsed : undefined;\n }\n return undefined;\n })\n .filter((item): item is number => typeof item === \"number\");\n return mapped.length ? Array.from(new Set(mapped)) : undefined;\n};\n\nconst toNumberOrNull = (value: unknown): number | null => {\n if (typeof value === \"number\" && Number.isFinite(value)) return value;\n if (typeof value === \"string\" && value.trim() !== \"\") {\n const parsed = Number.parseFloat(value);\n if (Number.isFinite(parsed)) return parsed;\n }\n return null;\n};\n\nconst mergeHighlightSources = (values: unknown[]): string[] | undefined => {\n const merged = values\n .flatMap((value) => toStringArray(value) ?? [])\n .filter((item) => item.length > 0);\n return merged.length ? Array.from(new Set(merged)) : undefined;\n};\n\nconst normalizeRawFilters = (filters: RawFilters): Record<string, unknown> => {\n const result: Record<string, unknown> = {};\n\n Object.entries(filters ?? {}).forEach(([key, val]) => {\n if ([\"page\", \"sortBy\", \"limit\"].includes(key)) return;\n if (Array.isArray(val)) {\n if (val.every((v) => isObjectWithValue(v))) {\n const mapped = val.map((v) => (v as { value: unknown }).value);\n result[key] = mapped.some(Array.isArray) ? mapped.flat() : mapped;\n } else {\n result[key] = val.flat();\n }\n } else if (isObjectWithValue(val)) {\n result[key] = val.value;\n } else {\n result[key] = key === \"base_price\" && val == null ? 15000 : val;\n }\n });\n\n return result;\n};\n\nconst redirectByBodyKey = (\n raw: RawFilters,\n { dropSource = true }: { dropSource?: boolean } = {},\n): Record<string, unknown> => {\n const draft: Record<string, unknown> = { ...raw };\n\n Object.entries(raw ?? {}).forEach(([prop, arr]) => {\n if (!Array.isArray(arr)) return;\n\n const items = arr.filter((it) => isObjectWithValue(it) && it.bodyKey);\n if (!items.length) return;\n\n items.forEach((it: any) => {\n const target = String(it.bodyKey ?? \"\");\n if (!target || target === prop) return;\n\n const vals = Array.isArray(it.value)\n ? it.value\n : it.value !== undefined\n ? [it.value]\n : [];\n\n const existing = draft[target];\n const merged = Array.from(\n new Set([\n ...(Array.isArray(existing)\n ? existing\n : existing != null\n ? [existing]\n : []),\n ...vals,\n ]),\n );\n\n draft[target] = merged;\n });\n\n if (dropSource) {\n delete draft[prop];\n }\n });\n\n return draft;\n};\n\nconst resolveSortBy = (\n value: unknown,\n sortParamMap: Record<string, SortBy>,\n defaultSort: SortBy,\n): SortBy => {\n if (typeof value === \"string\" && value.length > 0) {\n const mapped = sortParamMap[value];\n if (mapped) return mapped;\n if (\n value === \"relevance\" ||\n value === \"newest\" ||\n value === \"cost_low_to_high\" ||\n value === \"cost_high_to_low\"\n ) {\n return value;\n }\n }\n return defaultSort;\n};\n\nexport interface FilterPreferences {\n base_price: number | null;\n date_availability?: string[];\n qty_bedrooms?: number[];\n highlights?: string[];\n}\n\nexport interface UnitsSearchRequest {\n limit: number;\n page: number;\n sortBy: SortBy;\n base_price?: number | null;\n date_availability?: string[];\n qty_bedrooms?: number[];\n highlights?: string[];\n nearBuilding?: string[];\n nearNeighbourhood?: string[];\n}\n\nexport interface TransformUnitsSearchOptions {\n defaultLimit?: number;\n defaultPage?: number;\n defaultSort?: SortBy;\n sortParamMap?: Record<string, SortBy>;\n}\n\nexport const transformFiltersToPreferences = (\n rawFilters: RawFilters,\n): FilterPreferences => {\n const normalized = normalizeRawFilters(redirectByBodyKey(rawFilters));\n\n const mergedAvailability = mergeHighlightSources([\n normalized.date_availability,\n ]);\n const mergedBedrooms = toNumberArray(normalized.qty_bedrooms);\n const basePrice = toNumberOrNull(normalized.base_price);\n\n return {\n base_price: basePrice,\n date_availability: mergedAvailability,\n qty_bedrooms: mergedBedrooms,\n highlights: toStringArray(normalized.highlights),\n };\n};\n\nexport const transformFiltersToUnitsSearchParams = (\n rawFilters: RawFilters,\n options: TransformUnitsSearchOptions = {},\n): UnitsSearchRequest => {\n const { defaultLimit, defaultPage, defaultSort, sortParamMap } = options;\n const map = { ...DEFAULT_SORT_PARAM_MAP, ...(sortParamMap ?? {}) };\n const remapped = redirectByBodyKey(rawFilters);\n const normalized = normalizeRawFilters(remapped);\n\n const limitCandidate =\n toNumberOrNull((rawFilters as Record<string, unknown>).limit) ??\n toNumberOrNull(remapped.limit);\n const pageCandidate =\n toNumberOrNull((rawFilters as Record<string, unknown>).page) ??\n toNumberOrNull(remapped.page);\n\n const highlights = mergeHighlightSources([\n normalized.highlights,\n normalized.preferredEnvironment,\n normalized.spaceUsage,\n ]);\n const bedrooms = toNumberArray(normalized.qty_bedrooms);\n const base_price = toNumberOrNull(normalized.base_price);\n const date_availability = mergeHighlightSources([\n normalized.date_availability,\n ]);\n\n const sortBy = resolveSortBy(\n (rawFilters as Record<string, unknown>).sortBy,\n map,\n defaultSort ?? DEFAULT_SORT,\n );\n\n const payload: UnitsSearchRequest = {\n limit: limitCandidate ?? defaultLimit ?? DEFAULT_LIMIT,\n page: pageCandidate ?? defaultPage ?? DEFAULT_PAGE,\n sortBy,\n };\n\n if (base_price != null) {\n payload.base_price = base_price;\n }\n\n if (date_availability && date_availability.length > 0) {\n payload.date_availability = date_availability;\n }\n\n if (bedrooms && bedrooms.length > 0) {\n payload.qty_bedrooms = bedrooms;\n }\n\n if (highlights && highlights.length > 0) {\n payload.highlights = highlights;\n }\n\n const nearBuilding = toStringArray(normalized.nearBuilding);\n if (nearBuilding && nearBuilding.length > 0) {\n payload.nearBuilding = nearBuilding;\n }\n\n const nearNeighbourhood = toStringArray(normalized.nearNeighbourhood);\n if (nearNeighbourhood && nearNeighbourhood.length > 0) {\n payload.nearNeighbourhood = nearNeighbourhood;\n }\n\n return payload;\n};\n\nexport const defaultSortParamMap = { ...DEFAULT_SORT_PARAM_MAP };\n"],"names":["DEFAULT_SORT_PARAM_MAP","DEFAULT_LIMIT","DEFAULT_PAGE","DEFAULT_SORT","isObjectWithValue","value","toArray","toStringArray","mapped","item","toNumberArray","parsed","toNumberOrNull","mergeHighlightSources","values","merged","normalizeRawFilters","filters","result","key","val","v","redirectByBodyKey","raw","dropSource","draft","prop","arr","items","it","target","vals","existing","resolveSortBy","sortParamMap","defaultSort","transformFiltersToPreferences","rawFilters","normalized","mergedAvailability","mergedBedrooms","transformFiltersToUnitsSearchParams","options","defaultLimit","defaultPage","map","remapped","limitCandidate","pageCandidate","highlights","bedrooms","base_price","date_availability","sortBy","payload","nearBuilding","nearNeighbourhood","defaultSortParamMap"],"mappings":"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"}
|