@superbright/indexeddb-orm 1.0.30 → 1.0.31
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/dist/adapters/zustand-store.cjs +1 -1
- package/dist/adapters/zustand-store.cjs.map +1 -1
- package/dist/adapters/zustand-store.d.ts +2 -6
- package/dist/adapters/zustand-store.mjs +212 -167
- package/dist/adapters/zustand-store.mjs.map +1 -1
- package/dist/base/enums.cjs +1 -1
- package/dist/base/enums.cjs.map +1 -1
- package/dist/base/enums.d.ts +4 -0
- package/dist/base/enums.mjs +2 -1
- package/dist/base/enums.mjs.map +1 -1
- package/dist/base/userinquiry.d.ts +23 -0
- package/dist/base/visitor.d.ts +17 -0
- package/dist/base/visitorfilter.d.ts +25 -0
- package/dist/base/visitorquestionnaire.d.ts +25 -0
- package/dist/base/visitorunitengagement.d.ts +24 -0
- package/dist/features/units/transformers.cjs.map +1 -1
- package/dist/features/units/transformers.d.ts +2 -0
- package/dist/features/units/transformers.mjs.map +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.d.ts +1 -5
- package/dist/index.mjs +111 -127
- 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 +13 -41
- package/dist/schema.mjs +63 -74
- 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.d.ts +3 -21
- package/dist/stores/store.mjs +72 -120
- package/dist/stores/store.mjs.map +1 -1
- package/package.json +1 -1
- package/dist/api/favorites.cjs +0 -2
- package/dist/api/favorites.cjs.map +0 -1
- package/dist/api/favorites.d.ts +0 -4
- package/dist/api/favorites.mjs +0 -34
- package/dist/api/favorites.mjs.map +0 -1
- package/dist/api/properties.cjs +0 -2
- package/dist/api/properties.cjs.map +0 -1
- package/dist/api/properties.d.ts +0 -22
- package/dist/api/properties.mjs +0 -197
- package/dist/api/properties.mjs.map +0 -1
- package/dist/api/users.cjs +0 -2
- package/dist/api/users.cjs.map +0 -1
- package/dist/api/users.d.ts +0 -5
- package/dist/api/users.mjs +0 -54
- package/dist/api/users.mjs.map +0 -1
- package/dist/units/favorites.cjs +0 -2
- package/dist/units/favorites.cjs.map +0 -1
- package/dist/units/favorites.d.ts +0 -7
- package/dist/units/favorites.mjs +0 -19
- package/dist/units/favorites.mjs.map +0 -1
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const p=require("../features/filters/transformers.cjs"),y=require("../validation.cjs"),f=require("../schema.cjs"),u={date_availability:void 0,qty_bedrooms:void 0,base_price:void 0,highlights:void 0};function v(l){return(n,s)=>({properties:{},currentPropertyId:null,currentPropertySlug:null,hasPreviouslySearched:[],favorite_unit_ids:[],unitResults:[],filters:{...u},tempFilters:{...u},apiFilters:{limit:10,page:1,sortBy:"relevance"},resultsMode:"all",resolvedQuestionnaireValues:{},sortBy:"relevance",filtersLoaded:!1,async initializeProperty(e,r){const{properties:t}=s();if(t[e]){n({currentPropertyId:e,currentPropertySlug:r});return}n({currentPropertyId:e,currentPropertySlug:r,properties:{...t,[e]:{id:e,slug:r,tourContactedOn:null,viewedUnits:[],questionnaireResults:null,tourContactData:null}}})},async setCurrentProperty(e,r){n({currentPropertyId:e,...r&&{currentPropertySlug:r}})},async setCurrentPropertySlug(e){n({currentPropertySlug:e})},async setHasPreviouslySearched(e){const{hasPreviouslySearched:r}=s();n({hasPreviouslySearched:Array.from(new Set([...r,e]))})},async setFavoriteUnitIds(e){n({favorite_unit_ids:e})},async toggleFavorite(e){const{favorite_unit_ids:r}=s(),t=r.includes(e);n({favorite_unit_ids:t?r.filter(i=>i!==e):[...r,e]})},async markUnitAsViewed(e,r){window.open(r,"_blank","noopener,noreferrer");const t=new Date,i=`${String(t.getMonth()+1).padStart(2,"0")}/${String(t.getDate()).padStart(2,"0")}`,{currentPropertyId:a,properties:o}=s();if(!a||!o[a])return;const c=o[a];n({properties:{...o,[a]:{...c,viewedUnits:[...c.viewedUnits.filter(d=>d.unitId!==e),{unitId:e,viewedDate:i}]}}})},async setTourContactedOn(){const{currentPropertyId:e,properties:r}=s();!e||!r[e]||n({properties:{...r,[e]:{...r[e],tourContactedOn:new Date().toISOString()}}})},async getTourContactedOn(){var t;const{currentPropertyId:e,properties:r}=s();return e?((t=r[e])==null?void 0:t.tourContactedOn)??null:null},async setQuestionnaireResults(e){const{currentPropertyId:r,properties:t}=s();!r||!t[r]||n({properties:{...t,[r]:{...t[r],questionnaireResults:e}}})},async setTourContactData(e){const{currentPropertyId:r,properties:t}=s();!r||!t[r]||n({properties:{...t,[r]:{...t[r],tourContactData:e}}})},async setUnitResults(e){const r=Array.isArray(e)?e:e&&typeof e=="object"?Object.values(e):[],t=[];r.forEach((i,a)=>{const o=y.validate(f.UnitSchema,i,`unitResults[${a}]`);o&&t.push(o)}),n({unitResults:t})},async clearUnitResults(){n({unitResults:[]})},async setFilters(e){const{filters:r}=s();n({filters:{...r,...e}})},async setTempFilters(e){const{tempFilters:r}=s();n({tempFilters:{...r,...e}})},async setFiltersToDefault(){n({filters:{...u}})},async setApiFilters(e){const{apiFilters:r}=s();n({apiFilters:{...r,...e}})},async handleTempFilterChange(e,r){const{tempFilters:t}=s();n({tempFilters:{...t,[e]:r}})},async submitFilterUpdate(){var t;const e=s(),r=p.transformFiltersToUnitsSearchParams({...e.filters,limit:e.apiFilters.limit,page:e.apiFilters.page,sortBy:e.sortBy},{defaultLimit:e.apiFilters.limit,defaultPage:e.apiFilters.page,defaultSort:e.sortBy});n({apiFilters:r}),(t=l==null?void 0:l.onFilterUpdate)==null||t.call(l,r)},async setResultsMode(e){n({resultsMode:e})},async setSortBy(e){n({sortBy:e})},async setResolvedQuestionnaireValues(e,r){const{resolvedQuestionnaireValues:t}=s();n({resolvedQuestionnaireValues:{...t,[e]:r}})},async getResultsUrl(){const{currentPropertySlug:e}=s();return e?`/${e}/results`:null},async getCurrentProperty(){const{currentPropertyId:e,properties:r}=s();return e?r[e]??null:null},async getPropertyData(e){const{currentPropertyId:r,properties:t}=s(),i=e??r;return i?t[i]??null:null},async _hydrate(){},async _initialize(){n({filtersLoaded:!0})}})}exports.createZustandUnifiedStore=v;
|
|
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 setFavoriteUnitIds: (unitIds: 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 setFavoriteUnitIds(unitIds) {\n await store.setFavoriteUnitIds(unitIds);\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","unitIds","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) — pure in-memory, no IndexedDB\n *\n * All engagement state (favorites, viewed, filters, etc.) is held in Zustand\n * only. No IndexedDB writes happen here. State is seeded at runtime from the\n * API (bootstrap endpoint) and updated optimistically by the consuming app.\n *\n * IndexedDB is used exclusively for visitor_uuid — see stores/store.ts.\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 { transformFiltersToUnitsSearchParams } from \"../features/filters/transformers\";\nimport { validate } from \"../validation\";\nimport { UnitSchema } from \"../schema\";\nimport type { 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 favorite_unit_ids: 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 setFavoriteUnitIds: (unitIds: string[]) => Promise<void>;\n toggleFavorite: (unitId: string) => Promise<void>;\n markUnitAsViewed: (unitId: string, url: 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 // === 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 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\nconst defaultFilters: Filters = {\n date_availability: undefined,\n qty_bedrooms: undefined,\n base_price: undefined,\n highlights: undefined,\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 return {\n // Initial state\n properties: {},\n currentPropertyId: null,\n currentPropertySlug: null,\n hasPreviouslySearched: [],\n favorite_unit_ids: [],\n unitResults: [],\n filters: { ...defaultFilters },\n tempFilters: { ...defaultFilters },\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 const { properties } = get();\n if (properties[propertyId]) {\n set({ currentPropertyId: propertyId, currentPropertySlug: slug });\n return;\n }\n set({\n currentPropertyId: propertyId,\n currentPropertySlug: slug,\n properties: {\n ...properties,\n [propertyId]: {\n id: propertyId,\n slug,\n tourContactedOn: null,\n viewedUnits: [],\n questionnaireResults: null,\n tourContactData: null,\n },\n },\n });\n },\n\n async setCurrentProperty(propertyId, slug) {\n set({\n currentPropertyId: propertyId,\n ...(slug && { currentPropertySlug: slug }),\n });\n },\n\n async setCurrentPropertySlug(slug) {\n set({ currentPropertySlug: slug });\n },\n\n async setHasPreviouslySearched(slug) {\n const { hasPreviouslySearched } = get();\n set({\n hasPreviouslySearched: Array.from(new Set([...hasPreviouslySearched, slug])),\n });\n },\n\n async setFavoriteUnitIds(unitIds) {\n set({ favorite_unit_ids: unitIds });\n },\n\n async toggleFavorite(unitId) {\n const { favorite_unit_ids } = get();\n const isFavorited = favorite_unit_ids.includes(unitId);\n set({\n favorite_unit_ids: isFavorited\n ? favorite_unit_ids.filter((id: string) => id !== unitId)\n : [...favorite_unit_ids, unitId],\n });\n },\n\n async markUnitAsViewed(unitId, url) {\n window.open(url, \"_blank\", \"noopener,noreferrer\");\n const today = new Date();\n const formattedDate = `${String(today.getMonth() + 1).padStart(2, \"0\")}/${String(today.getDate()).padStart(2, \"0\")}`;\n const { currentPropertyId, properties } = get();\n if (!currentPropertyId || !properties[currentPropertyId]) return;\n const property = properties[currentPropertyId];\n set({\n properties: {\n ...properties,\n [currentPropertyId]: {\n ...property,\n viewedUnits: [\n ...property.viewedUnits.filter((u: any) => u.unitId !== unitId),\n { unitId, viewedDate: formattedDate },\n ],\n },\n },\n });\n },\n\n async setTourContactedOn() {\n const { currentPropertyId, properties } = get();\n if (!currentPropertyId || !properties[currentPropertyId]) return;\n set({\n properties: {\n ...properties,\n [currentPropertyId]: {\n ...properties[currentPropertyId],\n tourContactedOn: new Date().toISOString(),\n },\n },\n });\n },\n\n async getTourContactedOn() {\n const { currentPropertyId, properties } = get();\n if (!currentPropertyId) return null;\n return properties[currentPropertyId]?.tourContactedOn ?? null;\n },\n\n async setQuestionnaireResults(results) {\n const { currentPropertyId, properties } = get();\n if (!currentPropertyId || !properties[currentPropertyId]) return;\n set({\n properties: {\n ...properties,\n [currentPropertyId]: { ...properties[currentPropertyId], questionnaireResults: results },\n },\n });\n },\n\n async setTourContactData(data) {\n const { currentPropertyId, properties } = get();\n if (!currentPropertyId || !properties[currentPropertyId]) return;\n set({\n properties: {\n ...properties,\n [currentPropertyId]: { ...properties[currentPropertyId], tourContactData: data },\n },\n });\n },\n\n async setUnitResults(units: unknown) {\n const collection = Array.isArray(units)\n ? units\n : units && typeof units === \"object\"\n ? Object.values(units as Record<string, unknown>)\n : [];\n const validatedUnits: Unit[] = [];\n collection.forEach((unit: unknown, index: number) => {\n const parsed = validate(UnitSchema, unit, `unitResults[${index}]`);\n if (parsed) validatedUnits.push(parsed as Unit);\n });\n set({ unitResults: validatedUnits });\n },\n\n async clearUnitResults() {\n set({ unitResults: [] });\n },\n\n // === FILTER OPERATIONS ===\n async setFilters(filters) {\n const { filters: current } = get();\n set({ filters: { ...current, ...filters } });\n },\n\n async setTempFilters(filters) {\n const { tempFilters } = get();\n set({ tempFilters: { ...tempFilters, ...filters } });\n },\n\n async setFiltersToDefault() {\n set({ filters: { ...defaultFilters } });\n },\n\n async setApiFilters(filters) {\n const { apiFilters } = get();\n set({ apiFilters: { ...apiFilters, ...filters } });\n },\n\n async handleTempFilterChange(key, value) {\n const { tempFilters } = get();\n set({ tempFilters: { ...tempFilters, [key]: value } });\n },\n\n async submitFilterUpdate() {\n const state = get();\n const apiParams = transformFiltersToUnitsSearchParams(\n {\n ...state.filters,\n limit: state.apiFilters.limit,\n page: state.apiFilters.page,\n sortBy: state.sortBy,\n },\n {\n defaultLimit: state.apiFilters.limit,\n defaultPage: state.apiFilters.page,\n defaultSort: state.sortBy,\n },\n );\n set({ apiFilters: apiParams });\n options?.onFilterUpdate?.(apiParams);\n },\n\n // === RESULTS AND SORTING ===\n async setResultsMode(mode) {\n set({ resultsMode: mode });\n },\n\n async setSortBy(sortBy) {\n set({ sortBy });\n },\n\n // === QUESTIONNAIRE ===\n async setResolvedQuestionnaireValues(name, values) {\n const { resolvedQuestionnaireValues } = get();\n set({\n resolvedQuestionnaireValues: {\n ...resolvedQuestionnaireValues,\n [name]: values,\n },\n });\n },\n\n // === UTILITY METHODS ===\n async getResultsUrl() {\n const { currentPropertySlug } = get();\n return currentPropertySlug ? `/${currentPropertySlug}/results` : null;\n },\n\n async getCurrentProperty() {\n const { currentPropertyId, properties } = get();\n return currentPropertyId ? properties[currentPropertyId] ?? null : null;\n },\n\n async getPropertyData(propertyId) {\n const { currentPropertyId, properties } = get();\n const id = propertyId ?? currentPropertyId;\n return id ? properties[id] ?? null : null;\n },\n\n // === INTERNAL ===\n async _hydrate() {\n // No-op: state is seeded from API (bootstrap), not from IndexedDB.\n },\n\n async _initialize() {\n // No IndexedDB sync needed. Mark filters as loaded so the UI unblocks.\n set({ filtersLoaded: true });\n },\n };\n };\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":["defaultFilters","createZustandUnifiedStore","options","set","get","propertyId","slug","properties","hasPreviouslySearched","unitIds","unitId","favorite_unit_ids","isFavorited","id","url","today","formattedDate","currentPropertyId","property","u","_a","results","data","units","collection","validatedUnits","unit","index","parsed","validate","UnitSchema","filters","current","tempFilters","apiFilters","key","value","state","apiParams","transformFiltersToUnitsSearchParams","mode","sortBy","name","values","resolvedQuestionnaireValues","currentPropertySlug"],"mappings":"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"}
|
|
@@ -4,6 +4,7 @@ export interface ZustandUnifiedStoreState {
|
|
|
4
4
|
currentPropertyId: string | null;
|
|
5
5
|
currentPropertySlug: string | null;
|
|
6
6
|
hasPreviouslySearched: string[];
|
|
7
|
+
favorite_unit_ids: string[];
|
|
7
8
|
unitResults: Unit[];
|
|
8
9
|
filters: Filters;
|
|
9
10
|
tempFilters: Filters;
|
|
@@ -18,7 +19,7 @@ export interface ZustandUnifiedStoreState {
|
|
|
18
19
|
setHasPreviouslySearched: (slug: string) => Promise<void>;
|
|
19
20
|
setFavoriteUnitIds: (unitIds: string[]) => Promise<void>;
|
|
20
21
|
toggleFavorite: (unitId: string) => Promise<void>;
|
|
21
|
-
markUnitAsViewed: (unitId: string,
|
|
22
|
+
markUnitAsViewed: (unitId: string, url: string) => Promise<void>;
|
|
22
23
|
setTourContactedOn: () => Promise<void>;
|
|
23
24
|
getTourContactedOn: () => Promise<string | null>;
|
|
24
25
|
setQuestionnaireResults: (results: unknown) => Promise<void>;
|
|
@@ -34,10 +35,6 @@ export interface ZustandUnifiedStoreState {
|
|
|
34
35
|
setResultsMode: (mode: ResultsMode) => Promise<void>;
|
|
35
36
|
setSortBy: (sortBy: SortBy) => Promise<void>;
|
|
36
37
|
setResolvedQuestionnaireValues: (name: string, values: string[]) => Promise<void>;
|
|
37
|
-
getUnitState: (unitId: string) => {
|
|
38
|
-
isFavorite: boolean;
|
|
39
|
-
viewedDate: string;
|
|
40
|
-
};
|
|
41
38
|
getResultsUrl: () => Promise<string | null>;
|
|
42
39
|
getCurrentProperty: () => Promise<UserPropertyState | null>;
|
|
43
40
|
getPropertyData: (propertyId?: string) => Promise<UserPropertyState | null>;
|
|
@@ -51,5 +48,4 @@ export interface ZustandUnifiedStoreState {
|
|
|
51
48
|
export declare function createZustandUnifiedStore(options?: {
|
|
52
49
|
onFilterUpdate?: (apiParams: QueryParams) => void;
|
|
53
50
|
}): (set: any, get: any) => ZustandUnifiedStoreState;
|
|
54
|
-
export declare function createUseUnitState(): (useStore: any) => (unitId: string) => any;
|
|
55
51
|
export type { UnitData, UserPropertyState, Filters, QueryParams, ResultsMode, SortBy, TourContactData, Unit } from "../schema";
|
|
@@ -1,173 +1,218 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
1
|
+
import { transformFiltersToUnitsSearchParams as d } from "../features/filters/transformers.mjs";
|
|
2
|
+
import { validate as y } from "../validation.mjs";
|
|
3
|
+
import { UnitSchema as f } from "../schema.mjs";
|
|
4
|
+
const u = {
|
|
5
|
+
date_availability: void 0,
|
|
6
|
+
qty_bedrooms: void 0,
|
|
7
|
+
base_price: void 0,
|
|
8
|
+
highlights: void 0
|
|
9
|
+
};
|
|
10
|
+
function F(l) {
|
|
11
|
+
return (n, s) => ({
|
|
12
|
+
// Initial state
|
|
13
|
+
properties: {},
|
|
14
|
+
currentPropertyId: null,
|
|
15
|
+
currentPropertySlug: null,
|
|
16
|
+
hasPreviouslySearched: [],
|
|
17
|
+
favorite_unit_ids: [],
|
|
18
|
+
unitResults: [],
|
|
19
|
+
filters: { ...u },
|
|
20
|
+
tempFilters: { ...u },
|
|
21
|
+
apiFilters: {
|
|
22
|
+
limit: 10,
|
|
23
|
+
page: 1,
|
|
24
|
+
sortBy: "relevance"
|
|
25
|
+
},
|
|
26
|
+
resultsMode: "all",
|
|
27
|
+
resolvedQuestionnaireValues: {},
|
|
28
|
+
sortBy: "relevance",
|
|
29
|
+
filtersLoaded: !1,
|
|
30
|
+
// === PROPERTY OPERATIONS ===
|
|
31
|
+
async initializeProperty(r, e) {
|
|
32
|
+
const { properties: t } = s();
|
|
33
|
+
if (t[r]) {
|
|
34
|
+
n({ currentPropertyId: r, currentPropertySlug: e });
|
|
35
|
+
return;
|
|
23
36
|
}
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
highlights: void 0
|
|
37
|
-
},
|
|
38
|
-
tempFilters: {
|
|
39
|
-
date_availability: void 0,
|
|
40
|
-
qty_bedrooms: void 0,
|
|
41
|
-
base_price: void 0,
|
|
42
|
-
highlights: void 0
|
|
43
|
-
},
|
|
44
|
-
apiFilters: {
|
|
45
|
-
limit: 10,
|
|
46
|
-
page: 1,
|
|
47
|
-
sortBy: "relevance"
|
|
48
|
-
},
|
|
49
|
-
resultsMode: "all",
|
|
50
|
-
resolvedQuestionnaireValues: {},
|
|
51
|
-
sortBy: "relevance",
|
|
52
|
-
filtersLoaded: !1,
|
|
53
|
-
// === PROPERTY OPERATIONS ===
|
|
54
|
-
async initializeProperty(t, a) {
|
|
55
|
-
await e.initializeProperty(t, a), await r();
|
|
56
|
-
},
|
|
57
|
-
async setCurrentProperty(t, a) {
|
|
58
|
-
await e.setCurrentProperty(t, a), i({
|
|
59
|
-
currentPropertyId: t,
|
|
60
|
-
...a && { currentPropertySlug: a }
|
|
61
|
-
});
|
|
62
|
-
},
|
|
63
|
-
async setCurrentPropertySlug(t) {
|
|
64
|
-
await e.setCurrentPropertySlug(t), i({ currentPropertySlug: t });
|
|
65
|
-
},
|
|
66
|
-
async setHasPreviouslySearched(t) {
|
|
67
|
-
await e.setHasPreviouslySearched(t), await r();
|
|
68
|
-
},
|
|
69
|
-
async setFavoriteUnitIds(t) {
|
|
70
|
-
await e.setFavoriteUnitIds(t), await r();
|
|
71
|
-
},
|
|
72
|
-
async toggleFavorite(t) {
|
|
73
|
-
await e.toggleFavorite(t), await r();
|
|
74
|
-
},
|
|
75
|
-
async markUnitAsViewed(t, a) {
|
|
76
|
-
await e.markUnitAsViewed(t, a), await r();
|
|
77
|
-
},
|
|
78
|
-
async setTourContactedOn() {
|
|
79
|
-
await e.setTourContactedOn(), await r();
|
|
80
|
-
},
|
|
81
|
-
getTourContactedOn: e.getTourContactedOn.bind(e),
|
|
82
|
-
async setQuestionnaireResults(t) {
|
|
83
|
-
await e.setQuestionnaireResults(t), await r();
|
|
84
|
-
},
|
|
85
|
-
async setTourContactData(t) {
|
|
86
|
-
await e.setTourContactData(t), await r();
|
|
87
|
-
},
|
|
88
|
-
async setUnitResults(t) {
|
|
89
|
-
await e.setUnitResults(t), await r();
|
|
90
|
-
},
|
|
91
|
-
async clearUnitResults() {
|
|
92
|
-
await e.clearUnitResults(), await r();
|
|
93
|
-
},
|
|
94
|
-
// === FILTER OPERATIONS ===
|
|
95
|
-
async setFilters(t) {
|
|
96
|
-
await e.setFilters(t);
|
|
97
|
-
const a = n();
|
|
98
|
-
i({ filters: { ...a.filters, ...t } });
|
|
99
|
-
},
|
|
100
|
-
async setTempFilters(t) {
|
|
101
|
-
await e.setTempFilters(t);
|
|
102
|
-
const a = n();
|
|
103
|
-
i({ tempFilters: { ...a.tempFilters, ...t } });
|
|
104
|
-
},
|
|
105
|
-
async setFiltersToDefault() {
|
|
106
|
-
await e.setFiltersToDefault(), i({ filters: {
|
|
107
|
-
date_availability: void 0,
|
|
108
|
-
qty_bedrooms: void 0,
|
|
109
|
-
base_price: void 0,
|
|
110
|
-
highlights: void 0
|
|
111
|
-
} });
|
|
112
|
-
},
|
|
113
|
-
async setApiFilters(t) {
|
|
114
|
-
await e.setApiFilters(t);
|
|
115
|
-
const a = n();
|
|
116
|
-
i({ apiFilters: { ...a.apiFilters, ...t } });
|
|
117
|
-
},
|
|
118
|
-
async handleTempFilterChange(t, a) {
|
|
119
|
-
await e.handleTempFilterChange(t, a);
|
|
120
|
-
const s = n();
|
|
121
|
-
i({ tempFilters: { ...s.tempFilters, [t]: a } });
|
|
122
|
-
},
|
|
123
|
-
async submitFilterUpdate() {
|
|
124
|
-
await e.submitFilterUpdate(), await r(), await u();
|
|
125
|
-
},
|
|
126
|
-
// === RESULTS AND SORTING ===
|
|
127
|
-
async setResultsMode(t) {
|
|
128
|
-
await e.setResultsMode(t), i({ resultsMode: t });
|
|
129
|
-
},
|
|
130
|
-
async setSortBy(t) {
|
|
131
|
-
await e.setSortBy(t), i({ sortBy: t });
|
|
132
|
-
},
|
|
133
|
-
// === QUESTIONNAIRE ===
|
|
134
|
-
async setResolvedQuestionnaireValues(t, a) {
|
|
135
|
-
await e.setResolvedQuestionnaireValues(t, a);
|
|
136
|
-
const s = n();
|
|
137
|
-
i({
|
|
138
|
-
resolvedQuestionnaireValues: {
|
|
139
|
-
...s.resolvedQuestionnaireValues,
|
|
140
|
-
[t]: a
|
|
37
|
+
n({
|
|
38
|
+
currentPropertyId: r,
|
|
39
|
+
currentPropertySlug: e,
|
|
40
|
+
properties: {
|
|
41
|
+
...t,
|
|
42
|
+
[r]: {
|
|
43
|
+
id: r,
|
|
44
|
+
slug: e,
|
|
45
|
+
tourContactedOn: null,
|
|
46
|
+
viewedUnits: [],
|
|
47
|
+
questionnaireResults: null,
|
|
48
|
+
tourContactData: null
|
|
141
49
|
}
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
},
|
|
53
|
+
async setCurrentProperty(r, e) {
|
|
54
|
+
n({
|
|
55
|
+
currentPropertyId: r,
|
|
56
|
+
...e && { currentPropertySlug: e }
|
|
57
|
+
});
|
|
58
|
+
},
|
|
59
|
+
async setCurrentPropertySlug(r) {
|
|
60
|
+
n({ currentPropertySlug: r });
|
|
61
|
+
},
|
|
62
|
+
async setHasPreviouslySearched(r) {
|
|
63
|
+
const { hasPreviouslySearched: e } = s();
|
|
64
|
+
n({
|
|
65
|
+
hasPreviouslySearched: Array.from(/* @__PURE__ */ new Set([...e, r]))
|
|
66
|
+
});
|
|
67
|
+
},
|
|
68
|
+
async setFavoriteUnitIds(r) {
|
|
69
|
+
n({ favorite_unit_ids: r });
|
|
70
|
+
},
|
|
71
|
+
async toggleFavorite(r) {
|
|
72
|
+
const { favorite_unit_ids: e } = s(), t = e.includes(r);
|
|
73
|
+
n({
|
|
74
|
+
favorite_unit_ids: t ? e.filter((i) => i !== r) : [...e, r]
|
|
75
|
+
});
|
|
76
|
+
},
|
|
77
|
+
async markUnitAsViewed(r, e) {
|
|
78
|
+
window.open(e, "_blank", "noopener,noreferrer");
|
|
79
|
+
const t = /* @__PURE__ */ new Date(), i = `${String(t.getMonth() + 1).padStart(2, "0")}/${String(t.getDate()).padStart(2, "0")}`, { currentPropertyId: a, properties: o } = s();
|
|
80
|
+
if (!a || !o[a]) return;
|
|
81
|
+
const c = o[a];
|
|
82
|
+
n({
|
|
83
|
+
properties: {
|
|
84
|
+
...o,
|
|
85
|
+
[a]: {
|
|
86
|
+
...c,
|
|
87
|
+
viewedUnits: [
|
|
88
|
+
...c.viewedUnits.filter((p) => p.unitId !== r),
|
|
89
|
+
{ unitId: r, viewedDate: i }
|
|
90
|
+
]
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
});
|
|
94
|
+
},
|
|
95
|
+
async setTourContactedOn() {
|
|
96
|
+
const { currentPropertyId: r, properties: e } = s();
|
|
97
|
+
!r || !e[r] || n({
|
|
98
|
+
properties: {
|
|
99
|
+
...e,
|
|
100
|
+
[r]: {
|
|
101
|
+
...e[r],
|
|
102
|
+
tourContactedOn: (/* @__PURE__ */ new Date()).toISOString()
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
});
|
|
106
|
+
},
|
|
107
|
+
async getTourContactedOn() {
|
|
108
|
+
var t;
|
|
109
|
+
const { currentPropertyId: r, properties: e } = s();
|
|
110
|
+
return r ? ((t = e[r]) == null ? void 0 : t.tourContactedOn) ?? null : null;
|
|
111
|
+
},
|
|
112
|
+
async setQuestionnaireResults(r) {
|
|
113
|
+
const { currentPropertyId: e, properties: t } = s();
|
|
114
|
+
!e || !t[e] || n({
|
|
115
|
+
properties: {
|
|
116
|
+
...t,
|
|
117
|
+
[e]: { ...t[e], questionnaireResults: r }
|
|
118
|
+
}
|
|
119
|
+
});
|
|
120
|
+
},
|
|
121
|
+
async setTourContactData(r) {
|
|
122
|
+
const { currentPropertyId: e, properties: t } = s();
|
|
123
|
+
!e || !t[e] || n({
|
|
124
|
+
properties: {
|
|
125
|
+
...t,
|
|
126
|
+
[e]: { ...t[e], tourContactData: r }
|
|
127
|
+
}
|
|
128
|
+
});
|
|
129
|
+
},
|
|
130
|
+
async setUnitResults(r) {
|
|
131
|
+
const e = Array.isArray(r) ? r : r && typeof r == "object" ? Object.values(r) : [], t = [];
|
|
132
|
+
e.forEach((i, a) => {
|
|
133
|
+
const o = y(f, i, `unitResults[${a}]`);
|
|
134
|
+
o && t.push(o);
|
|
135
|
+
}), n({ unitResults: t });
|
|
136
|
+
},
|
|
137
|
+
async clearUnitResults() {
|
|
138
|
+
n({ unitResults: [] });
|
|
139
|
+
},
|
|
140
|
+
// === FILTER OPERATIONS ===
|
|
141
|
+
async setFilters(r) {
|
|
142
|
+
const { filters: e } = s();
|
|
143
|
+
n({ filters: { ...e, ...r } });
|
|
144
|
+
},
|
|
145
|
+
async setTempFilters(r) {
|
|
146
|
+
const { tempFilters: e } = s();
|
|
147
|
+
n({ tempFilters: { ...e, ...r } });
|
|
148
|
+
},
|
|
149
|
+
async setFiltersToDefault() {
|
|
150
|
+
n({ filters: { ...u } });
|
|
151
|
+
},
|
|
152
|
+
async setApiFilters(r) {
|
|
153
|
+
const { apiFilters: e } = s();
|
|
154
|
+
n({ apiFilters: { ...e, ...r } });
|
|
155
|
+
},
|
|
156
|
+
async handleTempFilterChange(r, e) {
|
|
157
|
+
const { tempFilters: t } = s();
|
|
158
|
+
n({ tempFilters: { ...t, [r]: e } });
|
|
159
|
+
},
|
|
160
|
+
async submitFilterUpdate() {
|
|
161
|
+
var t;
|
|
162
|
+
const r = s(), e = d(
|
|
163
|
+
{
|
|
164
|
+
...r.filters,
|
|
165
|
+
limit: r.apiFilters.limit,
|
|
166
|
+
page: r.apiFilters.page,
|
|
167
|
+
sortBy: r.sortBy
|
|
168
|
+
},
|
|
169
|
+
{
|
|
170
|
+
defaultLimit: r.apiFilters.limit,
|
|
171
|
+
defaultPage: r.apiFilters.page,
|
|
172
|
+
defaultSort: r.sortBy
|
|
173
|
+
}
|
|
174
|
+
);
|
|
175
|
+
n({ apiFilters: e }), (t = l == null ? void 0 : l.onFilterUpdate) == null || t.call(l, e);
|
|
176
|
+
},
|
|
177
|
+
// === RESULTS AND SORTING ===
|
|
178
|
+
async setResultsMode(r) {
|
|
179
|
+
n({ resultsMode: r });
|
|
180
|
+
},
|
|
181
|
+
async setSortBy(r) {
|
|
182
|
+
n({ sortBy: r });
|
|
183
|
+
},
|
|
184
|
+
// === QUESTIONNAIRE ===
|
|
185
|
+
async setResolvedQuestionnaireValues(r, e) {
|
|
186
|
+
const { resolvedQuestionnaireValues: t } = s();
|
|
187
|
+
n({
|
|
188
|
+
resolvedQuestionnaireValues: {
|
|
189
|
+
...t,
|
|
190
|
+
[r]: e
|
|
191
|
+
}
|
|
192
|
+
});
|
|
193
|
+
},
|
|
194
|
+
// === UTILITY METHODS ===
|
|
195
|
+
async getResultsUrl() {
|
|
196
|
+
const { currentPropertySlug: r } = s();
|
|
197
|
+
return r ? `/${r}/results` : null;
|
|
198
|
+
},
|
|
199
|
+
async getCurrentProperty() {
|
|
200
|
+
const { currentPropertyId: r, properties: e } = s();
|
|
201
|
+
return r ? e[r] ?? null : null;
|
|
202
|
+
},
|
|
203
|
+
async getPropertyData(r) {
|
|
204
|
+
const { currentPropertyId: e, properties: t } = s(), i = r ?? e;
|
|
205
|
+
return i ? t[i] ?? null : null;
|
|
206
|
+
},
|
|
207
|
+
// === INTERNAL ===
|
|
208
|
+
async _hydrate() {
|
|
209
|
+
},
|
|
210
|
+
async _initialize() {
|
|
211
|
+
n({ filtersLoaded: !0 });
|
|
212
|
+
}
|
|
213
|
+
});
|
|
168
214
|
}
|
|
169
215
|
export {
|
|
170
|
-
|
|
171
|
-
y as createZustandUnifiedStore
|
|
216
|
+
F as createZustandUnifiedStore
|
|
172
217
|
};
|
|
173
218
|
//# sourceMappingURL=zustand-store.mjs.map
|
|
@@ -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 setFavoriteUnitIds: (unitIds: 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 setFavoriteUnitIds(unitIds) {\n await store.setFavoriteUnitIds(unitIds);\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","unitIds","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.mjs","sources":["../../src/adapters/zustand-store.ts"],"sourcesContent":["/**\n * Zustand adapter (flat API) — pure in-memory, no IndexedDB\n *\n * All engagement state (favorites, viewed, filters, etc.) is held in Zustand\n * only. No IndexedDB writes happen here. State is seeded at runtime from the\n * API (bootstrap endpoint) and updated optimistically by the consuming app.\n *\n * IndexedDB is used exclusively for visitor_uuid — see stores/store.ts.\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 { transformFiltersToUnitsSearchParams } from \"../features/filters/transformers\";\nimport { validate } from \"../validation\";\nimport { UnitSchema } from \"../schema\";\nimport type { 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 favorite_unit_ids: 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 setFavoriteUnitIds: (unitIds: string[]) => Promise<void>;\n toggleFavorite: (unitId: string) => Promise<void>;\n markUnitAsViewed: (unitId: string, url: 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 // === 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 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\nconst defaultFilters: Filters = {\n date_availability: undefined,\n qty_bedrooms: undefined,\n base_price: undefined,\n highlights: undefined,\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 return {\n // Initial state\n properties: {},\n currentPropertyId: null,\n currentPropertySlug: null,\n hasPreviouslySearched: [],\n favorite_unit_ids: [],\n unitResults: [],\n filters: { ...defaultFilters },\n tempFilters: { ...defaultFilters },\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 const { properties } = get();\n if (properties[propertyId]) {\n set({ currentPropertyId: propertyId, currentPropertySlug: slug });\n return;\n }\n set({\n currentPropertyId: propertyId,\n currentPropertySlug: slug,\n properties: {\n ...properties,\n [propertyId]: {\n id: propertyId,\n slug,\n tourContactedOn: null,\n viewedUnits: [],\n questionnaireResults: null,\n tourContactData: null,\n },\n },\n });\n },\n\n async setCurrentProperty(propertyId, slug) {\n set({\n currentPropertyId: propertyId,\n ...(slug && { currentPropertySlug: slug }),\n });\n },\n\n async setCurrentPropertySlug(slug) {\n set({ currentPropertySlug: slug });\n },\n\n async setHasPreviouslySearched(slug) {\n const { hasPreviouslySearched } = get();\n set({\n hasPreviouslySearched: Array.from(new Set([...hasPreviouslySearched, slug])),\n });\n },\n\n async setFavoriteUnitIds(unitIds) {\n set({ favorite_unit_ids: unitIds });\n },\n\n async toggleFavorite(unitId) {\n const { favorite_unit_ids } = get();\n const isFavorited = favorite_unit_ids.includes(unitId);\n set({\n favorite_unit_ids: isFavorited\n ? favorite_unit_ids.filter((id: string) => id !== unitId)\n : [...favorite_unit_ids, unitId],\n });\n },\n\n async markUnitAsViewed(unitId, url) {\n window.open(url, \"_blank\", \"noopener,noreferrer\");\n const today = new Date();\n const formattedDate = `${String(today.getMonth() + 1).padStart(2, \"0\")}/${String(today.getDate()).padStart(2, \"0\")}`;\n const { currentPropertyId, properties } = get();\n if (!currentPropertyId || !properties[currentPropertyId]) return;\n const property = properties[currentPropertyId];\n set({\n properties: {\n ...properties,\n [currentPropertyId]: {\n ...property,\n viewedUnits: [\n ...property.viewedUnits.filter((u: any) => u.unitId !== unitId),\n { unitId, viewedDate: formattedDate },\n ],\n },\n },\n });\n },\n\n async setTourContactedOn() {\n const { currentPropertyId, properties } = get();\n if (!currentPropertyId || !properties[currentPropertyId]) return;\n set({\n properties: {\n ...properties,\n [currentPropertyId]: {\n ...properties[currentPropertyId],\n tourContactedOn: new Date().toISOString(),\n },\n },\n });\n },\n\n async getTourContactedOn() {\n const { currentPropertyId, properties } = get();\n if (!currentPropertyId) return null;\n return properties[currentPropertyId]?.tourContactedOn ?? null;\n },\n\n async setQuestionnaireResults(results) {\n const { currentPropertyId, properties } = get();\n if (!currentPropertyId || !properties[currentPropertyId]) return;\n set({\n properties: {\n ...properties,\n [currentPropertyId]: { ...properties[currentPropertyId], questionnaireResults: results },\n },\n });\n },\n\n async setTourContactData(data) {\n const { currentPropertyId, properties } = get();\n if (!currentPropertyId || !properties[currentPropertyId]) return;\n set({\n properties: {\n ...properties,\n [currentPropertyId]: { ...properties[currentPropertyId], tourContactData: data },\n },\n });\n },\n\n async setUnitResults(units: unknown) {\n const collection = Array.isArray(units)\n ? units\n : units && typeof units === \"object\"\n ? Object.values(units as Record<string, unknown>)\n : [];\n const validatedUnits: Unit[] = [];\n collection.forEach((unit: unknown, index: number) => {\n const parsed = validate(UnitSchema, unit, `unitResults[${index}]`);\n if (parsed) validatedUnits.push(parsed as Unit);\n });\n set({ unitResults: validatedUnits });\n },\n\n async clearUnitResults() {\n set({ unitResults: [] });\n },\n\n // === FILTER OPERATIONS ===\n async setFilters(filters) {\n const { filters: current } = get();\n set({ filters: { ...current, ...filters } });\n },\n\n async setTempFilters(filters) {\n const { tempFilters } = get();\n set({ tempFilters: { ...tempFilters, ...filters } });\n },\n\n async setFiltersToDefault() {\n set({ filters: { ...defaultFilters } });\n },\n\n async setApiFilters(filters) {\n const { apiFilters } = get();\n set({ apiFilters: { ...apiFilters, ...filters } });\n },\n\n async handleTempFilterChange(key, value) {\n const { tempFilters } = get();\n set({ tempFilters: { ...tempFilters, [key]: value } });\n },\n\n async submitFilterUpdate() {\n const state = get();\n const apiParams = transformFiltersToUnitsSearchParams(\n {\n ...state.filters,\n limit: state.apiFilters.limit,\n page: state.apiFilters.page,\n sortBy: state.sortBy,\n },\n {\n defaultLimit: state.apiFilters.limit,\n defaultPage: state.apiFilters.page,\n defaultSort: state.sortBy,\n },\n );\n set({ apiFilters: apiParams });\n options?.onFilterUpdate?.(apiParams);\n },\n\n // === RESULTS AND SORTING ===\n async setResultsMode(mode) {\n set({ resultsMode: mode });\n },\n\n async setSortBy(sortBy) {\n set({ sortBy });\n },\n\n // === QUESTIONNAIRE ===\n async setResolvedQuestionnaireValues(name, values) {\n const { resolvedQuestionnaireValues } = get();\n set({\n resolvedQuestionnaireValues: {\n ...resolvedQuestionnaireValues,\n [name]: values,\n },\n });\n },\n\n // === UTILITY METHODS ===\n async getResultsUrl() {\n const { currentPropertySlug } = get();\n return currentPropertySlug ? `/${currentPropertySlug}/results` : null;\n },\n\n async getCurrentProperty() {\n const { currentPropertyId, properties } = get();\n return currentPropertyId ? properties[currentPropertyId] ?? null : null;\n },\n\n async getPropertyData(propertyId) {\n const { currentPropertyId, properties } = get();\n const id = propertyId ?? currentPropertyId;\n return id ? properties[id] ?? null : null;\n },\n\n // === INTERNAL ===\n async _hydrate() {\n // No-op: state is seeded from API (bootstrap), not from IndexedDB.\n },\n\n async _initialize() {\n // No IndexedDB sync needed. Mark filters as loaded so the UI unblocks.\n set({ filtersLoaded: true });\n },\n };\n };\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":["defaultFilters","createZustandUnifiedStore","options","set","get","propertyId","slug","properties","hasPreviouslySearched","unitIds","unitId","favorite_unit_ids","isFavorited","id","url","today","formattedDate","currentPropertyId","property","u","_a","results","data","units","collection","validatedUnits","unit","index","parsed","validate","UnitSchema","filters","current","tempFilters","apiFilters","key","value","state","apiParams","transformFiltersToUnitsSearchParams","mode","sortBy","name","values","resolvedQuestionnaireValues","currentPropertySlug"],"mappings":"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"}
|
package/dist/base/enums.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var _=(E=>(E.UN_RENDERED="UN_RENDERED",E.IN_QUEUE="IN_QUEUE",E.RENDERING="RENDERING",E.RENDERED="RENDERED",E.FAILED="FAILED",E))(_||{}),O=(E=>(E.NOT_STARTED="NOT_STARTED",E.IN_QUEUE="IN_QUEUE",E.IN_PROGRESS="IN_PROGRESS",E.COMPLETED="COMPLETED",E.FAILED="FAILED",E))(O||{}),S=(E=>(E.Hyly="Hyly",E.GoogleAnalytics="GoogleAnalytics",E))(S||{}),I=(E=>(E.Pending="Pending",E.Failed="Failed",E.Success="Success",E))(I||{}),T=(E=>(E.image="image",E.video="video",E.model="model",E.audio="audio",E.json="json",E.blend="blend",E.logs="logs",E))(T||{}),N=(E=>(E.USER="USER",E.ADMIN="ADMIN",E))(N||{}),A=(E=>(E.archived="archived",E.active="active",E))(A||{}),R=(E=>(E.IN_STOCK="IN_STOCK",E.SOLD_OUT="SOLD_OUT",E.WAIT_LIST="WAIT_LIST",E))(R||{}),L=(E=>(E.USD="USD",E.GBP="GBP",E))(L||{}),D=(E=>(E.GOOD_VIEW="GOOD_VIEW",E.SUNSET_VIEWS="SUNSET_VIEWS",E.GOOD_FOR_HOSTING="GOOD_FOR_HOSTING",E.LOTS_OF_WINDOWS="LOTS_OF_WINDOWS",E.BATHTUB="BATHTUB",E.SOUTH_FACING="SOUTH_FACING",E.CLOSE_TO_ELEVATOR="CLOSE_TO_ELEVATOR",E.PEACE_AND_QUIET="PEACE_AND_QUIET",E.LARGE_LIVING_ROOM="LARGE_LIVING_ROOM",E.LARGE_BEDROOM="LARGE_BEDROOM",E.PRIVATE_TERRACE="PRIVATE_TERRACE",E.WALK_IN_CLOSET="WALK_IN_CLOSET",E.LOTS_OF_LIGHT="LOTS_OF_LIGHT",E.LOTS_OF_STORAGE="LOTS_OF_STORAGE",E.HIS_AND_HERS_SINKS="HIS_AND_HERS_SINKS",E.COUNTER_SPACE="COUNTER_SPACE",E.BALCONY="BALCONY",E.WHEELCHAIR_ACCESSIBLE="WHEELCHAIR_ACCESSIBLE",E))(D||{});exports.Currency=L;exports.DeliveryStatus=I;exports.ExternalService=S;exports.FurnitureAvailability=R;exports.Highlights=D;exports.MediaType=T;exports.QueueJobStatus=O;exports.RenderStatus=_;exports.Status=A;exports.UserRole=N;
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var _=(E=>(E.UN_RENDERED="UN_RENDERED",E.IN_QUEUE="IN_QUEUE",E.RENDERING="RENDERING",E.RENDERED="RENDERED",E.FAILED="FAILED",E))(_||{}),O=(E=>(E.NOT_STARTED="NOT_STARTED",E.IN_QUEUE="IN_QUEUE",E.IN_PROGRESS="IN_PROGRESS",E.COMPLETED="COMPLETED",E.FAILED="FAILED",E))(O||{}),S=(E=>(E.Hyly="Hyly",E.GoogleAnalytics="GoogleAnalytics",E))(S||{}),I=(E=>(E.Pending="Pending",E.Failed="Failed",E.Success="Success",E))(I||{}),T=(E=>(E.image="image",E.video="video",E.model="model",E.audio="audio",E.json="json",E.blend="blend",E.logs="logs",E))(T||{}),N=(E=>(E.USER="USER",E.ADMIN="ADMIN",E))(N||{}),A=(E=>(E.archived="archived",E.active="active",E))(A||{}),R=(E=>(E.IN_STOCK="IN_STOCK",E.SOLD_OUT="SOLD_OUT",E.WAIT_LIST="WAIT_LIST",E))(R||{}),L=(E=>(E.USD="USD",E.GBP="GBP",E))(L||{}),D=(E=>(E.GOOD_VIEW="GOOD_VIEW",E.SUNSET_VIEWS="SUNSET_VIEWS",E.GOOD_FOR_HOSTING="GOOD_FOR_HOSTING",E.LOTS_OF_WINDOWS="LOTS_OF_WINDOWS",E.BATHTUB="BATHTUB",E.SOUTH_FACING="SOUTH_FACING",E.CLOSE_TO_ELEVATOR="CLOSE_TO_ELEVATOR",E.PEACE_AND_QUIET="PEACE_AND_QUIET",E.LARGE_LIVING_ROOM="LARGE_LIVING_ROOM",E.LARGE_BEDROOM="LARGE_BEDROOM",E.PRIVATE_TERRACE="PRIVATE_TERRACE",E.WALK_IN_CLOSET="WALK_IN_CLOSET",E.LOTS_OF_LIGHT="LOTS_OF_LIGHT",E.LOTS_OF_STORAGE="LOTS_OF_STORAGE",E.HIS_AND_HERS_SINKS="HIS_AND_HERS_SINKS",E.COUNTER_SPACE="COUNTER_SPACE",E.BALCONY="BALCONY",E.WHEELCHAIR_ACCESSIBLE="WHEELCHAIR_ACCESSIBLE",E))(D||{}),r=(E=>(E.FAVORITE="FAVORITE",E.SEEN="SEEN",E))(r||{});exports.Currency=L;exports.DeliveryStatus=I;exports.EngagementType=r;exports.ExternalService=S;exports.FurnitureAvailability=R;exports.Highlights=D;exports.MediaType=T;exports.QueueJobStatus=O;exports.RenderStatus=_;exports.Status=A;exports.UserRole=N;
|
|
2
2
|
//# sourceMappingURL=enums.cjs.map
|
package/dist/base/enums.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"enums.cjs","sources":["../../src/base/enums.ts"],"sourcesContent":["export enum RenderStatus {\n UN_RENDERED = 'UN_RENDERED',\n IN_QUEUE = 'IN_QUEUE',\n RENDERING = 'RENDERING',\n RENDERED = 'RENDERED',\n FAILED = 'FAILED',\n }\n \n export enum QueueJobStatus {\n NOT_STARTED = 'NOT_STARTED',\n IN_QUEUE = 'IN_QUEUE',\n IN_PROGRESS = 'IN_PROGRESS',\n COMPLETED = 'COMPLETED',\n FAILED = 'FAILED',\n }\n \n export enum ExternalService {\n Hyly = 'Hyly',\n GoogleAnalytics = 'GoogleAnalytics',\n }\n \n export enum DeliveryStatus {\n Pending = 'Pending',\n Failed = 'Failed',\n Success = 'Success',\n }\n \n export enum MediaType {\n image = 'image',\n video = 'video',\n model = 'model',\n audio = 'audio',\n json = 'json',\n blend = 'blend',\n logs = 'logs',\n }\n \n export enum UserRole {\n USER = 'USER',\n ADMIN = 'ADMIN',\n }\n
|
|
1
|
+
{"version":3,"file":"enums.cjs","sources":["../../src/base/enums.ts"],"sourcesContent":["export enum RenderStatus {\n UN_RENDERED = 'UN_RENDERED',\n IN_QUEUE = 'IN_QUEUE',\n RENDERING = 'RENDERING',\n RENDERED = 'RENDERED',\n FAILED = 'FAILED',\n }\n \n export enum QueueJobStatus {\n NOT_STARTED = 'NOT_STARTED',\n IN_QUEUE = 'IN_QUEUE',\n IN_PROGRESS = 'IN_PROGRESS',\n COMPLETED = 'COMPLETED',\n FAILED = 'FAILED',\n }\n \n export enum ExternalService {\n Hyly = 'Hyly',\n GoogleAnalytics = 'GoogleAnalytics',\n }\n \n export enum DeliveryStatus {\n Pending = 'Pending',\n Failed = 'Failed',\n Success = 'Success',\n }\n \n export enum MediaType {\n image = 'image',\n video = 'video',\n model = 'model',\n audio = 'audio',\n json = 'json',\n blend = 'blend',\n logs = 'logs',\n }\n \n export enum UserRole {\n USER = 'USER',\n ADMIN = 'ADMIN',\n }\n\n export enum Status {\n archived = 'archived',\n active = 'active',\n }\n \n export enum FurnitureAvailability {\n IN_STOCK = 'IN_STOCK',\n SOLD_OUT = 'SOLD_OUT',\n WAIT_LIST = 'WAIT_LIST',\n }\n \n export enum Currency {\n USD = 'USD',\n GBP = 'GBP',\n }\n \n export enum Highlights {\n GOOD_VIEW = 'GOOD_VIEW',\n SUNSET_VIEWS = 'SUNSET_VIEWS',\n GOOD_FOR_HOSTING = 'GOOD_FOR_HOSTING',\n LOTS_OF_WINDOWS = 'LOTS_OF_WINDOWS',\n BATHTUB = 'BATHTUB',\n SOUTH_FACING = 'SOUTH_FACING',\n CLOSE_TO_ELEVATOR = 'CLOSE_TO_ELEVATOR',\n PEACE_AND_QUIET = 'PEACE_AND_QUIET',\n LARGE_LIVING_ROOM = 'LARGE_LIVING_ROOM',\n LARGE_BEDROOM = 'LARGE_BEDROOM',\n PRIVATE_TERRACE = 'PRIVATE_TERRACE',\n WALK_IN_CLOSET = 'WALK_IN_CLOSET',\n LOTS_OF_LIGHT = 'LOTS_OF_LIGHT',\n LOTS_OF_STORAGE = 'LOTS_OF_STORAGE',\n HIS_AND_HERS_SINKS = 'HIS_AND_HERS_SINKS',\n COUNTER_SPACE = 'COUNTER_SPACE',\n BALCONY = 'BALCONY',\n WHEELCHAIR_ACCESSIBLE = 'WHEELCHAIR_ACCESSIBLE',\n }\n \n export enum EngagementType {\n FAVORITE = 'FAVORITE',\n SEEN = 'SEEN'\n };\n"],"names":["RenderStatus","QueueJobStatus","ExternalService","DeliveryStatus","MediaType","UserRole","Status","FurnitureAvailability","Currency","Highlights","EngagementType"],"mappings":"gFAAO,IAAKA,GAAAA,IACRA,EAAA,YAAc,cACdA,EAAA,SAAW,WACXA,EAAA,UAAY,YACZA,EAAA,SAAW,WACXA,EAAA,OAAS,SALDA,IAAAA,GAAA,CAAA,CAAA,EAQEC,GAAAA,IACVA,EAAA,YAAc,cACdA,EAAA,SAAW,WACXA,EAAA,YAAc,cACdA,EAAA,UAAY,YACZA,EAAA,OAAS,SALCA,IAAAA,GAAA,CAAA,CAAA,EAQAC,GAAAA,IACVA,EAAA,KAAO,OACPA,EAAA,gBAAkB,kBAFRA,IAAAA,GAAA,CAAA,CAAA,EAKAC,GAAAA,IACVA,EAAA,QAAU,UACVA,EAAA,OAAS,SACTA,EAAA,QAAU,UAHAA,IAAAA,GAAA,CAAA,CAAA,EAMAC,GAAAA,IACVA,EAAA,MAAQ,QACRA,EAAA,MAAQ,QACRA,EAAA,MAAQ,QACRA,EAAA,MAAQ,QACRA,EAAA,KAAO,OACPA,EAAA,MAAQ,QACRA,EAAA,KAAO,OAPGA,IAAAA,GAAA,CAAA,CAAA,EAUAC,GAAAA,IACVA,EAAA,KAAO,OACPA,EAAA,MAAQ,QAFEA,IAAAA,GAAA,CAAA,CAAA,EAKAC,GAAAA,IACVA,EAAA,SAAW,WACXA,EAAA,OAAS,SAFCA,IAAAA,GAAA,CAAA,CAAA,EAKAC,GAAAA,IACVA,EAAA,SAAW,WACXA,EAAA,SAAW,WACXA,EAAA,UAAY,YAHFA,IAAAA,GAAA,CAAA,CAAA,EAMAC,GAAAA,IACVA,EAAA,IAAM,MACNA,EAAA,IAAM,MAFIA,IAAAA,GAAA,CAAA,CAAA,EAKAC,GAAAA,IACVA,EAAA,UAAY,YACZA,EAAA,aAAe,eACfA,EAAA,iBAAmB,mBACnBA,EAAA,gBAAkB,kBAClBA,EAAA,QAAU,UACVA,EAAA,aAAe,eACfA,EAAA,kBAAoB,oBACpBA,EAAA,gBAAkB,kBAClBA,EAAA,kBAAoB,oBACpBA,EAAA,cAAgB,gBAChBA,EAAA,gBAAkB,kBAClBA,EAAA,eAAiB,iBACjBA,EAAA,cAAgB,gBAChBA,EAAA,gBAAkB,kBAClBA,EAAA,mBAAqB,qBACrBA,EAAA,cAAgB,gBAChBA,EAAA,QAAU,UACVA,EAAA,sBAAwB,wBAlBdA,IAAAA,GAAA,CAAA,CAAA,EAqBAC,GAAAA,IACVA,EAAA,SAAW,WACXA,EAAA,KAAO,OAFGA,IAAAA,GAAA,CAAA,CAAA"}
|