@pisell/pisellos 2.2.78 → 2.2.79
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/core/index.d.ts +2 -2
- package/dist/modules/ProductList/index.d.ts +3 -0
- package/dist/modules/ProductList/index.js +9 -7
- package/dist/plugins/request.d.ts +2 -0
- package/dist/server/index.d.ts +27 -2
- package/dist/server/index.js +499 -295
- package/dist/server/modules/products/index.d.ts +101 -3
- package/dist/server/modules/products/index.js +1378 -242
- package/dist/server/modules/products/types.d.ts +24 -1
- package/dist/server/modules/products/types.js +3 -0
- package/dist/server/utils/product.d.ts +1 -0
- package/dist/server/utils/product.js +35 -25
- package/dist/solution/BookingTicket/index.d.ts +9 -1
- package/dist/solution/BookingTicket/index.js +41 -28
- package/dist/types/index.d.ts +3 -0
- package/lib/core/index.d.ts +2 -2
- package/lib/modules/ProductList/index.d.ts +3 -0
- package/lib/modules/ProductList/index.js +2 -2
- package/lib/plugins/request.d.ts +2 -0
- package/lib/server/index.d.ts +27 -2
- package/lib/server/index.js +172 -95
- package/lib/server/modules/products/index.d.ts +101 -3
- package/lib/server/modules/products/index.js +595 -52
- package/lib/server/modules/products/types.d.ts +24 -1
- package/lib/server/modules/products/types.js +1 -0
- package/lib/server/utils/product.d.ts +1 -0
- package/lib/server/utils/product.js +27 -11
- package/lib/solution/BookingTicket/index.d.ts +9 -1
- package/lib/solution/BookingTicket/index.js +10 -2
- package/lib/types/index.d.ts +3 -0
- package/package.json +1 -1
|
@@ -19,6 +19,9 @@ export declare class ProductsModule extends BaseModule implements Module {
|
|
|
19
19
|
private readonly CACHE_MAX_DAYS;
|
|
20
20
|
private formatters;
|
|
21
21
|
private isPriceFormatterRegistered;
|
|
22
|
+
private productDataSource;
|
|
23
|
+
private pendingSyncMessages;
|
|
24
|
+
private syncTimer?;
|
|
22
25
|
constructor(name?: string, version?: string);
|
|
23
26
|
initialize(core: PisellCore, options: any): Promise<void>;
|
|
24
27
|
/**
|
|
@@ -107,26 +110,57 @@ export declare class ProductsModule extends BaseModule implements Module {
|
|
|
107
110
|
* 可用于手动刷新价格数据
|
|
108
111
|
*/
|
|
109
112
|
clearPriceCache(): void;
|
|
113
|
+
/**
|
|
114
|
+
* 通过 ProductDataSource SSE 加载完整商品列表
|
|
115
|
+
*/
|
|
116
|
+
loadProductsByServer(): Promise<any>;
|
|
117
|
+
/**
|
|
118
|
+
* 纯请求方法:通过 HTTP 接口获取商品列表(无副作用,不触发事件、不写 IndexDB)
|
|
119
|
+
* @param params 查询参数
|
|
120
|
+
* @returns 商品列表
|
|
121
|
+
*/
|
|
122
|
+
private fetchProductsByHttp;
|
|
110
123
|
/**
|
|
111
124
|
* 加载完整商品列表通过接口(包含所有详细数据)
|
|
125
|
+
* 包含副作用:保存到 IndexDB + 触发 onProductsLoaded 事件
|
|
112
126
|
* @param params 查询参数
|
|
113
127
|
*/
|
|
114
|
-
|
|
128
|
+
loadProductsByServerHttp(params?: {
|
|
115
129
|
category_ids?: number[];
|
|
116
130
|
product_ids?: number[];
|
|
117
131
|
collection?: number | string[];
|
|
118
132
|
customer_id?: number;
|
|
119
133
|
cacheId?: string;
|
|
120
|
-
}): Promise<
|
|
134
|
+
}): Promise<ProductData[]>;
|
|
121
135
|
/**
|
|
122
|
-
*
|
|
136
|
+
* 获取商品列表(深拷贝,供外部安全使用)
|
|
123
137
|
*/
|
|
124
138
|
getProducts(): Promise<ProductData[]>;
|
|
139
|
+
/**
|
|
140
|
+
* 内部获取商品列表的直接引用(无拷贝)
|
|
141
|
+
* 仅供内部 formatter 流程使用,因为 formatter 会创建新对象
|
|
142
|
+
*/
|
|
143
|
+
private getProductsRef;
|
|
125
144
|
/**
|
|
126
145
|
* 根据ID获取单个商品(从内存缓存)
|
|
127
146
|
* 使用 Map 快速查询,时间复杂度 O(1)
|
|
128
147
|
*/
|
|
129
148
|
getProductById(id: number): Promise<ProductData | undefined>;
|
|
149
|
+
/**
|
|
150
|
+
* 根据 ID 列表删除商品(用于 pubsub 同步删除场景)
|
|
151
|
+
* 同时更新 store.list、store.map、IndexDB 和价格缓存
|
|
152
|
+
*/
|
|
153
|
+
removeProductsByIds(ids: number[]): Promise<void>;
|
|
154
|
+
/**
|
|
155
|
+
* 重新从服务器加载全量商品列表并更新本地 store
|
|
156
|
+
* 用于 pubsub 同步 create / update / batch_update 场景
|
|
157
|
+
*/
|
|
158
|
+
refreshProducts(): Promise<ProductData[]>;
|
|
159
|
+
/**
|
|
160
|
+
* 局部更新指定商品的报价单价格
|
|
161
|
+
* 遍历所有已缓存的日期,为目标商品重新获取价格并覆盖到缓存中
|
|
162
|
+
*/
|
|
163
|
+
updateProductPriceByIds(ids: number[]): Promise<void>;
|
|
130
164
|
/**
|
|
131
165
|
* 清空缓存
|
|
132
166
|
*/
|
|
@@ -152,6 +186,70 @@ export declare class ProductsModule extends BaseModule implements Module {
|
|
|
152
186
|
* 在模块注册后自动调用
|
|
153
187
|
*/
|
|
154
188
|
preload(): Promise<void>;
|
|
189
|
+
/**
|
|
190
|
+
* 初始化 ProductDataSource 实例
|
|
191
|
+
* 与 pubsub 订阅和数据获取分开,仅负责创建实例
|
|
192
|
+
*/
|
|
193
|
+
private initProductDataSource;
|
|
194
|
+
/**
|
|
195
|
+
* 初始化 pubsub 订阅,监听管理后台商品变更
|
|
196
|
+
* 仅负责订阅 product / product_quotation 频道,消息通过防抖合并后批量处理
|
|
197
|
+
* 数据获取由 loadProductsByServer 单独负责
|
|
198
|
+
*/
|
|
199
|
+
private setupProductSync;
|
|
200
|
+
/**
|
|
201
|
+
* 处理防抖后的同步消息批次
|
|
202
|
+
*
|
|
203
|
+
* product 模块:
|
|
204
|
+
* - operation === 'delete' → 本地删除
|
|
205
|
+
* - 有 body(无 price change_types) → body 完整数据直接覆盖本地
|
|
206
|
+
* - change_types 包含 price → SSE 增量拉取 + 刷新报价单价格缓存
|
|
207
|
+
* - change_types 仅 stock → 跳过(暂不响应)
|
|
208
|
+
*
|
|
209
|
+
* product_collection / product_category / product_quotation:
|
|
210
|
+
* - 按 relation_product_ids SSE 拉取受影响商品
|
|
211
|
+
* - product_quotation 额外刷新报价单价格缓存
|
|
212
|
+
*
|
|
213
|
+
* 处理完成后 emit onProductsSyncCompleted 通知 Server 层
|
|
214
|
+
*/
|
|
215
|
+
private processProductSyncMessages;
|
|
216
|
+
/**
|
|
217
|
+
* 通过 SSE 按 ids 增量拉取商品数据
|
|
218
|
+
* 请求 GET /shop/core/stream?type=product&ids={ids}
|
|
219
|
+
*/
|
|
220
|
+
private fetchProductsBySSE;
|
|
221
|
+
/**
|
|
222
|
+
* 将 body 完整数据直接覆盖到本地 store(不调用报价单接口)
|
|
223
|
+
* 已存在的 → 直接替换;不存在的 → 追加
|
|
224
|
+
* 同时更新 Map 缓存、IndexDB,清空价格缓存,触发 onProductsChanged
|
|
225
|
+
*/
|
|
226
|
+
private applyBodyUpdatesToStore;
|
|
227
|
+
/**
|
|
228
|
+
* 将增量拉取的商品合并到 store
|
|
229
|
+
* 已存在的 → 替换;新的 → 追加
|
|
230
|
+
* 同时更新 store.map、IndexDB,触发 onProductsChanged
|
|
231
|
+
*/
|
|
232
|
+
private mergeProductsToStore;
|
|
233
|
+
/**
|
|
234
|
+
* 增量更新价格缓存中变更的商品
|
|
235
|
+
* 对每个已缓存的日期 key:替换/追加最新商品数据,重新拉取这些 ID 的价格并应用
|
|
236
|
+
*/
|
|
237
|
+
private updatePriceCacheForProducts;
|
|
238
|
+
/**
|
|
239
|
+
* 全量重新拉取报价单价格并重建价格缓存
|
|
240
|
+
* 遍历当前已缓存的所有日期 key,对每个日期重新调用 loadProductsPrice
|
|
241
|
+
*/
|
|
242
|
+
private refreshAllPriceCache;
|
|
243
|
+
/**
|
|
244
|
+
* 静默全量刷新:后台重新拉取全量 SSE 数据并更新本地
|
|
245
|
+
* 拿到完整数据后一次性替换 store,清除价格缓存,触发 onProductsSyncCompleted
|
|
246
|
+
* @returns 刷新后的商品列表
|
|
247
|
+
*/
|
|
248
|
+
silentRefresh(): Promise<ProductData[]>;
|
|
249
|
+
/**
|
|
250
|
+
* 销毁同步资源(取消 pubsub 订阅、清除定时器)
|
|
251
|
+
*/
|
|
252
|
+
destroyProductSync(): void;
|
|
155
253
|
/**
|
|
156
254
|
* 获取模块的路由定义
|
|
157
255
|
* Products 模块暂不提供路由,由 Server 层统一处理
|