react-native-fxview 1.0.2 → 1.0.3-beta2

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.
@@ -1,6 +1,7 @@
1
1
  import React from "react";
2
2
  import { FXComponentController, FXComponentItem } from "./types";
3
3
  import { FXCategoryController } from "./FXCategoryController";
4
+ import logger from "./logger/FXLogger";
4
5
 
5
6
  export class FXViewController {
6
7
  public fxViewId: string;
@@ -27,7 +28,7 @@ export class FXViewController {
27
28
  categoryId?: string,
28
29
  componentId?: string,
29
30
  ): FXComponentController {
30
- console.log("FXViewController.add", `[${this.fxViewId}]`, {
31
+ logger.info("FXViewController.add", `[${this.fxViewId}]`, {
31
32
  categoryId,
32
33
  componentId,
33
34
  });
@@ -48,7 +49,7 @@ export class FXViewController {
48
49
  categoryId?: string,
49
50
  componentId?: string,
50
51
  ): FXComponentController {
51
- console.log("FXViewController.build", `[${this.fxViewId}]`, {
52
+ logger.info("FXViewController.build", `[${this.fxViewId}]`, {
52
53
  categoryId,
53
54
  componentId,
54
55
  });
@@ -63,14 +64,14 @@ export class FXViewController {
63
64
  * @param categoryId 分类 ID(可选,默认 "default")
64
65
  */
65
66
  show(componentId: string, categoryId?: string): void {
66
- console.log("FXViewController.show", `[${this.fxViewId}]`, {
67
+ logger.info("FXViewController.show", `[${this.fxViewId}]`, {
67
68
  categoryId,
68
69
  componentId,
69
70
  });
70
71
 
71
72
  const categoryController = this.getCategoryController(categoryId);
72
73
  if (!categoryController) {
73
- console.warn(
74
+ logger.warn(
74
75
  `CategoryController ${categoryId || "default"} not found in view ${this.fxViewId}`,
75
76
  );
76
77
  return;
@@ -85,14 +86,14 @@ export class FXViewController {
85
86
  * @param categoryId 分类 ID(可选,默认 "default")
86
87
  */
87
88
  hide(componentId: string, categoryId?: string): void {
88
- console.log("FXViewController.hide", `[${this.fxViewId}]`, {
89
+ logger.info("FXViewController.hide", `[${this.fxViewId}]`, {
89
90
  categoryId,
90
91
  componentId,
91
92
  });
92
93
 
93
94
  const categoryController = this.getCategoryController(categoryId);
94
95
  if (!categoryController) {
95
- console.warn(
96
+ logger.warn(
96
97
  `CategoryController ${categoryId || "default"} not found in view ${this.fxViewId}`,
97
98
  );
98
99
  return;
@@ -112,14 +113,14 @@ export class FXViewController {
112
113
  component: React.ReactNode,
113
114
  categoryId?: string,
114
115
  ): void {
115
- console.log("FXViewController.update", `[${this.fxViewId}]`, {
116
+ logger.info("FXViewController.update", `[${this.fxViewId}]`, {
116
117
  categoryId,
117
118
  componentId,
118
119
  });
119
120
 
120
121
  const categoryController = this.getCategoryController(categoryId);
121
122
  if (!categoryController) {
122
- console.warn(
123
+ logger.warn(
123
124
  `CategoryController ${categoryId || "default"} not found in view ${this.fxViewId}`,
124
125
  );
125
126
  return;
@@ -134,14 +135,14 @@ export class FXViewController {
134
135
  * @param categoryId 分类 ID(可选,默认 "default")
135
136
  */
136
137
  remove(componentId: string, categoryId?: string): void {
137
- console.log("FXViewController.remove", `[${this.fxViewId}]`, {
138
+ logger.info("FXViewController.remove", `[${this.fxViewId}]`, {
138
139
  categoryId,
139
140
  componentId,
140
141
  });
141
142
 
142
143
  const categoryController = this.getCategoryController(categoryId);
143
144
  if (!categoryController) {
144
- console.warn(
145
+ logger.warn(
145
146
  `CategoryController ${categoryId || "default"} not found in view ${this.fxViewId}`,
146
147
  );
147
148
  return;
@@ -160,13 +161,13 @@ export class FXViewController {
160
161
  * @param categoryId 分类 ID(可选,默认 "default")
161
162
  */
162
163
  removeLast(categoryId?: string): void {
163
- console.log("FXViewController.removeLast", `[${this.fxViewId}]`, {
164
+ logger.info("FXViewController.removeLast", `[${this.fxViewId}]`, {
164
165
  categoryId,
165
166
  });
166
167
 
167
168
  const categoryController = this.getCategoryController(categoryId);
168
169
  if (!categoryController) {
169
- console.warn(
170
+ logger.warn(
170
171
  `CategoryController ${categoryId || "default"} not found in view ${this.fxViewId}`,
171
172
  );
172
173
  return;
@@ -184,13 +185,13 @@ export class FXViewController {
184
185
  * 清空所有分类的所有组件
185
186
  */
186
187
  clearAll(): void {
187
- console.log("FXViewController.clearAll", `[${this.fxViewId}]`);
188
+ logger.info("FXViewController.clearAll", `[${this.fxViewId}]`);
188
189
 
189
190
  this.categoryControllerMap.forEach((controller) => {
190
191
  controller.clearAll();
191
192
  });
192
193
  this.categoryControllerMap.clear();
193
- console.log(
194
+ logger.info(
194
195
  "FXViewController.clearAll done",
195
196
  this.categoryControllerMap.size,
196
197
  );
@@ -202,13 +203,13 @@ export class FXViewController {
202
203
  */
203
204
  clearCategory(categoryId?: string): void {
204
205
  const finalCategoryId = categoryId || "default";
205
- console.log("FXViewController.clearCategory", `[${this.fxViewId}]`, {
206
+ logger.info("FXViewController.clearCategory", `[${this.fxViewId}]`, {
206
207
  categoryId: finalCategoryId,
207
208
  });
208
209
 
209
210
  const categoryController = this.getCategoryController(categoryId);
210
211
  if (!categoryController) {
211
- console.warn(
212
+ logger.warn(
212
213
  `CategoryController ${finalCategoryId} not found in view ${this.fxViewId}`,
213
214
  );
214
215
  return;
@@ -363,7 +364,7 @@ export class FXViewController {
363
364
  */
364
365
  private removeCategory(categoryId?: string): void {
365
366
  const finalCategoryId = categoryId || "default";
366
- console.log("FXViewController.removeCategory", `[${this.fxViewId}]`, {
367
+ logger.info("FXViewController.removeCategory", `[${this.fxViewId}]`, {
367
368
  categoryId: finalCategoryId,
368
369
  });
369
370
  this.categoryControllerMap.delete(finalCategoryId);
@@ -84,7 +84,15 @@ export declare class FXViewManager {
84
84
  * @returns 是否成功注销
85
85
  */
86
86
  unregisterView(fxViewId: string): boolean;
87
+ /**
88
+ * 注册生命周期回调
89
+ * @param callbacks 生命周期回调
90
+ */
87
91
  registerLifecycleCallbacks(callbacks: FXLifecycleCallbacks): void;
92
+ /**
93
+ * 注销生命周期回调
94
+ * @param callbacks 生命周期回调
95
+ */
88
96
  unregisterLifecycleCallbacks(callbacks: FXLifecycleCallbacks): void;
89
97
  /**
90
98
  * 获取最近使用的视图 ID(栈顶)
@@ -144,3 +152,5 @@ export declare class FXViewManager {
144
152
  */
145
153
  private autoFXViewId;
146
154
  }
155
+ declare const FXManager: FXViewManager;
156
+ export default FXManager;
package/FXViewManager.js CHANGED
@@ -1,8 +1,12 @@
1
1
  "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
2
5
  Object.defineProperty(exports, "__esModule", { value: true });
3
6
  exports.FXViewManager = void 0;
4
7
  const FXViewController_1 = require("./FXViewController");
5
8
  const PriorityQueue_1 = require("./queue/PriorityQueue");
9
+ const FXLogger_1 = __importDefault(require("./logger/FXLogger"));
6
10
  class FXViewManager {
7
11
  constructor() {
8
12
  // 存储视图控制器
@@ -27,7 +31,7 @@ class FXViewManager {
27
31
  * @returns 组件控制器
28
32
  */
29
33
  add(component, fxViewId, categoryId, componentId) {
30
- console.log("FXViewManager.add", {
34
+ FXLogger_1.default.log("FXViewManager", "add", {
31
35
  fxViewId,
32
36
  categoryId,
33
37
  componentId,
@@ -44,7 +48,7 @@ class FXViewManager {
44
48
  * @returns 组件控制器
45
49
  */
46
50
  build(component, fxViewId, categoryId, componentId) {
47
- console.log("FXViewManager.build", {
51
+ FXLogger_1.default.log("FXViewManager", "build", {
48
52
  fxViewId,
49
53
  categoryId,
50
54
  componentId,
@@ -59,14 +63,14 @@ class FXViewManager {
59
63
  * @param categoryId 分类 ID(可选,默认 "default")
60
64
  */
61
65
  show(componentId, fxViewId, categoryId) {
62
- console.log("FXViewManager.show", {
66
+ FXLogger_1.default.log("FXViewManager", "show", {
63
67
  fxViewId,
64
68
  categoryId,
65
69
  componentId,
66
70
  });
67
71
  const viewController = this.getViewController(fxViewId);
68
72
  if (!viewController) {
69
- console.warn(`FXView ${fxViewId || "latest"} not found`);
73
+ FXLogger_1.default.warn("FXViewManager", `FXView ${fxViewId || "latest"} not found`);
70
74
  return;
71
75
  }
72
76
  viewController.show(componentId, categoryId);
@@ -78,14 +82,14 @@ class FXViewManager {
78
82
  * @param categoryId 分类 ID(可选,默认 "default")
79
83
  */
80
84
  hide(componentId, fxViewId, categoryId) {
81
- console.log("FXViewManager.hide", {
85
+ FXLogger_1.default.log("FXViewManager", "hide", {
82
86
  fxViewId,
83
87
  categoryId,
84
88
  componentId,
85
89
  });
86
90
  const viewController = this.getViewController(fxViewId);
87
91
  if (!viewController) {
88
- console.warn(`FXView ${fxViewId || "latest"} not found`);
92
+ FXLogger_1.default.warn("FXViewManager", `FXView ${fxViewId || "latest"} not found`);
89
93
  return;
90
94
  }
91
95
  viewController.hide(componentId, categoryId);
@@ -98,14 +102,14 @@ class FXViewManager {
98
102
  * @param categoryId 分类 ID(可选,默认 "default")
99
103
  */
100
104
  update(componentId, component, fxViewId, categoryId) {
101
- console.log("FXViewManager.update", {
105
+ FXLogger_1.default.log("FXViewManager", "update", {
102
106
  fxViewId,
103
107
  categoryId,
104
108
  componentId,
105
109
  });
106
110
  const viewController = this.getViewController(fxViewId);
107
111
  if (!viewController) {
108
- console.warn(`FXView ${fxViewId || "latest"} not found`);
112
+ FXLogger_1.default.warn("FXViewManager", `FXView ${fxViewId || "latest"} not found`);
109
113
  return;
110
114
  }
111
115
  viewController.update(componentId, component, categoryId);
@@ -117,14 +121,14 @@ class FXViewManager {
117
121
  * @param categoryId 分类 ID(可选,默认 "default")
118
122
  */
119
123
  remove(componentId, fxViewId, categoryId) {
120
- console.log("FXViewManager.remove", {
124
+ FXLogger_1.default.log("FXViewManager", "remove", {
121
125
  fxViewId,
122
126
  categoryId,
123
127
  componentId,
124
128
  });
125
129
  const viewController = this.getViewController(fxViewId);
126
130
  if (!viewController) {
127
- console.warn(`FXView ${fxViewId || "latest"} not found`);
131
+ FXLogger_1.default.warn("FXViewManager", `FXView ${fxViewId || "latest"} not found`);
128
132
  return;
129
133
  }
130
134
  viewController.remove(componentId, categoryId);
@@ -135,13 +139,13 @@ class FXViewManager {
135
139
  * @param categoryId 分类 ID(可选,默认 "default")
136
140
  */
137
141
  removeLast(fxViewId, categoryId) {
138
- console.log("FXViewManager.removeLast", {
142
+ FXLogger_1.default.log("FXViewManager", "removeLast", {
139
143
  fxViewId,
140
144
  categoryId,
141
145
  });
142
146
  const viewController = this.getViewController(fxViewId);
143
147
  if (!viewController) {
144
- console.warn(`FXView ${fxViewId || "latest"} not found`);
148
+ FXLogger_1.default.warn("FXViewManager", `FXView ${fxViewId || "latest"} not found`);
145
149
  return;
146
150
  }
147
151
  viewController.removeLast(categoryId);
@@ -151,7 +155,7 @@ class FXViewManager {
151
155
  * @param fxViewId 视图 ID(可选,清空所有视图)
152
156
  */
153
157
  clearAll(fxViewId) {
154
- console.log("FXViewManager.clearAll", { fxViewId });
158
+ FXLogger_1.default.log("FXViewManager", "clearAll", { fxViewId });
155
159
  if (fxViewId) {
156
160
  // 清空指定视图
157
161
  const viewController = this.getViewController(fxViewId);
@@ -172,10 +176,10 @@ class FXViewManager {
172
176
  * @param fxViewId 视图 ID(可选,使用最近的视图)
173
177
  */
174
178
  clearCategory(categoryId, fxViewId) {
175
- console.log("FXViewManager.clearCategory", { fxViewId, categoryId });
179
+ FXLogger_1.default.log("FXViewManager", "clearCategory", { fxViewId, categoryId });
176
180
  const viewController = this.getViewController(fxViewId);
177
181
  if (!viewController) {
178
- console.warn(`FXView ${fxViewId || "latest"} not found`);
182
+ FXLogger_1.default.warn("FXViewManager", `FXView ${fxViewId || "latest"} not found`);
179
183
  return;
180
184
  }
181
185
  viewController.clearCategory(categoryId);
@@ -189,7 +193,7 @@ class FXViewManager {
189
193
  * @returns 视图控制器
190
194
  */
191
195
  registerView(fxViewId, updateCallback) {
192
- console.log("FXViewManager.registerView", fxViewId);
196
+ FXLogger_1.default.log("FXViewManager", "registerView", fxViewId);
193
197
  let viewController = this.viewControllerMap.get(fxViewId);
194
198
  if (!viewController) {
195
199
  viewController = new FXViewController_1.FXViewController(fxViewId);
@@ -197,9 +201,7 @@ class FXViewManager {
197
201
  }
198
202
  // 注册更新回调
199
203
  viewController.registerUpdateCallback(updateCallback);
200
- if (this.fxViewIdQueue.find((id) => id === fxViewId) !== null) {
201
- this.fxViewIdQueue.remove(fxViewId);
202
- }
204
+ this.fxViewIdQueue.remove(fxViewId);
203
205
  this.fxViewIdQueue.enqueue(fxViewId);
204
206
  this.viewLifecycleCallbacks.forEach((callback) => {
205
207
  var _a;
@@ -213,10 +215,10 @@ class FXViewManager {
213
215
  * @returns 是否成功注销
214
216
  */
215
217
  unregisterView(fxViewId) {
216
- console.log("FXViewManager.unregisterView", fxViewId);
218
+ FXLogger_1.default.log("FXViewManager", "unregisterView", fxViewId);
217
219
  const viewController = this.getViewController(fxViewId);
218
220
  if (!viewController) {
219
- console.warn(`FXView ${fxViewId} not found, cannot unregister`);
221
+ FXLogger_1.default.warn("FXViewManager", `FXView ${fxViewId} not found, cannot unregister`);
220
222
  return false;
221
223
  }
222
224
  // 清空回调
@@ -233,12 +235,20 @@ class FXViewManager {
233
235
  });
234
236
  return true;
235
237
  }
238
+ /**
239
+ * 注册生命周期回调
240
+ * @param callbacks 生命周期回调
241
+ */
236
242
  registerLifecycleCallbacks(callbacks) {
237
- console.log("FXViewManager.registerLifecycleCallbacks");
243
+ FXLogger_1.default.log("FXViewManager", "registerLifecycleCallbacks");
238
244
  this.viewLifecycleCallbacks.push(callbacks);
239
245
  }
246
+ /**
247
+ * 注销生命周期回调
248
+ * @param callbacks 生命周期回调
249
+ */
240
250
  unregisterLifecycleCallbacks(callbacks) {
241
- console.log("FXViewManager.unregisterLifecycleCallbacks");
251
+ FXLogger_1.default.log("FXViewManager", "unregisterLifecycleCallbacks");
242
252
  this.viewLifecycleCallbacks = this.viewLifecycleCallbacks.filter((callback) => callback !== callbacks);
243
253
  }
244
254
  /**
@@ -255,15 +265,15 @@ class FXViewManager {
255
265
  * @returns 组件列表
256
266
  */
257
267
  getComponents(fxViewId, categoryId) {
258
- console.log("FXViewManager.getComponents", { fxViewId, categoryId });
268
+ FXLogger_1.default.log("FXViewManager", "getComponents", { fxViewId, categoryId });
259
269
  const finalFXViewId = fxViewId || this.getLatestFXViewId();
260
270
  if (!finalFXViewId) {
261
- console.warn("No FXView available");
271
+ FXLogger_1.default.warn("FXViewManager", "No FXView available");
262
272
  return [];
263
273
  }
264
274
  const viewController = this.getViewController(finalFXViewId);
265
275
  if (!viewController) {
266
- console.warn(`FXViewController ${finalFXViewId} not found`);
276
+ FXLogger_1.default.warn("FXViewManager", `FXViewController ${finalFXViewId} not found`);
267
277
  return [];
268
278
  }
269
279
  return viewController.getComponents(categoryId);
@@ -322,7 +332,7 @@ class FXViewManager {
322
332
  getViewController(fxViewId) {
323
333
  const finalFXViewId = fxViewId || this.getLatestFXViewId();
324
334
  if (!finalFXViewId) {
325
- console.warn("FXViewManager.getViewController: no fxViewId available");
335
+ FXLogger_1.default.warn("FXViewManager", "getViewController: no fxViewId available");
326
336
  return null;
327
337
  }
328
338
  return this.viewControllerMap.get(finalFXViewId) || null;
@@ -336,7 +346,7 @@ class FXViewManager {
336
346
  const finalFXViewId = fxViewId || this.getLatestFXViewId() || this.autoFXViewId();
337
347
  let viewController = this.viewControllerMap.get(finalFXViewId);
338
348
  if (!viewController) {
339
- console.warn(`FXViewController ${finalFXViewId} not registered, creating a temporary one`);
349
+ FXLogger_1.default.warn("FXViewManager", `FXViewController ${finalFXViewId} not registered, creating a temporary one`);
340
350
  viewController = new FXViewController_1.FXViewController(finalFXViewId);
341
351
  this.viewControllerMap.set(finalFXViewId, viewController);
342
352
  this.fxViewIdQueue.enqueue(finalFXViewId);
@@ -352,3 +362,5 @@ class FXViewManager {
352
362
  }
353
363
  }
354
364
  exports.FXViewManager = FXViewManager;
365
+ const FXManager = FXViewManager.getInstance();
366
+ exports.default = FXManager;
package/FXViewManager.ts CHANGED
@@ -6,6 +6,7 @@ import {
6
6
  } from "./types";
7
7
  import { FXViewController } from "./FXViewController";
8
8
  import { HeapType, PriorityOrder, PriorityQueue } from "./queue/PriorityQueue";
9
+ import logger from "./logger/FXLogger";
9
10
 
10
11
  export class FXViewManager {
11
12
  private static instance: FXViewManager;
@@ -41,7 +42,7 @@ export class FXViewManager {
41
42
  categoryId?: string,
42
43
  componentId?: string,
43
44
  ): FXComponentController {
44
- console.log("FXViewManager.add", {
45
+ logger.log("FXViewManager", "add", {
45
46
  fxViewId,
46
47
  categoryId,
47
48
  componentId,
@@ -65,7 +66,7 @@ export class FXViewManager {
65
66
  categoryId?: string,
66
67
  componentId?: string,
67
68
  ): FXComponentController {
68
- console.log("FXViewManager.build", {
69
+ logger.log("FXViewManager", "build", {
69
70
  fxViewId,
70
71
  categoryId,
71
72
  componentId,
@@ -82,7 +83,7 @@ export class FXViewManager {
82
83
  * @param categoryId 分类 ID(可选,默认 "default")
83
84
  */
84
85
  show(componentId: string, fxViewId?: string, categoryId?: string): void {
85
- console.log("FXViewManager.show", {
86
+ logger.log("FXViewManager", "show", {
86
87
  fxViewId,
87
88
  categoryId,
88
89
  componentId,
@@ -90,7 +91,7 @@ export class FXViewManager {
90
91
 
91
92
  const viewController = this.getViewController(fxViewId);
92
93
  if (!viewController) {
93
- console.warn(`FXView ${fxViewId || "latest"} not found`);
94
+ logger.warn("FXViewManager", `FXView ${fxViewId || "latest"} not found`);
94
95
  return;
95
96
  }
96
97
 
@@ -104,7 +105,7 @@ export class FXViewManager {
104
105
  * @param categoryId 分类 ID(可选,默认 "default")
105
106
  */
106
107
  hide(componentId: string, fxViewId?: string, categoryId?: string): void {
107
- console.log("FXViewManager.hide", {
108
+ logger.log("FXViewManager", "hide", {
108
109
  fxViewId,
109
110
  categoryId,
110
111
  componentId,
@@ -112,7 +113,7 @@ export class FXViewManager {
112
113
 
113
114
  const viewController = this.getViewController(fxViewId);
114
115
  if (!viewController) {
115
- console.warn(`FXView ${fxViewId || "latest"} not found`);
116
+ logger.warn("FXViewManager", `FXView ${fxViewId || "latest"} not found`);
116
117
  return;
117
118
  }
118
119
 
@@ -132,7 +133,7 @@ export class FXViewManager {
132
133
  fxViewId?: string,
133
134
  categoryId?: string,
134
135
  ): void {
135
- console.log("FXViewManager.update", {
136
+ logger.log("FXViewManager", "update", {
136
137
  fxViewId,
137
138
  categoryId,
138
139
  componentId,
@@ -140,7 +141,7 @@ export class FXViewManager {
140
141
 
141
142
  const viewController = this.getViewController(fxViewId);
142
143
  if (!viewController) {
143
- console.warn(`FXView ${fxViewId || "latest"} not found`);
144
+ logger.warn("FXViewManager", `FXView ${fxViewId || "latest"} not found`);
144
145
  return;
145
146
  }
146
147
 
@@ -154,7 +155,7 @@ export class FXViewManager {
154
155
  * @param categoryId 分类 ID(可选,默认 "default")
155
156
  */
156
157
  remove(componentId: string, fxViewId?: string, categoryId?: string): void {
157
- console.log("FXViewManager.remove", {
158
+ logger.log("FXViewManager", "remove", {
158
159
  fxViewId,
159
160
  categoryId,
160
161
  componentId,
@@ -162,7 +163,7 @@ export class FXViewManager {
162
163
 
163
164
  const viewController = this.getViewController(fxViewId);
164
165
  if (!viewController) {
165
- console.warn(`FXView ${fxViewId || "latest"} not found`);
166
+ logger.warn("FXViewManager", `FXView ${fxViewId || "latest"} not found`);
166
167
  return;
167
168
  }
168
169
 
@@ -175,14 +176,14 @@ export class FXViewManager {
175
176
  * @param categoryId 分类 ID(可选,默认 "default")
176
177
  */
177
178
  removeLast(fxViewId?: string, categoryId?: string): void {
178
- console.log("FXViewManager.removeLast", {
179
+ logger.log("FXViewManager", "removeLast", {
179
180
  fxViewId,
180
181
  categoryId,
181
182
  });
182
183
 
183
184
  const viewController = this.getViewController(fxViewId);
184
185
  if (!viewController) {
185
- console.warn(`FXView ${fxViewId || "latest"} not found`);
186
+ logger.warn("FXViewManager", `FXView ${fxViewId || "latest"} not found`);
186
187
  return;
187
188
  }
188
189
 
@@ -194,7 +195,7 @@ export class FXViewManager {
194
195
  * @param fxViewId 视图 ID(可选,清空所有视图)
195
196
  */
196
197
  clearAll(fxViewId?: string): void {
197
- console.log("FXViewManager.clearAll", { fxViewId });
198
+ logger.log("FXViewManager", "clearAll", { fxViewId });
198
199
 
199
200
  if (fxViewId) {
200
201
  // 清空指定视图
@@ -216,11 +217,11 @@ export class FXViewManager {
216
217
  * @param fxViewId 视图 ID(可选,使用最近的视图)
217
218
  */
218
219
  clearCategory(categoryId: string, fxViewId?: string): void {
219
- console.log("FXViewManager.clearCategory", { fxViewId, categoryId });
220
+ logger.log("FXViewManager", "clearCategory", { fxViewId, categoryId });
220
221
 
221
222
  const viewController = this.getViewController(fxViewId);
222
223
  if (!viewController) {
223
- console.warn(`FXView ${fxViewId || "latest"} not found`);
224
+ logger.warn("FXViewManager", `FXView ${fxViewId || "latest"} not found`);
224
225
  return;
225
226
  }
226
227
 
@@ -238,7 +239,7 @@ export class FXViewManager {
238
239
  * @returns 视图控制器
239
240
  */
240
241
  registerView(fxViewId: string, updateCallback: () => void): FXViewController {
241
- console.log("FXViewManager.registerView", fxViewId);
242
+ logger.log("FXViewManager", "registerView", fxViewId);
242
243
 
243
244
  let viewController = this.viewControllerMap.get(fxViewId);
244
245
 
@@ -249,9 +250,7 @@ export class FXViewManager {
249
250
 
250
251
  // 注册更新回调
251
252
  viewController.registerUpdateCallback(updateCallback);
252
- if (this.fxViewIdQueue.find((id) => id === fxViewId) !== null) {
253
- this.fxViewIdQueue.remove(fxViewId);
254
- }
253
+ this.fxViewIdQueue.remove(fxViewId);
255
254
  this.fxViewIdQueue.enqueue(fxViewId);
256
255
  this.viewLifecycleCallbacks.forEach((callback) => {
257
256
  callback.didMount?.(fxViewId);
@@ -265,11 +264,14 @@ export class FXViewManager {
265
264
  * @returns 是否成功注销
266
265
  */
267
266
  unregisterView(fxViewId: string): boolean {
268
- console.log("FXViewManager.unregisterView", fxViewId);
267
+ logger.log("FXViewManager", "unregisterView", fxViewId);
269
268
 
270
269
  const viewController = this.getViewController(fxViewId);
271
270
  if (!viewController) {
272
- console.warn(`FXView ${fxViewId} not found, cannot unregister`);
271
+ logger.warn(
272
+ "FXViewManager",
273
+ `FXView ${fxViewId} not found, cannot unregister`,
274
+ );
273
275
  return false;
274
276
  }
275
277
 
@@ -292,13 +294,21 @@ export class FXViewManager {
292
294
  return true;
293
295
  }
294
296
 
297
+ /**
298
+ * 注册生命周期回调
299
+ * @param callbacks 生命周期回调
300
+ */
295
301
  registerLifecycleCallbacks(callbacks: FXLifecycleCallbacks): void {
296
- console.log("FXViewManager.registerLifecycleCallbacks");
302
+ logger.log("FXViewManager", "registerLifecycleCallbacks");
297
303
  this.viewLifecycleCallbacks.push(callbacks);
298
304
  }
299
305
 
306
+ /**
307
+ * 注销生命周期回调
308
+ * @param callbacks 生命周期回调
309
+ */
300
310
  unregisterLifecycleCallbacks(callbacks: FXLifecycleCallbacks): void {
301
- console.log("FXViewManager.unregisterLifecycleCallbacks");
311
+ logger.log("FXViewManager", "unregisterLifecycleCallbacks");
302
312
  this.viewLifecycleCallbacks = this.viewLifecycleCallbacks.filter(
303
313
  (callback) => callback !== callbacks,
304
314
  );
@@ -319,17 +329,20 @@ export class FXViewManager {
319
329
  * @returns 组件列表
320
330
  */
321
331
  getComponents(fxViewId?: string, categoryId?: string): FXComponentItem[] {
322
- console.log("FXViewManager.getComponents", { fxViewId, categoryId });
332
+ logger.log("FXViewManager", "getComponents", { fxViewId, categoryId });
323
333
 
324
334
  const finalFXViewId = fxViewId || this.getLatestFXViewId();
325
335
  if (!finalFXViewId) {
326
- console.warn("No FXView available");
336
+ logger.warn("FXViewManager", "No FXView available");
327
337
  return [];
328
338
  }
329
339
 
330
340
  const viewController = this.getViewController(finalFXViewId);
331
341
  if (!viewController) {
332
- console.warn(`FXViewController ${finalFXViewId} not found`);
342
+ logger.warn(
343
+ "FXViewManager",
344
+ `FXViewController ${finalFXViewId} not found`,
345
+ );
333
346
  return [];
334
347
  }
335
348
 
@@ -400,7 +413,7 @@ export class FXViewManager {
400
413
  private getViewController(fxViewId?: string): FXViewController | null {
401
414
  const finalFXViewId = fxViewId || this.getLatestFXViewId();
402
415
  if (!finalFXViewId) {
403
- console.warn("FXViewManager.getViewController: no fxViewId available");
416
+ logger.warn("FXViewManager", "getViewController: no fxViewId available");
404
417
  return null;
405
418
  }
406
419
  return this.viewControllerMap.get(finalFXViewId) || null;
@@ -418,7 +431,8 @@ export class FXViewManager {
418
431
  let viewController = this.viewControllerMap.get(finalFXViewId);
419
432
 
420
433
  if (!viewController) {
421
- console.warn(
434
+ logger.warn(
435
+ "FXViewManager",
422
436
  `FXViewController ${finalFXViewId} not registered, creating a temporary one`,
423
437
  );
424
438
  viewController = new FXViewController(finalFXViewId);
@@ -439,3 +453,6 @@ export class FXViewManager {
439
453
 
440
454
  //#endregion
441
455
  }
456
+
457
+ const FXManager = FXViewManager.getInstance();
458
+ export default FXManager;
package/index.d.ts CHANGED
@@ -1,5 +1,4 @@
1
1
  export { default as FXView } from "./FXView";
2
- export { FXViewManager } from "./FXViewManager";
3
- export { FXViewController } from "./FXViewController";
4
- export { FXCategoryController } from "./FXCategoryController";
2
+ export { default as FXManager } from "./FXViewManager";
3
+ export { default as logger } from "./logger/FXLogger";
5
4
  export * from "./types";
package/index.js CHANGED
@@ -17,14 +17,12 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
17
17
  return (mod && mod.__esModule) ? mod : { "default": mod };
18
18
  };
19
19
  Object.defineProperty(exports, "__esModule", { value: true });
20
- exports.FXCategoryController = exports.FXViewController = exports.FXViewManager = exports.FXView = void 0;
20
+ exports.logger = exports.FXManager = exports.FXView = void 0;
21
21
  // 主入口文件
22
22
  var FXView_1 = require("./FXView");
23
23
  Object.defineProperty(exports, "FXView", { enumerable: true, get: function () { return __importDefault(FXView_1).default; } });
24
24
  var FXViewManager_1 = require("./FXViewManager");
25
- Object.defineProperty(exports, "FXViewManager", { enumerable: true, get: function () { return FXViewManager_1.FXViewManager; } });
26
- var FXViewController_1 = require("./FXViewController");
27
- Object.defineProperty(exports, "FXViewController", { enumerable: true, get: function () { return FXViewController_1.FXViewController; } });
28
- var FXCategoryController_1 = require("./FXCategoryController");
29
- Object.defineProperty(exports, "FXCategoryController", { enumerable: true, get: function () { return FXCategoryController_1.FXCategoryController; } });
25
+ Object.defineProperty(exports, "FXManager", { enumerable: true, get: function () { return __importDefault(FXViewManager_1).default; } });
26
+ var FXLogger_1 = require("./logger/FXLogger");
27
+ Object.defineProperty(exports, "logger", { enumerable: true, get: function () { return __importDefault(FXLogger_1).default; } });
30
28
  __exportStar(require("./types"), exports);