@wix/headless-stores 0.0.41 → 0.0.43
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/cjs/dist/react/ProductList.d.ts +31 -3
- package/cjs/dist/react/ProductList.js +33 -5
- package/cjs/dist/react/ProductListFilters.d.ts +100 -111
- package/cjs/dist/react/ProductListFilters.js +105 -115
- package/cjs/dist/react/ProductListPagination.d.ts +89 -96
- package/cjs/dist/react/ProductListPagination.js +96 -104
- package/cjs/dist/react/ProductListSort.d.ts +26 -57
- package/cjs/dist/react/ProductListSort.js +26 -58
- package/cjs/dist/services/index.d.ts +1 -3
- package/cjs/dist/services/index.js +1 -3
- package/cjs/dist/services/products-list-search-service.d.ts +220 -0
- package/cjs/dist/services/products-list-search-service.js +813 -0
- package/cjs/dist/services/products-list-service.d.ts +28 -11
- package/cjs/dist/services/products-list-service.js +26 -6
- package/dist/react/ProductList.d.ts +31 -3
- package/dist/react/ProductList.js +33 -5
- package/dist/react/ProductListFilters.d.ts +100 -111
- package/dist/react/ProductListFilters.js +105 -115
- package/dist/react/ProductListPagination.d.ts +89 -96
- package/dist/react/ProductListPagination.js +96 -104
- package/dist/react/ProductListSort.d.ts +26 -57
- package/dist/react/ProductListSort.js +26 -58
- package/dist/services/index.d.ts +1 -3
- package/dist/services/index.js +1 -3
- package/dist/services/products-list-search-service.d.ts +220 -0
- package/dist/services/products-list-search-service.js +813 -0
- package/dist/services/products-list-service.d.ts +28 -11
- package/dist/services/products-list-service.js +26 -6
- package/package.json +2 -2
- package/cjs/dist/services/products-list-filters-service.d.ts +0 -309
- package/cjs/dist/services/products-list-filters-service.js +0 -504
- package/cjs/dist/services/products-list-pagination-service.d.ts +0 -186
- package/cjs/dist/services/products-list-pagination-service.js +0 -179
- package/cjs/dist/services/products-list-sort-service.d.ts +0 -117
- package/cjs/dist/services/products-list-sort-service.js +0 -144
- package/dist/services/products-list-filters-service.d.ts +0 -309
- package/dist/services/products-list-filters-service.js +0 -504
- package/dist/services/products-list-pagination-service.d.ts +0 -186
- package/dist/services/products-list-pagination-service.js +0 -179
- package/dist/services/products-list-sort-service.d.ts +0 -117
- package/dist/services/products-list-sort-service.js +0 -144
|
@@ -0,0 +1,220 @@
|
|
|
1
|
+
import type { Signal } from "@wix/services-definitions/core-services/signals";
|
|
2
|
+
import { productsV3, customizationsV3 } from "@wix/stores";
|
|
3
|
+
import { type Category } from "./category-service.js";
|
|
4
|
+
import { SortType } from "./../enums/sort-enums.js";
|
|
5
|
+
export { SortType } from "./../enums/sort-enums.js";
|
|
6
|
+
/**
|
|
7
|
+
* Enumeration of inventory status types available for filtering.
|
|
8
|
+
* Re-exports the Wix inventory availability status enum values.
|
|
9
|
+
*/
|
|
10
|
+
export declare const InventoryStatusType: typeof productsV3.InventoryAvailabilityStatus;
|
|
11
|
+
/**
|
|
12
|
+
* Type for inventory status values.
|
|
13
|
+
* Re-exports the Wix inventory availability status enum type.
|
|
14
|
+
*/
|
|
15
|
+
export type InventoryStatusType = productsV3.InventoryAvailabilityStatus;
|
|
16
|
+
/**
|
|
17
|
+
* Interface representing a product option (like Size, Color, etc.).
|
|
18
|
+
*/
|
|
19
|
+
export interface ProductOption {
|
|
20
|
+
id: string;
|
|
21
|
+
name: string;
|
|
22
|
+
choices: ProductChoice[];
|
|
23
|
+
optionRenderType?: string;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Interface representing a choice within a product option.
|
|
27
|
+
*/
|
|
28
|
+
export interface ProductChoice {
|
|
29
|
+
id: string;
|
|
30
|
+
name: string;
|
|
31
|
+
colorCode?: string;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Initial search state that can be loaded from URL parameters.
|
|
35
|
+
*/
|
|
36
|
+
type InitialSearchState = {
|
|
37
|
+
sort?: SortType;
|
|
38
|
+
limit?: number;
|
|
39
|
+
cursor?: string | null;
|
|
40
|
+
priceRange?: {
|
|
41
|
+
min?: number;
|
|
42
|
+
max?: number;
|
|
43
|
+
};
|
|
44
|
+
inventoryStatuses?: InventoryStatusType[];
|
|
45
|
+
productOptions?: Record<string, string[]>;
|
|
46
|
+
category?: Category;
|
|
47
|
+
visible?: boolean;
|
|
48
|
+
productType?: string;
|
|
49
|
+
};
|
|
50
|
+
/**
|
|
51
|
+
* Configuration interface for the Products List Search service.
|
|
52
|
+
*/
|
|
53
|
+
export type ProductsListSearchServiceConfig = {
|
|
54
|
+
customizations: customizationsV3.Customization[];
|
|
55
|
+
initialSearchState?: InitialSearchState;
|
|
56
|
+
};
|
|
57
|
+
/**
|
|
58
|
+
* Service definition for the Products List Search service.
|
|
59
|
+
* This consolidates sort, pagination, and filtering functionality.
|
|
60
|
+
*/
|
|
61
|
+
export declare const ProductsListSearchServiceDefinition: string & {
|
|
62
|
+
__api: {
|
|
63
|
+
selectedSortOption: Signal<string>;
|
|
64
|
+
sortOptions: SortType[];
|
|
65
|
+
setSelectedSortOption: (sort: string) => void;
|
|
66
|
+
currentLimit: Signal<number>;
|
|
67
|
+
currentCursor: Signal<string | null>;
|
|
68
|
+
hasNextPage: {
|
|
69
|
+
get: () => boolean;
|
|
70
|
+
};
|
|
71
|
+
hasPrevPage: {
|
|
72
|
+
get: () => boolean;
|
|
73
|
+
};
|
|
74
|
+
setLimit: (limit: number) => void;
|
|
75
|
+
nextPage: () => void;
|
|
76
|
+
prevPage: () => void;
|
|
77
|
+
navigateToFirstPage: () => void;
|
|
78
|
+
loadMore: (count: number) => void;
|
|
79
|
+
selectedMinPrice: Signal<number>;
|
|
80
|
+
selectedMaxPrice: Signal<number>;
|
|
81
|
+
availableMinPrice: Signal<number>;
|
|
82
|
+
availableMaxPrice: Signal<number>;
|
|
83
|
+
availableInventoryStatuses: Signal<InventoryStatusType[]>;
|
|
84
|
+
selectedInventoryStatuses: Signal<InventoryStatusType[]>;
|
|
85
|
+
availableProductOptions: Signal<ProductOption[]>;
|
|
86
|
+
selectedProductOptions: Signal<Record<string, string[]>>;
|
|
87
|
+
selectedCategory: Signal<Category | null>;
|
|
88
|
+
setSelectedMinPrice: (minPrice: number) => void;
|
|
89
|
+
setSelectedMaxPrice: (maxPrice: number) => void;
|
|
90
|
+
toggleInventoryStatus: (status: InventoryStatusType) => void;
|
|
91
|
+
toggleProductOption: (optionId: string, choiceId: string) => void;
|
|
92
|
+
setSelectedCategory: (category: Category | null) => void;
|
|
93
|
+
isFiltered: Signal<boolean>;
|
|
94
|
+
reset: () => void;
|
|
95
|
+
};
|
|
96
|
+
__config: {};
|
|
97
|
+
isServiceDefinition?: boolean;
|
|
98
|
+
} & {
|
|
99
|
+
selectedSortOption: Signal<string>;
|
|
100
|
+
sortOptions: SortType[];
|
|
101
|
+
setSelectedSortOption: (sort: string) => void;
|
|
102
|
+
currentLimit: Signal<number>;
|
|
103
|
+
currentCursor: Signal<string | null>;
|
|
104
|
+
hasNextPage: {
|
|
105
|
+
get: () => boolean;
|
|
106
|
+
};
|
|
107
|
+
hasPrevPage: {
|
|
108
|
+
get: () => boolean;
|
|
109
|
+
};
|
|
110
|
+
setLimit: (limit: number) => void;
|
|
111
|
+
nextPage: () => void;
|
|
112
|
+
prevPage: () => void;
|
|
113
|
+
navigateToFirstPage: () => void;
|
|
114
|
+
loadMore: (count: number) => void;
|
|
115
|
+
selectedMinPrice: Signal<number>;
|
|
116
|
+
selectedMaxPrice: Signal<number>;
|
|
117
|
+
availableMinPrice: Signal<number>;
|
|
118
|
+
availableMaxPrice: Signal<number>;
|
|
119
|
+
availableInventoryStatuses: Signal<InventoryStatusType[]>;
|
|
120
|
+
selectedInventoryStatuses: Signal<InventoryStatusType[]>;
|
|
121
|
+
availableProductOptions: Signal<ProductOption[]>;
|
|
122
|
+
selectedProductOptions: Signal<Record<string, string[]>>;
|
|
123
|
+
selectedCategory: Signal<Category | null>;
|
|
124
|
+
setSelectedMinPrice: (minPrice: number) => void;
|
|
125
|
+
setSelectedMaxPrice: (maxPrice: number) => void;
|
|
126
|
+
toggleInventoryStatus: (status: InventoryStatusType) => void;
|
|
127
|
+
toggleProductOption: (optionId: string, choiceId: string) => void;
|
|
128
|
+
setSelectedCategory: (category: Category | null) => void;
|
|
129
|
+
isFiltered: Signal<boolean>;
|
|
130
|
+
reset: () => void;
|
|
131
|
+
};
|
|
132
|
+
/**
|
|
133
|
+
* Convert URL sort format to SortType enum
|
|
134
|
+
*/
|
|
135
|
+
export declare function convertUrlSortToSortType(urlSort: string): SortType | null;
|
|
136
|
+
/**
|
|
137
|
+
* Parse URL and build complete search options with all filters, sort, and pagination
|
|
138
|
+
*/
|
|
139
|
+
export declare function parseUrlForProductsListSearch(url: string, categoriesList: Category[], defaultSearchOptions?: productsV3.V3ProductSearch): Promise<{
|
|
140
|
+
searchOptions: productsV3.V3ProductSearch;
|
|
141
|
+
initialSearchState: InitialSearchState;
|
|
142
|
+
}>;
|
|
143
|
+
/**
|
|
144
|
+
* Load search service configuration from URL
|
|
145
|
+
*/
|
|
146
|
+
export declare function loadProductsListSearchServiceConfig(url: string): Promise<ProductsListSearchServiceConfig>;
|
|
147
|
+
/**
|
|
148
|
+
* Implementation of the Products List Search service
|
|
149
|
+
*/
|
|
150
|
+
export declare const ProductsListSearchService: import("@wix/services-definitions").ServiceFactory<string & {
|
|
151
|
+
__api: {
|
|
152
|
+
selectedSortOption: Signal<string>;
|
|
153
|
+
sortOptions: SortType[];
|
|
154
|
+
setSelectedSortOption: (sort: string) => void;
|
|
155
|
+
currentLimit: Signal<number>;
|
|
156
|
+
currentCursor: Signal<string | null>;
|
|
157
|
+
hasNextPage: {
|
|
158
|
+
get: () => boolean;
|
|
159
|
+
};
|
|
160
|
+
hasPrevPage: {
|
|
161
|
+
get: () => boolean;
|
|
162
|
+
};
|
|
163
|
+
setLimit: (limit: number) => void;
|
|
164
|
+
nextPage: () => void;
|
|
165
|
+
prevPage: () => void;
|
|
166
|
+
navigateToFirstPage: () => void;
|
|
167
|
+
loadMore: (count: number) => void;
|
|
168
|
+
selectedMinPrice: Signal<number>;
|
|
169
|
+
selectedMaxPrice: Signal<number>;
|
|
170
|
+
availableMinPrice: Signal<number>;
|
|
171
|
+
availableMaxPrice: Signal<number>;
|
|
172
|
+
availableInventoryStatuses: Signal<InventoryStatusType[]>;
|
|
173
|
+
selectedInventoryStatuses: Signal<InventoryStatusType[]>;
|
|
174
|
+
availableProductOptions: Signal<ProductOption[]>;
|
|
175
|
+
selectedProductOptions: Signal<Record<string, string[]>>;
|
|
176
|
+
selectedCategory: Signal<Category | null>;
|
|
177
|
+
setSelectedMinPrice: (minPrice: number) => void;
|
|
178
|
+
setSelectedMaxPrice: (maxPrice: number) => void;
|
|
179
|
+
toggleInventoryStatus: (status: InventoryStatusType) => void;
|
|
180
|
+
toggleProductOption: (optionId: string, choiceId: string) => void;
|
|
181
|
+
setSelectedCategory: (category: Category | null) => void;
|
|
182
|
+
isFiltered: Signal<boolean>;
|
|
183
|
+
reset: () => void;
|
|
184
|
+
};
|
|
185
|
+
__config: {};
|
|
186
|
+
isServiceDefinition?: boolean;
|
|
187
|
+
} & {
|
|
188
|
+
selectedSortOption: Signal<string>;
|
|
189
|
+
sortOptions: SortType[];
|
|
190
|
+
setSelectedSortOption: (sort: string) => void;
|
|
191
|
+
currentLimit: Signal<number>;
|
|
192
|
+
currentCursor: Signal<string | null>;
|
|
193
|
+
hasNextPage: {
|
|
194
|
+
get: () => boolean;
|
|
195
|
+
};
|
|
196
|
+
hasPrevPage: {
|
|
197
|
+
get: () => boolean;
|
|
198
|
+
};
|
|
199
|
+
setLimit: (limit: number) => void;
|
|
200
|
+
nextPage: () => void;
|
|
201
|
+
prevPage: () => void;
|
|
202
|
+
navigateToFirstPage: () => void;
|
|
203
|
+
loadMore: (count: number) => void;
|
|
204
|
+
selectedMinPrice: Signal<number>;
|
|
205
|
+
selectedMaxPrice: Signal<number>;
|
|
206
|
+
availableMinPrice: Signal<number>;
|
|
207
|
+
availableMaxPrice: Signal<number>;
|
|
208
|
+
availableInventoryStatuses: Signal<InventoryStatusType[]>;
|
|
209
|
+
selectedInventoryStatuses: Signal<InventoryStatusType[]>;
|
|
210
|
+
availableProductOptions: Signal<ProductOption[]>;
|
|
211
|
+
selectedProductOptions: Signal<Record<string, string[]>>;
|
|
212
|
+
selectedCategory: Signal<Category | null>;
|
|
213
|
+
setSelectedMinPrice: (minPrice: number) => void;
|
|
214
|
+
setSelectedMaxPrice: (maxPrice: number) => void;
|
|
215
|
+
toggleInventoryStatus: (status: InventoryStatusType) => void;
|
|
216
|
+
toggleProductOption: (optionId: string, choiceId: string) => void;
|
|
217
|
+
setSelectedCategory: (category: Category | null) => void;
|
|
218
|
+
isFiltered: Signal<boolean>;
|
|
219
|
+
reset: () => void;
|
|
220
|
+
}, ProductsListSearchServiceConfig>;
|