@baishuyun/coze-provider 0.0.1

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.
Files changed (54) hide show
  1. package/.turbo/turbo-build.log +22 -0
  2. package/CHANGELOG.md +7 -0
  3. package/dist/index.d.mts +42 -0
  4. package/dist/index.d.ts +42 -0
  5. package/dist/index.js +1766 -0
  6. package/dist/index.js.map +1 -0
  7. package/dist/index.mjs +1732 -0
  8. package/dist/index.mjs.map +1 -0
  9. package/package.json +50 -0
  10. package/src/const.ts +1 -0
  11. package/src/coze-language-model.ts +150 -0
  12. package/src/coze-provider.ts +102 -0
  13. package/src/evt-sample.ts +28 -0
  14. package/src/index.ts +4 -0
  15. package/src/stream-trasnformer/fields-json-transform-stream.ts +108 -0
  16. package/src/stream-trasnformer/llm-chunk-injector-transform-stream.ts +66 -0
  17. package/src/stream-trasnformer/llm-part-transform-stream.ts +34 -0
  18. package/src/stream-trasnformer/mcp-chunk-filter-transform-stream.ts +52 -0
  19. package/src/stream-trasnformer/suggestion-transform-stream.ts +35 -0
  20. package/src/types.ts +26 -0
  21. package/src/utils/build-widget-name.ts +15 -0
  22. package/src/utils/enqueue-text-info.ts +35 -0
  23. package/src/utils/excel2json.ts +44 -0
  24. package/src/utils/fields-json-rebuild/default-builder.ts +3 -0
  25. package/src/utils/fields-json-rebuild/index.ts +82 -0
  26. package/src/utils/fields-json-rebuild/rebuild-address.ts +36 -0
  27. package/src/utils/fields-json-rebuild/rebuild-button.ts +46 -0
  28. package/src/utils/fields-json-rebuild/rebuild-checkbox-group.ts +35 -0
  29. package/src/utils/fields-json-rebuild/rebuild-combo-checker.ts +38 -0
  30. package/src/utils/fields-json-rebuild/rebuild-data-linker.ts +30 -0
  31. package/src/utils/fields-json-rebuild/rebuild-data-loader.ts +89 -0
  32. package/src/utils/fields-json-rebuild/rebuild-data-query.ts +34 -0
  33. package/src/utils/fields-json-rebuild/rebuild-date-time.ts +61 -0
  34. package/src/utils/fields-json-rebuild/rebuild-dept-group.ts +38 -0
  35. package/src/utils/fields-json-rebuild/rebuild-dept.ts +37 -0
  36. package/src/utils/fields-json-rebuild/rebuild-image.ts +61 -0
  37. package/src/utils/fields-json-rebuild/rebuild-line.ts +22 -0
  38. package/src/utils/fields-json-rebuild/rebuild-location.ts +37 -0
  39. package/src/utils/fields-json-rebuild/rebuild-number.ts +58 -0
  40. package/src/utils/fields-json-rebuild/rebuild-radio-group.ts +36 -0
  41. package/src/utils/fields-json-rebuild/rebuild-select.ts +37 -0
  42. package/src/utils/fields-json-rebuild/rebuild-signature.ts +26 -0
  43. package/src/utils/fields-json-rebuild/rebuild-sn.ts +26 -0
  44. package/src/utils/fields-json-rebuild/rebuild-subform.ts +71 -0
  45. package/src/utils/fields-json-rebuild/rebuild-text.ts +66 -0
  46. package/src/utils/fields-json-rebuild/rebuild-textarea.ts +44 -0
  47. package/src/utils/fields-json-rebuild/rebuild-upload.ts +31 -0
  48. package/src/utils/fields-json-rebuild/rebuild-user-group.ts +39 -0
  49. package/src/utils/fields-json-rebuild/rebuild-user.ts +39 -0
  50. package/src/utils/mcp-to-llm-chunk.ts +105 -0
  51. package/src/utils/parse-multi-modal-message.ts +34 -0
  52. package/src/utils/prompt-to-model-msg.ts +93 -0
  53. package/tsconfig.json +14 -0
  54. package/tsup.config.ts +16 -0
package/dist/index.js ADDED
@@ -0,0 +1,1766 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+
30
+ // src/index.ts
31
+ var index_exports = {};
32
+ __export(index_exports, {
33
+ SuggestionTransformStream: () => SuggestionTransformStream,
34
+ createCoze: () => createCoze,
35
+ createFieldsJsonTransformStream: () => createFieldsJsonTransformStream,
36
+ createTextInfoEnqueuer: () => createTextInfoEnqueuer
37
+ });
38
+ module.exports = __toCommonJS(index_exports);
39
+
40
+ // src/coze-provider.ts
41
+ var import_provider = require("@ai-sdk/provider");
42
+ var import_provider_utils = require("@ai-sdk/provider-utils");
43
+
44
+ // src/const.ts
45
+ var VERSION = "0.0.1";
46
+
47
+ // src/coze-language-model.ts
48
+ var import_parse_sse = require("parse-sse");
49
+ var import_web = require("stream/web");
50
+
51
+ // src/utils/prompt-to-model-msg.ts
52
+ var import_api = require("@coze/api");
53
+
54
+ // src/utils/excel2json.ts
55
+ var import_xlsx = __toESM(require("xlsx"));
56
+ var excel2json = (file) => {
57
+ const workbook = import_xlsx.default.read(file, {
58
+ type: "array",
59
+ // 或 'buffer'
60
+ cellStyles: true,
61
+ cellFormula: true,
62
+ cellDates: true,
63
+ cellNF: true,
64
+ sheetStubs: true,
65
+ bookVBA: true
66
+ });
67
+ const result = {
68
+ sheets: []
69
+ };
70
+ workbook.SheetNames.forEach((sheetName) => {
71
+ const worksheet = workbook.Sheets[sheetName];
72
+ const data = import_xlsx.default.utils.sheet_to_json(worksheet, {
73
+ header: 1,
74
+ // 使用数组格式
75
+ defval: null,
76
+ // 空单元格默认值
77
+ raw: false,
78
+ // 格式化值
79
+ dateNF: "yyyy-mm-dd"
80
+ // 日期格式
81
+ });
82
+ result.sheets.push({
83
+ name: sheetName,
84
+ data,
85
+ range: worksheet["!ref"],
86
+ merges: worksheet["!merges"] || []
87
+ });
88
+ });
89
+ return JSON.stringify(result);
90
+ };
91
+
92
+ // src/utils/prompt-to-model-msg.ts
93
+ var decoder = new TextDecoder("utf-8");
94
+ var data2csvText = (data) => {
95
+ return decoder.decode(data);
96
+ };
97
+ var parseMessageContent = (message, isMultiModalMsg) => {
98
+ const result = message.content.map((part) => {
99
+ if (part.type === "text") {
100
+ return part.text;
101
+ }
102
+ const isCsv = part.mediaType === "text/csv";
103
+ const isTxt = part.mediaType === "text/plain";
104
+ const isImg = part.mediaType?.startsWith("image/");
105
+ const isExcel = part.mediaType === "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
106
+ if (isImg) {
107
+ const meta = part.providerOptions?.uploadMetadata;
108
+ console.log("img meta", meta);
109
+ return meta?.parsedData;
110
+ }
111
+ if (isExcel) {
112
+ return excel2json(part.data);
113
+ }
114
+ if (isCsv || isTxt) {
115
+ return data2csvText(part.data);
116
+ }
117
+ return "";
118
+ }).join("");
119
+ return result;
120
+ };
121
+ var convertPromptToMessages = (messages) => {
122
+ return messages.map((message) => {
123
+ switch (message.role) {
124
+ case "user":
125
+ return {
126
+ role: import_api.RoleType.User,
127
+ // content: parseMessageContent(message, multiModal) || "",
128
+ // content_type: multiModal ? "object_string" : "text",
129
+ content: parseMessageContent(message) || "",
130
+ content_type: "text"
131
+ };
132
+ break;
133
+ case "assistant":
134
+ return {
135
+ role: import_api.RoleType.Assistant,
136
+ content: message.content.map((part) => part.type === "text" ? part.text : "").join(""),
137
+ content_type: "text"
138
+ };
139
+ break;
140
+ }
141
+ });
142
+ };
143
+
144
+ // src/evt-sample.ts
145
+ var EvtSample = class {
146
+ _evtSampleMap = /* @__PURE__ */ new Map();
147
+ _key1 = "1";
148
+ _key2 = "2";
149
+ _maxSample = 2;
150
+ addEventSample(evt) {
151
+ if (this._evtSampleMap.size >= this._maxSample) {
152
+ const evt2 = this._evtSampleMap.get(this._key2);
153
+ this._evtSampleMap.set(this._key1, evt2);
154
+ this._evtSampleMap.set(this._key2, evt);
155
+ return;
156
+ }
157
+ this._evtSampleMap.set((this._evtSampleMap.size + 1).toString(), evt);
158
+ }
159
+ getFirstSample() {
160
+ return this._evtSampleMap.get(this._key1);
161
+ }
162
+ getSecondSample() {
163
+ return this._evtSampleMap.get(this._key2);
164
+ }
165
+ };
166
+
167
+ // src/stream-trasnformer/llm-chunk-injector-transform-stream.ts
168
+ var LLMChunkInjectorTransformStream = class extends TransformStream {
169
+ eventSampleMap = new EvtSample();
170
+ constructor() {
171
+ super({
172
+ transform: (part, controller) => {
173
+ this.eventSampleMap.addEventSample(part);
174
+ const sample1 = this.eventSampleMap.getFirstSample();
175
+ const sample2 = this.eventSampleMap.getSecondSample();
176
+ if (sample1 && sample2 && sample1.data.reasoning_content && !sample2.data.reasoning_content) {
177
+ controller.enqueue({
178
+ disableTransform: true,
179
+ type: "reasoning-end",
180
+ id: sample1.data.conversation_id
181
+ });
182
+ }
183
+ if (sample1 && sample2 && !sample1.data.content && sample2.data.content) {
184
+ controller.enqueue({
185
+ disableTransform: true,
186
+ type: "text-start",
187
+ id: sample2.data.conversation_id
188
+ });
189
+ }
190
+ controller.enqueue(part);
191
+ }
192
+ });
193
+ }
194
+ };
195
+
196
+ // src/stream-trasnformer/mcp-chunk-filter-transform-stream.ts
197
+ var import_api2 = require("@coze/api");
198
+ var MCPChunkFilterTransformStream = class extends TransformStream {
199
+ isVisibleMsgPart(evtData, part, omitTextEndChunk) {
200
+ if (evtData.type === "knowledge" && evtData.role === "assistant") {
201
+ return false;
202
+ }
203
+ if (omitTextEndChunk && part.event === import_api2.ChatEventType.CONVERSATION_MESSAGE_COMPLETED && part.data.type !== "follow_up") {
204
+ return false;
205
+ }
206
+ if (part.event === "conversation.message.completed" && evtData.type == "verbose") {
207
+ return false;
208
+ }
209
+ return true;
210
+ }
211
+ constructor(omitTextEndChunk = false) {
212
+ super({
213
+ transform: (evt, controller) => {
214
+ if (!evt) return;
215
+ console.log("origin event", evt);
216
+ const part = {
217
+ event: evt.type,
218
+ data: JSON.parse(evt.data) || {}
219
+ };
220
+ if (this.isVisibleMsgPart(part.data, part, omitTextEndChunk)) {
221
+ controller.enqueue(part);
222
+ }
223
+ }
224
+ });
225
+ }
226
+ };
227
+
228
+ // src/utils/mcp-to-llm-chunk.ts
229
+ var import_api3 = require("@coze/api");
230
+ var mcp2llmChunk = (part) => {
231
+ const fullData = JSON.stringify(part);
232
+ switch (part.event) {
233
+ case import_api3.ChatEventType.CONVERSATION_CHAT_CREATED:
234
+ return {
235
+ type: "raw",
236
+ rawValue: part.data
237
+ };
238
+ break;
239
+ case import_api3.ChatEventType.CONVERSATION_CHAT_IN_PROGRESS:
240
+ return {
241
+ // type: "text-delta",
242
+ // id: part.data.conversation_id,
243
+ // delta: part.data.content || "",
244
+ // providerMetadata: {
245
+ // raw: { data: fullData },
246
+ // },
247
+ type: "raw",
248
+ rawValue: part.data
249
+ };
250
+ break;
251
+ case import_api3.ChatEventType.CONVERSATION_MESSAGE_DELTA:
252
+ const isReasoning = Boolean(part.data.reasoning_content);
253
+ return {
254
+ type: isReasoning ? "reasoning-delta" : "text-delta",
255
+ delta: isReasoning ? part.data.reasoning_content : part.data.content,
256
+ id: part.data.conversation_id,
257
+ providerMetadata: {}
258
+ };
259
+ break;
260
+ case import_api3.ChatEventType.CONVERSATION_MESSAGE_COMPLETED:
261
+ if (part.data && part.data.type === "follow_up") {
262
+ return {
263
+ type: "raw",
264
+ rawValue: part.data
265
+ };
266
+ }
267
+ return {
268
+ type: "text-end",
269
+ id: part.data.conversation_id,
270
+ // delta: part.data.content || part.data.reasoning_content || "",
271
+ providerMetadata: {}
272
+ };
273
+ break;
274
+ case import_api3.ChatEventType.CONVERSATION_CHAT_COMPLETED:
275
+ return {
276
+ type: "finish",
277
+ finishReason: "stop",
278
+ usage: {
279
+ inputTokens: part.data.usage?.input_count || 0,
280
+ outputTokens: part.data.usage?.output_count || 0,
281
+ totalTokens: part.data.usage?.total_count || 0
282
+ }
283
+ };
284
+ break;
285
+ case import_api3.ChatEventType.DONE:
286
+ return {
287
+ type: "finish",
288
+ finishReason: "stop",
289
+ usage: {
290
+ inputTokens: part.data.usage?.input_count || 0,
291
+ outputTokens: part.data.usage?.output_count || 0,
292
+ totalTokens: part.data.usage?.total_count || 0
293
+ }
294
+ };
295
+ break;
296
+ case import_api3.ChatEventType.ERROR:
297
+ console.error("[ERROR]", part.data);
298
+ return {
299
+ type: "error",
300
+ error: new Error(`Coze streaming error: ${JSON.stringify(part.data)}`)
301
+ };
302
+ default:
303
+ console.warn("Unknown event type:", part.event);
304
+ return {
305
+ type: "error",
306
+ error: "Unknown event type" + part.event
307
+ };
308
+ }
309
+ return {
310
+ type: "error",
311
+ error: "unknown"
312
+ };
313
+ };
314
+
315
+ // src/stream-trasnformer/llm-part-transform-stream.ts
316
+ var LLMPartTrasnformStream = class extends TransformStream {
317
+ constructor() {
318
+ super({
319
+ transform: (part, controller) => {
320
+ const { disableTransform } = part;
321
+ if (disableTransform) {
322
+ controller.enqueue(part);
323
+ return;
324
+ }
325
+ try {
326
+ const chunk = mcp2llmChunk(part);
327
+ if (chunk) {
328
+ controller.enqueue(chunk);
329
+ }
330
+ } catch (error) {
331
+ console.error("transform coze evt error");
332
+ }
333
+ }
334
+ });
335
+ }
336
+ };
337
+
338
+ // src/coze-language-model.ts
339
+ var CozeLanguageModel = class {
340
+ specificationVersion = "v2";
341
+ provider;
342
+ modelId;
343
+ supportedUrls;
344
+ config;
345
+ constructor(modelId, config) {
346
+ this.modelId = modelId;
347
+ this.provider = config.provider || "coze";
348
+ this.supportedUrls = config.supportedUrls?.() || {};
349
+ this.config = config;
350
+ }
351
+ doGenerate(options) {
352
+ throw new Error("Method not implemented.");
353
+ }
354
+ isVisibleMsgPart(evtData) {
355
+ if (evtData.type === "knowledge" && evtData.role === "assistant") {
356
+ return false;
357
+ }
358
+ return true;
359
+ }
360
+ async doStream(options) {
361
+ const messages = convertPromptToMessages(options.prompt);
362
+ const warnings = [];
363
+ const url = this.config.url({
364
+ path: "/chat"
365
+ });
366
+ const user_id = options.headers ? options.headers["x-user-id"] : "";
367
+ const body = {
368
+ bot_id: this.config.botId,
369
+ auto_save_history: false,
370
+ user_id: user_id || "123456",
371
+ stream: true,
372
+ additional_messages: messages
373
+ };
374
+ console.log("messages", messages);
375
+ const headers = this.config.headers();
376
+ const response = await fetch(url, {
377
+ method: "POST",
378
+ headers,
379
+ credentials: "include",
380
+ body: JSON.stringify(body)
381
+ });
382
+ if (!response.ok || !response.body) {
383
+ const rawError = await response.text();
384
+ let errorDetail;
385
+ try {
386
+ errorDetail = JSON.parse(rawError);
387
+ } catch {
388
+ errorDetail = rawError;
389
+ }
390
+ throw new Error(
391
+ `Coze API error: ${response.status} ${response.statusText}`
392
+ );
393
+ }
394
+ let externalTransformers = this.config.extraStreamTransformers || [];
395
+ const stage = options.headers ? options.headers["x-user-stage"] : "";
396
+ const isBuildStage = stage === "build";
397
+ const isFillStage = stage === "fill";
398
+ const result = response.body.pipeThrough(
399
+ new import_web.TextDecoderStream()
400
+ ).pipeThrough(new import_parse_sse.ServerSentEventTransformStream()).pipeThrough(
401
+ new MCPChunkFilterTransformStream(isBuildStage || isFillStage)
402
+ ).pipeThrough(new LLMChunkInjectorTransformStream()).pipeThrough(new LLMPartTrasnformStream());
403
+ let finalResult = result;
404
+ if (externalTransformers.length > 0) {
405
+ finalResult = externalTransformers.reduce(
406
+ (stream, transformer) => stream.pipeThrough(transformer),
407
+ result
408
+ // 初始累积值(原始流)
409
+ );
410
+ }
411
+ return {
412
+ stream: finalResult
413
+ };
414
+ }
415
+ };
416
+
417
+ // src/coze-provider.ts
418
+ function createCoze(options = {
419
+ botId: ""
420
+ }) {
421
+ const baseURL = (0, import_provider_utils.withoutTrailingSlash)(options.baseURL);
422
+ const agentPartHeader = (0, import_provider_utils.withUserAgentSuffix)(
423
+ options.headers || {},
424
+ `ai-sdk/coze/${VERSION}`
425
+ );
426
+ const authorizationHeader = `Bearer ${(0, import_provider_utils.loadApiKey)({
427
+ apiKey: options.apiKey,
428
+ environmentVariableName: "COZE_API_KEY",
429
+ description: ""
430
+ })}`;
431
+ const getHeaders = () => ({
432
+ ...agentPartHeader,
433
+ Authorization: authorizationHeader,
434
+ "content-type": "application/json"
435
+ });
436
+ const createLanguageModel = (modelId) => {
437
+ return new CozeLanguageModel(modelId, {
438
+ botId: options.botId,
439
+ provider: `coze.chat`,
440
+ url: ({ path }) => `${baseURL}${path}`,
441
+ headers: getHeaders,
442
+ fetch: options.fetch,
443
+ extraStreamTransformers: options.extraStreamTransformers || []
444
+ });
445
+ };
446
+ const provider = (modelId) => createLanguageModel(modelId);
447
+ provider.specificationVersion = "v3";
448
+ provider.languageModel = createLanguageModel;
449
+ provider.chat = createLanguageModel;
450
+ provider.embeddingModel = (modelId) => {
451
+ throw new import_provider.NoSuchModelError({ modelId, modelType: "textEmbeddingModel" });
452
+ };
453
+ provider.imageModel = (modelId) => {
454
+ throw new import_provider.NoSuchModelError({ modelId, modelType: "imageModel" });
455
+ };
456
+ provider.textEmbeddingModel = (modelId) => {
457
+ throw new import_provider.NoSuchModelError({ modelId, modelType: "textEmbeddingModel" });
458
+ };
459
+ return provider;
460
+ }
461
+
462
+ // src/stream-trasnformer/fields-json-transform-stream.ts
463
+ var import_json = require("@streamparser/json");
464
+
465
+ // src/utils/enqueue-text-info.ts
466
+ var import_provider_utils2 = require("@ai-sdk/provider-utils");
467
+ var createTextInfoEnqueuer = (controller) => (textInfo, metaPayload, id = (0, import_provider_utils2.generateId)()) => {
468
+ controller.enqueue({
469
+ type: "text-start",
470
+ id
471
+ });
472
+ const chunk = {
473
+ type: "text-delta",
474
+ id,
475
+ delta: textInfo,
476
+ providerMetadata: metaPayload ? {
477
+ raw: { data: metaPayload }
478
+ } : void 0
479
+ };
480
+ controller.enqueue(chunk);
481
+ controller.enqueue({
482
+ type: "text-end",
483
+ id
484
+ });
485
+ };
486
+
487
+ // src/utils/fields-json-rebuild/rebuild-text.ts
488
+ var REG_EX_MAP = {
489
+ \u624B\u673A\u53F7\u7801: "^((\\(\\d{2,3}\\))|(\\d{3}\\-))?1\\d{10}$",
490
+ \u7535\u8BDD\u53F7\u7801: "^(0[0-9]{2,3}\\-)?([2-9][0-9]{6,7})+(\\-[0-9]{1,4})?$",
491
+ \u90AE\u653F\u7F16\u7801: "^\\d{6}$",
492
+ \u8EAB\u4EFD\u8BC1\u53F7\u7801: "(^\\d{15}$)|(^\\d{18}$)|(^\\d{17}(\\d|X|x)$)",
493
+ \u90AE\u7BB1: "^([a-zA-Z0-9_\\.\\-])+\\@(([a-zA-Z0-9\\-])+\\.)+([a-zA-Z0-9]{2,4})+$",
494
+ \u65F6\u5206: "(^[0-1]{1}[0-9]{1}:[0-5]{1}[0-9]{1}$|^[2]{1}[0-3]{1}:[0-5]{1}[0-9]{1}$|^[0-9]{1}:[0-5]{1}[0-9]{1}$)",
495
+ \u65F6\u5206\u79D2: "(^[0-1]{1}[0-9]{1}:[0-5]{1}[0-9]{1}:[0-5]{1}[0-9]{1}$|^[2]{1}[0-3]{1}:[0-5]{1}[0-9]{1}:[0-5]{1}[0-9]{1}$|^[0-9]{1}:[0-5]{1}[0-9]{1}:[0-5]{1}[0-9]{1}$)",
496
+ \u56FE\u7247\u94FE\u63A5: "imageurl",
497
+ \u4E8C\u7EF4\u7801\u56FE\u7247: "qrcode",
498
+ \u6761\u5F62\u7801\u56FE\u7247: "barcode",
499
+ \u81EA\u5B9A\u4E49: "custom"
500
+ };
501
+ var rebuildText = (truncatedJson) => {
502
+ const { widget, labelStyle, label, ...rest } = truncatedJson || {};
503
+ const regex = REG_EX_MAP[labelStyle] || "";
504
+ return {
505
+ widget: {
506
+ widgetName: `_widget_${Date.now()}`,
507
+ widgetNameAlias: "",
508
+ // triggerEvent: 0,
509
+ customCls: null,
510
+ height: 34,
511
+ width: 350,
512
+ text: null,
513
+ value: "",
514
+ //默认值 没有默认值的话 整个value不存在
515
+ enable: true,
516
+ visible: true,
517
+ // hint: placeholder,
518
+ allowBlank: true,
519
+ rely: null,
520
+ libs: [],
521
+ extendSet: {
522
+ sort: ["datahelp", "module", "formEvent"],
523
+ status: true,
524
+ triggerField: "",
525
+ triggerFieldMode: "none",
526
+ version: 1
527
+ },
528
+ // regex, //格式 ^((\(\d{2,3}\))|(\d{3}\-))?1\d{10}$ 手机号码 ^(0[0-9]{2,3}\-)?([2-9][0-9]{6,7})+(\-[0-9]{1,4})?$ 电话号码 ^\d{6}$ 邮政编码 (^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$) 身份证号码 ^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$ 邮箱 (^[0-1]{1}[0-9]{1}:[0-5]{1}[0-9]{1}$|^[2]{1}[0-3]{1}:[0-5]{1}[0-9]{1}$|^[0-9]{1}:[0-5]{1}[0-9]{1}$) 时分 (^[0-1]{1}[0-9]{1}:[0-5]{1}[0-9]{1}:[0-5]{1}[0-9]{1}$|^[2]{1}[0-3]{1}:[0-5]{1}[0-9]{1}:[0-5]{1}[0-9]{1}$|^[0-9]{1}:[0-5]{1}[0-9]{1}:[0-5]{1}[0-9]{1}$) 时分秒 imageurl 图片链接 qrcode 二维码图片 barcode 条形码图片 custom 自定义
529
+ noRepeat: true,
530
+ scan: null,
531
+ // textMode,
532
+ generateQR: false,
533
+ eventAlert: true,
534
+ alertinfo: {
535
+ icon: "error"
536
+ // tip: placeholder,
537
+ // msg: placeholder,
538
+ },
539
+ enterClearText: true,
540
+ ...widget,
541
+ regex,
542
+ type: "text",
543
+ labelStyle: label
544
+ },
545
+ // description,
546
+ label,
547
+ lineWidth: 6,
548
+ tab: null,
549
+ ...rest
550
+ };
551
+ };
552
+
553
+ // src/utils/build-widget-name.ts
554
+ var buildWidgetName = (prefix = "_widget", index) => {
555
+ const baseName = `${prefix}_${Date.now()}`;
556
+ if (index === void 0) {
557
+ return baseName;
558
+ }
559
+ const idxLength = index.toString().length;
560
+ const slicedBaseName = baseName.slice(0, -idxLength);
561
+ return `${slicedBaseName}${index}`;
562
+ };
563
+
564
+ // src/utils/fields-json-rebuild/rebuild-number.ts
565
+ var rebuildNumber = (value) => {
566
+ const { widget, label, ...rest } = value || {};
567
+ return {
568
+ widget: {
569
+ type: "number",
570
+ widgetName: buildWidgetName(),
571
+ widgetNameAlias: "",
572
+ triggerEvent: false,
573
+ customCls: null,
574
+ height: 34,
575
+ width: 350,
576
+ enable: true,
577
+ visible: true,
578
+ allowBlank: true,
579
+ funMode: "module",
580
+ module: null,
581
+ libs: [],
582
+ extendSet: {
583
+ sort: ["datahelp", "module", "formEvent"],
584
+ status: true,
585
+ triggerField: "",
586
+ triggerFieldMode: "none",
587
+ version: 1
588
+ },
589
+ // regex,
590
+ // hint: placeholder,
591
+ noRepeat: false,
592
+ alertinfo: {
593
+ icon: "success",
594
+ tip: "\u8BF7\u8BBE\u7F6E\u63D0\u793A\u5185\u5BB9"
595
+ },
596
+ allowDecimals: true,
597
+ //允许小数,默认值 true,已废弃
598
+ allowNegative: true,
599
+ //允许负数,默认值 true ,已废弃
600
+ // maxNumber: max, //限定数值范围 最大值
601
+ // minNumber: min, //限定数值范围 最小值
602
+ displayMode: "percent",
603
+ // 新的格式, percent 百分比 number 数值
604
+ precision: null,
605
+ //保留小数位数
606
+ thousandsSeparator: false,
607
+ //显示千分符
608
+ notround: true,
609
+ //不四舍五入
610
+ format: "",
611
+ //旧的格式,新的由多个属性来控制,前端代码会用其他几个参数拼接出正确的这个值。 其中结尾有% 代表百分比 ,没有%代表数字 ,然后小数点后面的0的个数代表 保留的小数位数,如果小数点后面没有0代表(如0.%),代表没有设置 保留小数位数,保留用户输入的所有小数
612
+ afterSuffix: {
613
+ //单位
614
+ zh_cn: "",
615
+ //中文的
616
+ en_us: "",
617
+ //英文的
618
+ zh_tw: ""
619
+ //繁体的
620
+ },
621
+ ...widget,
622
+ labelStyle: label
623
+ },
624
+ // description,
625
+ label,
626
+ lineWidth: 6,
627
+ tab: null,
628
+ ...rest
629
+ };
630
+ };
631
+
632
+ // src/utils/fields-json-rebuild/rebuild-select.ts
633
+ var rebuildSelect = (truncatedJson) => {
634
+ const { widget, label, ...rest } = truncatedJson || {};
635
+ return {
636
+ widget: {
637
+ type: "combo",
638
+ height: 34,
639
+ width: 350,
640
+ enable: true,
641
+ visible: true,
642
+ allowBlank: true,
643
+ mode: 1,
644
+ allowAddLinkData: false,
645
+ // items: options,
646
+ widgetName: `_widget_${Date.now()}`,
647
+ widgetNameAlias: "",
648
+ customCls: null,
649
+ funMode: "module",
650
+ module: null,
651
+ libs: [],
652
+ extendSet: {
653
+ sort: ["datahelp", "module", "formEvent"],
654
+ status: true,
655
+ triggerField: "",
656
+ triggerFieldMode: "none",
657
+ version: 1
658
+ },
659
+ colorEnable: true,
660
+ //颜色 是否开启颜色
661
+ ...widget,
662
+ labelStyle: label
663
+ },
664
+ // description,
665
+ label,
666
+ lineWidth: 6,
667
+ tab: null,
668
+ ...rest
669
+ };
670
+ };
671
+
672
+ // src/utils/fields-json-rebuild/rebuild-radio-group.ts
673
+ var rebuildRadioGroup = (truncatedJson) => {
674
+ const { widget, label, ...rest } = truncatedJson || {};
675
+ return {
676
+ widget: {
677
+ enable: true,
678
+ visible: true,
679
+ allowBlank: true,
680
+ funMode: "module",
681
+ module: null,
682
+ libs: [],
683
+ // items: options,
684
+ layout: "vertical",
685
+ stopCancel: false,
686
+ widgetName: `_widget_${Date.now()}`,
687
+ widgetNameAlias: "",
688
+ customCls: null,
689
+ value: null,
690
+ extendSet: {
691
+ sort: ["datahelp", "module", "formEvent"],
692
+ status: true,
693
+ triggerField: "",
694
+ triggerFieldMode: "none",
695
+ version: 1
696
+ },
697
+ colorEnable: true,
698
+ //颜色 是否开启颜色
699
+ ...widget,
700
+ type: "radiogroup"
701
+ },
702
+ // description,
703
+ label,
704
+ lineWidth: 6,
705
+ tab: null,
706
+ ...rest,
707
+ labelStyle: label
708
+ };
709
+ };
710
+
711
+ // src/utils/fields-json-rebuild/rebuild-date-time.ts
712
+ var rebuildDatetime = (truncatedJson) => {
713
+ const { widget, label, ...rest } = truncatedJson || {};
714
+ return {
715
+ widget: {
716
+ type: "datetime",
717
+ height: 34,
718
+ width: 350,
719
+ enable: true,
720
+ visible: true,
721
+ allowBlank: true,
722
+ funMode: "module",
723
+ widgetName: `_widget_${Date.now()}`,
724
+ widgetNameAlias: "",
725
+ customCls: null,
726
+ value: "today",
727
+ //默认值, today 填写当前时间 ,如果是数字,如 1762957800000 ,是自定义的时间,为所选时间的时间戳的毫秒级,
728
+ rely: null,
729
+ module: null,
730
+ libs: [],
731
+ extendSet: {
732
+ sort: ["datahelp", "module", "formEvent"],
733
+ status: true,
734
+ triggerField: "",
735
+ triggerFieldMode: "none",
736
+ version: 1
737
+ },
738
+ hint: "",
739
+ dateLimit: {
740
+ //日期范围
741
+ week: {
742
+ //可选择星期
743
+ enable: false,
744
+ //是否开启可选择星期
745
+ value: [
746
+ //星期 星期一到天,用1-7代表
747
+ 1,
748
+ 2,
749
+ 6
750
+ ]
751
+ },
752
+ start: {
753
+ //最早可选时间
754
+ enable: false,
755
+ //是否开启最早可选时间
756
+ mode: "dynamic",
757
+ //模式: dynamic 动态 static 固定值 fieldValue 字段值
758
+ value: "yesterday"
759
+ //限定的值: today 今天 yesterday 昨天 tomorrow 明天 7day_before 七天前 7day_after 七天后 30day_before 30天前 30day_after 30天后
760
+ },
761
+ end: {
762
+ //最晚可选时间
763
+ enable: false,
764
+ //是否开启最晚可选时间
765
+ mode: "static",
766
+ //模式: dynamic 动态 static 固定值 fieldValue 字段值
767
+ value: 17620938e5
768
+ //限定的值:这种数字的为 选择的固定值,时间的时间戳,毫秒级别 ,如果为 _widget_1762154537014 这种,为字段的值,这个字段需要也是日期字段,和当前这个字段是同一个 format的
769
+ }
770
+ },
771
+ ...widget,
772
+ labelStyle: label
773
+ },
774
+ label,
775
+ lineWidth: 6,
776
+ tab: null,
777
+ ...rest
778
+ };
779
+ };
780
+
781
+ // src/utils/fields-json-rebuild/default-builder.ts
782
+ var defaultBuilder = (truncatedJson) => {
783
+ return truncatedJson;
784
+ };
785
+
786
+ // src/utils/fields-json-rebuild/rebuild-dept-group.ts
787
+ var rebuildDeptGroup = (truncatedJson) => {
788
+ const { widget, label, ...rest } = truncatedJson || {};
789
+ return {
790
+ widget: {
791
+ type: "deptgroup",
792
+ widgetName: buildWidgetName(),
793
+ widgetNameAlias: "",
794
+ customCls: null,
795
+ height: "34",
796
+ width: 350,
797
+ enable: true,
798
+ visible: true,
799
+ allowBlank: true,
800
+ funMode: "module",
801
+ module: null,
802
+ libs: [],
803
+ extendSet: {
804
+ sort: ["datahelp", "module", "formEvent"],
805
+ status: true,
806
+ triggerField: "",
807
+ triggerFieldMode: "none",
808
+ version: 1
809
+ },
810
+ noRepeat: false,
811
+ limit: {},
812
+ valueOption: 0,
813
+ ...widget,
814
+ labelStyle: label
815
+ },
816
+ label,
817
+ lineWidth: 6,
818
+ tab: null,
819
+ ...rest
820
+ };
821
+ };
822
+
823
+ // src/utils/fields-json-rebuild/rebuild-sn.ts
824
+ var rebuildSn = (truncatedJson) => {
825
+ const { widget, label, ...rest } = truncatedJson || {};
826
+ return {
827
+ widget: {
828
+ type: "sn",
829
+ widgetName: buildWidgetName(),
830
+ widgetNameAlias: "",
831
+ triggerEvent: 0,
832
+ customCls: null,
833
+ width: 350,
834
+ enable: true,
835
+ visible: true,
836
+ // rules: rules,
837
+ importMode: 1,
838
+ //导入模式 1 excel末尾递增 2 excel最大值递增 3 excel/表单最大值比较递增
839
+ ...widget,
840
+ labelStyle: label
841
+ },
842
+ // description,
843
+ label,
844
+ lineWidth: 6,
845
+ tab: null,
846
+ ...rest
847
+ };
848
+ };
849
+
850
+ // src/utils/fields-json-rebuild/rebuild-dept.ts
851
+ var rebuildDept = (truncatedJson) => {
852
+ const { widget, label, ...rest } = truncatedJson || {};
853
+ return {
854
+ widget: {
855
+ type: "dept",
856
+ widgetName: buildWidgetName(),
857
+ widgetNameAlias: "",
858
+ customCls: null,
859
+ height: "34",
860
+ width: 350,
861
+ enable: true,
862
+ visible: true,
863
+ allowBlank: true,
864
+ funMode: "module",
865
+ module: null,
866
+ libs: [],
867
+ extendSet: {
868
+ sort: ["datahelp", "module", "formEvent"],
869
+ status: true,
870
+ triggerField: "",
871
+ triggerFieldMode: "none",
872
+ version: 1
873
+ },
874
+ noRepeat: false,
875
+ limit: {},
876
+ valueOption: 0,
877
+ ...widget,
878
+ labelStyle: label
879
+ },
880
+ label,
881
+ lineWidth: 6,
882
+ tab: null,
883
+ ...rest
884
+ };
885
+ };
886
+
887
+ // src/utils/fields-json-rebuild/rebuild-user-group.ts
888
+ var rebuildUserGroup = (truncatedJson) => {
889
+ const { widget, label, ...rest } = truncatedJson || {};
890
+ return {
891
+ widget: {
892
+ type: "usergroup",
893
+ widgetName: buildWidgetName(),
894
+ widgetNameAlias: "",
895
+ customCls: null,
896
+ height: "34",
897
+ width: 350,
898
+ enable: true,
899
+ visible: true,
900
+ allowBlank: true,
901
+ funMode: "module",
902
+ module: null,
903
+ libs: [],
904
+ extendSet: {
905
+ sort: ["datahelp", "module", "formEvent"],
906
+ status: true,
907
+ triggerField: "",
908
+ triggerFieldMode: "none",
909
+ version: 1
910
+ },
911
+ noRepeat: false,
912
+ limit: {},
913
+ limitWidget: null,
914
+ //可选范围 由部门字段确定,如果有值 是 _widget_1762226067008 这种,另一个部门字段的id。和limit互斥,limit将为[]
915
+ valueOption: 0,
916
+ ...widget,
917
+ labelStyle: label
918
+ },
919
+ // description,
920
+ label,
921
+ lineWidth: 6,
922
+ tab: null,
923
+ ...rest
924
+ };
925
+ };
926
+
927
+ // src/utils/fields-json-rebuild/rebuild-data-linker.ts
928
+ var rebuildDataLinker = (truncatedJson) => {
929
+ const { widget, label, ...rest } = truncatedJson || {};
930
+ return {
931
+ widget: {
932
+ widgetName: buildWidgetName(),
933
+ widgetNameAlias: "",
934
+ customCls: null,
935
+ enable: true,
936
+ visible: true,
937
+ allowBlank: true,
938
+ rely: {
939
+ widgets: []
940
+ },
941
+ linkFilter: {},
942
+ allowAdd: true,
943
+ //允许新增关联表数据
944
+ refType: "form",
945
+ //关联表的类型,只能是form
946
+ ...widget,
947
+ linkFields: [],
948
+ labelStyle: label,
949
+ type: "linkdata"
950
+ },
951
+ label,
952
+ lineWidth: 6,
953
+ tab: null,
954
+ ...rest
955
+ };
956
+ };
957
+
958
+ // src/utils/fields-json-rebuild/rebuild-data-loader.ts
959
+ var tmpMapFields2Fields = (mapFieldsFromTruncatedJson) => {
960
+ if (!mapFieldsFromTruncatedJson || !mapFieldsFromTruncatedJson.length) {
961
+ return mapFieldsFromTruncatedJson;
962
+ }
963
+ return mapFieldsFromTruncatedJson.map((mf, index) => {
964
+ return {
965
+ id: index,
966
+ // name: "_widget_1761976674767",
967
+ // form: "a2f34ef882158a3e97da4ef7",
968
+ // tag: buildWidgetName("f_", index),
969
+ title: mf.field,
970
+ text: mf.field,
971
+ icon: `icon-widget-${mf.type}`,
972
+ type: mf.type,
973
+ isEditable: true,
974
+ group: "dimension,filter,select",
975
+ formula: ""
976
+ };
977
+ });
978
+ };
979
+ var tmpMapFields2MapFields = (mapFieldsFromTruncatedJson) => {
980
+ if (!mapFieldsFromTruncatedJson || !mapFieldsFromTruncatedJson.length) {
981
+ return mapFieldsFromTruncatedJson;
982
+ }
983
+ return mapFieldsFromTruncatedJson.map((mf) => {
984
+ return {
985
+ mode: "depend",
986
+ ...mf
987
+ };
988
+ });
989
+ };
990
+ var rebuildDataLoader = (truncatedJson) => {
991
+ const { widget, label, ...rest } = truncatedJson || {};
992
+ return {
993
+ widget: {
994
+ type: "dataload",
995
+ widgetName: buildWidgetName(),
996
+ widgetNameAlias: "",
997
+ customCls: null,
998
+ width: 350,
999
+ text: label,
1000
+ enable: true,
1001
+ visible: true,
1002
+ allowBlank: true,
1003
+ allowAddData: true,
1004
+ // 允许新增数据源数据
1005
+ ...widget,
1006
+ mode: "list",
1007
+ //一直是 list 应该是废弃的
1008
+ loaddataconfig: {
1009
+ extendSet: {
1010
+ sort: ["datahelp", "module", "formEvent"],
1011
+ status: true,
1012
+ triggerField: "",
1013
+ triggerFieldMode: "none"
1014
+ },
1015
+ dataloadmode: ["add", "cover"],
1016
+ filter: {
1017
+ cond: [],
1018
+ rel: "and"
1019
+ },
1020
+ defaultSort: [],
1021
+ treeFields: {},
1022
+ mode: "list",
1023
+ selectFields: [],
1024
+ triggerControl: null,
1025
+ triggerWidget: null,
1026
+ triggerFieldMode: "none",
1027
+ triggerField: null,
1028
+ forms: widget?.loaddataconfig?.forms,
1029
+ selectArg: [],
1030
+ selectRel: "and",
1031
+ fields: tmpMapFields2Fields(widget?.loaddataconfig?.mapFields),
1032
+ mapFields: tmpMapFields2MapFields(widget?.loaddataconfig?.mapFields)
1033
+ },
1034
+ labelStyle: label
1035
+ },
1036
+ label,
1037
+ lineWidth: 6,
1038
+ tab: null,
1039
+ ...rest
1040
+ };
1041
+ };
1042
+
1043
+ // src/utils/fields-json-rebuild/rebuild-user.ts
1044
+ var rebuildUser = (truncatedJson) => {
1045
+ const { widget, label, ...rest } = truncatedJson || {};
1046
+ return {
1047
+ widget: {
1048
+ type: "user",
1049
+ widgetName: buildWidgetName(),
1050
+ widgetNameAlias: "",
1051
+ customCls: null,
1052
+ height: "34",
1053
+ width: 350,
1054
+ enable: true,
1055
+ visible: true,
1056
+ allowBlank: true,
1057
+ funMode: "module",
1058
+ module: null,
1059
+ libs: [],
1060
+ extendSet: {
1061
+ sort: ["datahelp", "module", "formEvent"],
1062
+ status: true,
1063
+ triggerField: "",
1064
+ triggerFieldMode: "none",
1065
+ version: 1
1066
+ },
1067
+ noRepeat: false,
1068
+ limit: {},
1069
+ limitWidget: null,
1070
+ //可选范围 由部门字段确定,如果有值 是 _widget_1762226067008 这种,另一个部门字段的id。和limit互斥,limit将为[]
1071
+ valueOption: 0,
1072
+ ...widget,
1073
+ labelStyle: label
1074
+ },
1075
+ // description,
1076
+ label,
1077
+ lineWidth: 6,
1078
+ tab: null,
1079
+ ...rest
1080
+ };
1081
+ };
1082
+
1083
+ // src/utils/fields-json-rebuild/rebuild-signature.ts
1084
+ var rebuildSignature = (truncatedJson) => {
1085
+ const { widget, label, ...rest } = truncatedJson || {};
1086
+ return {
1087
+ widget: {
1088
+ type: "signature",
1089
+ widgetName: buildWidgetName(),
1090
+ widgetNameAlias: "",
1091
+ customCls: null,
1092
+ height: 34,
1093
+ width: 350,
1094
+ enable: true,
1095
+ visible: true,
1096
+ allowBlank: true,
1097
+ rely: null,
1098
+ ...widget,
1099
+ labelStyle: label
1100
+ },
1101
+ description: null,
1102
+ label,
1103
+ lineWidth: 6,
1104
+ tab: null,
1105
+ ...rest
1106
+ };
1107
+ };
1108
+
1109
+ // src/utils/fields-json-rebuild/rebuild-image.ts
1110
+ var rebuildImage = (truncatedJson) => {
1111
+ const { widget, label, ...rest } = truncatedJson || {};
1112
+ return {
1113
+ widget: {
1114
+ type: "image",
1115
+ widgetName: buildWidgetName(),
1116
+ widgetNameAlias: "",
1117
+ customCls: null,
1118
+ height: 100,
1119
+ enable: true,
1120
+ visible: true,
1121
+ allowBlank: true,
1122
+ funMode: "module",
1123
+ module: null,
1124
+ libs: [],
1125
+ extendSet: {
1126
+ sort: ["datahelp", "module", "formEvent"],
1127
+ status: true,
1128
+ triggerField: "",
1129
+ triggerFieldMode: "none",
1130
+ version: 1
1131
+ },
1132
+ download: true,
1133
+ //打包下载
1134
+ is_file_down: true,
1135
+ //操作权限 可下载
1136
+ check_image_exif: true,
1137
+ //照片支持查看EXIF扩展信息
1138
+ online_edit: false,
1139
+ online_edit_record: false,
1140
+ fileType: [
1141
+ //支持上传的类型,默认,不可以设置
1142
+ "jpg",
1143
+ "jpeg",
1144
+ "png",
1145
+ "gif",
1146
+ "bmp",
1147
+ "tif"
1148
+ ],
1149
+ compressed: true,
1150
+ //三方图片压缩
1151
+ wxOriginalComponent: true,
1152
+ //微信/企业微信原生拍照模式
1153
+ onlyCamera: false,
1154
+ //仅允许拍照上传
1155
+ preview: true,
1156
+ //是否可以预览 默认 不可以设置
1157
+ watermarkSwitch: true,
1158
+ //水印属性
1159
+ watermarkPosition: "center",
1160
+ //水印位置
1161
+ watermarkFieldTitle: true,
1162
+ //是否显示水印字段标题
1163
+ watermarkSize: "14",
1164
+ //水印字体大小 不可以设置
1165
+ watermarkFixedField: {},
1166
+ previewWidth: 450,
1167
+ //预览的宽 默认 不可以设置
1168
+ previewHeight: 450,
1169
+ //预览的高 默认 不可以设置
1170
+ browserCompress: true,
1171
+ //浏览器图片压缩
1172
+ quality: 0.7,
1173
+ //压缩图片比例,开启 浏览器图片压缩 后才能设置
1174
+ ...widget,
1175
+ labelStyle: label
1176
+ },
1177
+ label,
1178
+ lineWidth: 6,
1179
+ tab: null,
1180
+ ...rest
1181
+ };
1182
+ };
1183
+
1184
+ // src/utils/fields-json-rebuild/rebuild-upload.ts
1185
+ var rebuildUploader = (truncatedJson) => {
1186
+ const { widget, label, ...rest } = truncatedJson || {};
1187
+ return {
1188
+ widget: {
1189
+ type: "upload",
1190
+ widgetName: buildWidgetName(),
1191
+ widgetNameAlias: "",
1192
+ customCls: null,
1193
+ enable: true,
1194
+ visible: true,
1195
+ allowBlank: true,
1196
+ maxFileCount: 50,
1197
+ //允许多文件上传 1为不可以 50为可以
1198
+ download: true,
1199
+ //打包下载
1200
+ is_file_down: true,
1201
+ //操作权限 可下载
1202
+ check_image_exif: true,
1203
+ //照片支持查看EXIF扩展信息
1204
+ online_edit: true,
1205
+ //允许文档在线编辑
1206
+ online_edit_record: true,
1207
+ //是否查看协作记录
1208
+ fileSizeLimit: 10485760,
1209
+ //设置单个文件大小上限,单位是字节,范围 1M-20M
1210
+ // fileType,
1211
+ ...widget,
1212
+ labelStyle: label
1213
+ },
1214
+ // description,
1215
+ label,
1216
+ lineWidth: 6,
1217
+ tab: null,
1218
+ ...rest
1219
+ };
1220
+ };
1221
+
1222
+ // src/utils/fields-json-rebuild/rebuild-checkbox-group.ts
1223
+ var rebuildCheckboxGroup = (truncatedJson) => {
1224
+ const { widget, label, ...rest } = truncatedJson || {};
1225
+ return {
1226
+ widget: {
1227
+ type: "checkboxgroup",
1228
+ widgetName: buildWidgetName(),
1229
+ widgetNameAlias: "",
1230
+ customCls: null,
1231
+ enable: true,
1232
+ visible: true,
1233
+ allowBlank: true,
1234
+ funMode: "module",
1235
+ module: null,
1236
+ libs: [],
1237
+ extendSet: {
1238
+ sort: ["datahelp", "module", "formEvent"],
1239
+ status: true,
1240
+ triggerField: "",
1241
+ triggerFieldMode: "none",
1242
+ version: 1
1243
+ },
1244
+ colorEnable: true,
1245
+ //颜色 是否开启颜色
1246
+ layout: "vertical",
1247
+ allowAddOptions: false,
1248
+ //允许成员填写时添加新选项
1249
+ ...widget,
1250
+ labelStyle: label
1251
+ },
1252
+ label,
1253
+ lineWidth: 6,
1254
+ tab: null,
1255
+ ...rest
1256
+ };
1257
+ };
1258
+
1259
+ // src/utils/fields-json-rebuild/rebuild-line.ts
1260
+ var rebuildLine = (truncatedJson) => {
1261
+ const { widget, label, ...rest } = truncatedJson || {};
1262
+ return {
1263
+ widget: {
1264
+ type: "separator",
1265
+ widgetName: buildWidgetName(),
1266
+ widgetNameAlias: "",
1267
+ customCls: null,
1268
+ enable: true,
1269
+ visible: true,
1270
+ allowBlank: true,
1271
+ ...widget,
1272
+ labelStyle: label
1273
+ },
1274
+ label,
1275
+ lineWidth: 12,
1276
+ tab: null,
1277
+ ...rest
1278
+ };
1279
+ };
1280
+
1281
+ // src/utils/fields-json-rebuild/rebuild-combo-checker.ts
1282
+ var rebuildComboChecker = (truncatedJson) => {
1283
+ const { widget, label, ...rest } = truncatedJson || {};
1284
+ return {
1285
+ widget: {
1286
+ type: "combocheck",
1287
+ widgetName: buildWidgetName(),
1288
+ widgetNameAlias: "",
1289
+ customCls: null,
1290
+ height: 34,
1291
+ width: 350,
1292
+ enable: true,
1293
+ visible: true,
1294
+ allowBlank: true,
1295
+ funMode: "module",
1296
+ module: null,
1297
+ libs: [],
1298
+ extendSet: {
1299
+ sort: ["datahelp", "module", "formEvent"],
1300
+ status: true,
1301
+ triggerField: "",
1302
+ triggerFieldMode: "none",
1303
+ version: 1
1304
+ },
1305
+ colorEnable: true,
1306
+ //颜色 是否开启颜色
1307
+ mode: "",
1308
+ allowAddOptions: false,
1309
+ //允许成员填写时添加新选项
1310
+ allowAddLinkData: false,
1311
+ ...widget,
1312
+ labelStyle: label
1313
+ },
1314
+ label,
1315
+ lineWidth: 6,
1316
+ tab: null,
1317
+ ...rest
1318
+ };
1319
+ };
1320
+
1321
+ // src/utils/fields-json-rebuild/rebuild-location.ts
1322
+ var rebuildLocation = (truncatedJson) => {
1323
+ const { widget, label, ...rest } = truncatedJson || {};
1324
+ return {
1325
+ widget: {
1326
+ type: "location",
1327
+ widgetName: buildWidgetName(),
1328
+ widgetNameAlias: "",
1329
+ customCls: null,
1330
+ enable: true,
1331
+ visible: true,
1332
+ allowBlank: true,
1333
+ funMode: "module",
1334
+ module: null,
1335
+ libs: [],
1336
+ extendSet: {
1337
+ sort: ["datahelp", "module", "formEvent"],
1338
+ status: true,
1339
+ triggerField: "",
1340
+ triggerFieldMode: "none",
1341
+ version: 1
1342
+ },
1343
+ adjustable: true,
1344
+ //允许移动端微调
1345
+ lnglatVisible: true,
1346
+ //显示经纬度坐标
1347
+ autoLocation: true,
1348
+ //移动端自动触发定位
1349
+ enablePcLocation: true,
1350
+ //允许PC端定位并选择位置
1351
+ ...widget,
1352
+ labelStyle: label
1353
+ },
1354
+ label,
1355
+ lineWidth: 6,
1356
+ tab: null,
1357
+ ...rest
1358
+ };
1359
+ };
1360
+
1361
+ // src/utils/fields-json-rebuild/rebuild-textarea.ts
1362
+ var rebuildTextarea = (truncatedJson) => {
1363
+ const { widget, label, ...rest } = truncatedJson || {};
1364
+ return {
1365
+ widget: {
1366
+ type: "textarea",
1367
+ widgetName: buildWidgetName(),
1368
+ widgetNameAlias: "",
1369
+ triggerEvent: false,
1370
+ customCls: null,
1371
+ height: 140,
1372
+ width: 734,
1373
+ value: "",
1374
+ enable: true,
1375
+ visible: true,
1376
+ allowBlank: true,
1377
+ funMode: "module",
1378
+ module: null,
1379
+ libs: [],
1380
+ extendSet: {
1381
+ sort: ["datahelp", "module", "formEvent"],
1382
+ status: true,
1383
+ triggerField: "",
1384
+ triggerFieldMode: "none",
1385
+ version: 1
1386
+ },
1387
+ noRepeat: false,
1388
+ alertinfo: {
1389
+ icon: "success",
1390
+ tip: "\u8BF7\u8BBE\u7F6E\u63D0\u793A\u5185\u5BB9"
1391
+ },
1392
+ autoHeight: true,
1393
+ //根据内容自适应高度
1394
+ maxLength: 5e3,
1395
+ //限制输入最大字符数 不限制的话,整个maxLength不存在
1396
+ ...widget,
1397
+ labelStyle: label
1398
+ },
1399
+ // description,
1400
+ label,
1401
+ lineWidth: 6,
1402
+ tab: null,
1403
+ ...rest
1404
+ };
1405
+ };
1406
+
1407
+ // src/utils/fields-json-rebuild/rebuild-button.ts
1408
+ var rebuildButton = (truncatedJson = {}) => {
1409
+ const { widget, label, ...rest } = truncatedJson;
1410
+ return {
1411
+ widget: {
1412
+ type: "button",
1413
+ widgetName: buildWidgetName(),
1414
+ widgetNameAlias: "",
1415
+ triggerEvent: 0,
1416
+ customCls: null,
1417
+ height: 36,
1418
+ width: 350,
1419
+ enable: true,
1420
+ visible: true,
1421
+ allowBlank: false,
1422
+ extendSet: {
1423
+ sort: ["datahelp", "module", "formEvent"],
1424
+ status: true,
1425
+ triggerField: "",
1426
+ triggerFieldMode: "none",
1427
+ funMode: "popupreport"
1428
+ },
1429
+ background: {
1430
+ //颜色
1431
+ mode: "color",
1432
+ position: "center"
1433
+ },
1434
+ mode: "all",
1435
+ //模式 all 扩展 popupreport 弹出报表 popupform 弹出表单 print 页面打印 popuppage 弹出外部网页
1436
+ theme: "default",
1437
+ //风格 default 默认,有边框有底色 style1 有边框无底色 none 无边框无底色
1438
+ eventAlert: false,
1439
+ //是否显示提醒框
1440
+ alertinfo: {
1441
+ icon: "success",
1442
+ tip: "\u8BF7\u8BBE\u7F6E\u63D0\u793A\u5185\u5BB9"
1443
+ },
1444
+ ...widget,
1445
+ labelStyle: label
1446
+ },
1447
+ label,
1448
+ lineWidth: 6,
1449
+ tab: null,
1450
+ ...rest
1451
+ };
1452
+ };
1453
+
1454
+ // src/utils/fields-json-rebuild/rebuild-address.ts
1455
+ var rebuildAddress = (truncatedJson = {}) => {
1456
+ const { widget, label, ...rest } = truncatedJson;
1457
+ return {
1458
+ widget: {
1459
+ type: "address",
1460
+ widgetName: buildWidgetName(),
1461
+ widgetNameAlias: "",
1462
+ customCls: null,
1463
+ width: 720,
1464
+ enable: true,
1465
+ visible: true,
1466
+ funMode: "module",
1467
+ module: null,
1468
+ libs: [],
1469
+ extendSet: {
1470
+ sort: ["datahelp", "module", "formEvent"],
1471
+ status: true,
1472
+ triggerField: "",
1473
+ triggerFieldMode: "none",
1474
+ version: 1
1475
+ },
1476
+ needDetail: true,
1477
+ eventMode: 1,
1478
+ //公式联动触发模式 1 默认,省市县/详细地址内容改变都触发 2 只有省市县改变才触发 3 只有详细地址改变才触发
1479
+ seleceMapAddress: true,
1480
+ //开启经纬度定位
1481
+ ...widget,
1482
+ labelStyle: label
1483
+ },
1484
+ label,
1485
+ lineWidth: 6,
1486
+ tab: null,
1487
+ ...rest
1488
+ };
1489
+ };
1490
+
1491
+ // src/utils/fields-json-rebuild/rebuild-subform.ts
1492
+ var rebuildSubform = (originObj = {}) => {
1493
+ const { widget, label, ...rest } = originObj;
1494
+ return {
1495
+ widget: {
1496
+ type: "subform",
1497
+ widgetName: buildWidgetName(),
1498
+ widgetNameAlias: "",
1499
+ customCls: null,
1500
+ enable: true,
1501
+ visible: true,
1502
+ allowBlank: true,
1503
+ labelStyle: label,
1504
+ extendSet: {
1505
+ sort: ["datahelp", "module", "formEvent"],
1506
+ status: true,
1507
+ triggerField: "",
1508
+ triggerFieldMode: "none",
1509
+ version: 1
1510
+ },
1511
+ items: (widget.items || []).map((item, index) => {
1512
+ const result = rebuildFieldsJsonStructure(item, true);
1513
+ result.widget.widgetName = buildWidgetName("_widget", index);
1514
+ return result;
1515
+ }),
1516
+ sortable: true,
1517
+ //启用子表单数据排序
1518
+ allowImportV2: false,
1519
+ //从excel导入数据
1520
+ sticky_column: {
1521
+ //PC端冻结前 n 列
1522
+ limit: 2,
1523
+ //多少列 范围 1-3
1524
+ enable: true
1525
+ //是否开启
1526
+ },
1527
+ sticky_column_mobile: {
1528
+ //移动端冻结前 n 列
1529
+ limit: 1,
1530
+ //多少列 范围 1-3
1531
+ enable: true
1532
+ //是否开启
1533
+ },
1534
+ mobileStyle: "table",
1535
+ //移动端显示样式 list 纵向展开 table 横向表格
1536
+ subform_create: true,
1537
+ //可新增记录
1538
+ subform_insert: true,
1539
+ //可插入记录
1540
+ subform_edit: true,
1541
+ //可编辑已有记录
1542
+ subform_delete: true,
1543
+ //可删除已有记录
1544
+ subform_fill: true,
1545
+ //允许填报数据
1546
+ subform_import: true,
1547
+ //允许导入数据
1548
+ subform_dataload: true,
1549
+ //允许数据加载
1550
+ loaddataconfig: {
1551
+ //数据加载设置
1552
+ mode: "tree",
1553
+ extendSet: {
1554
+ sort: ["datahelp", "module", "formEvent"],
1555
+ status: true,
1556
+ triggerField: "",
1557
+ triggerFieldMode: "none"
1558
+ }
1559
+ },
1560
+ allowLoadData: false,
1561
+ //是否开启数据加载
1562
+ allowAddData: true,
1563
+ //允许新增数据源数据
1564
+ subformloaddataTitle: "\u6570\u636E\u52A0\u8F7D",
1565
+ //数据加载显示的标题
1566
+ subFieldShowRules: [],
1567
+ //子字段显隐规则
1568
+ quick_fill: true
1569
+ //从excel填报数据
1570
+ },
1571
+ description: null,
1572
+ label,
1573
+ lineWidth: 12,
1574
+ tab: null
1575
+ };
1576
+ };
1577
+
1578
+ // src/utils/fields-json-rebuild/rebuild-data-query.ts
1579
+ var rebuildDataQuery = (truncatedJson) => {
1580
+ const { widget, label, ...rest } = truncatedJson || {};
1581
+ return {
1582
+ widget: {
1583
+ widgetName: buildWidgetName(),
1584
+ widgetNameAlias: "",
1585
+ customCls: null,
1586
+ enable: true,
1587
+ visible: true,
1588
+ allowBlank: true,
1589
+ linkFilter: {},
1590
+ rely: {
1591
+ widgets: []
1592
+ },
1593
+ showMode: "one",
1594
+ //显示数据条数 one 一条 many 多条
1595
+ allowAdd: true,
1596
+ //允许新增关联表数据,只有 refType 为 form才可以选择true
1597
+ refType: "form",
1598
+ //关联表的类型,根据 linkForm 表的类型决定的。 form 表单 etl_table 视图 aggregate_table 聚合表
1599
+ showType: "none",
1600
+ //数据显示模式 none 默认 label 标题
1601
+ addExtendSet: [],
1602
+ ...widget,
1603
+ linkFields: [],
1604
+ labelStyle: label,
1605
+ type: "linkquery"
1606
+ },
1607
+ description: null,
1608
+ label,
1609
+ lineWidth: 6,
1610
+ tab: null,
1611
+ ...rest
1612
+ };
1613
+ };
1614
+
1615
+ // src/utils/fields-json-rebuild/index.ts
1616
+ var RebuilderMap = {
1617
+ address: rebuildAddress,
1618
+ button: rebuildButton,
1619
+ textarea: rebuildTextarea,
1620
+ datetime: rebuildDatetime,
1621
+ text: rebuildText,
1622
+ password: rebuildText,
1623
+ location: rebuildLocation,
1624
+ radiogroup: rebuildRadioGroup,
1625
+ radio: rebuildRadioGroup,
1626
+ combo: rebuildSelect,
1627
+ combocheck: rebuildComboChecker,
1628
+ separator: rebuildLine,
1629
+ checkboxgroup: rebuildCheckboxGroup,
1630
+ upload: rebuildUploader,
1631
+ number: rebuildNumber,
1632
+ image: rebuildImage,
1633
+ signature: rebuildSignature,
1634
+ user: rebuildUser,
1635
+ dataload: rebuildDataLoader,
1636
+ linkdata: rebuildDataLinker,
1637
+ linkquery: rebuildDataQuery,
1638
+ usergroup: rebuildUserGroup,
1639
+ subform: rebuildSubform,
1640
+ dept: rebuildDept,
1641
+ sn: rebuildSn,
1642
+ deptgroup: rebuildDeptGroup,
1643
+ unknown: defaultBuilder
1644
+ };
1645
+ var rebuildFieldsJsonStructure = (truncatedJson, subItemsOnly = false) => {
1646
+ if (!truncatedJson || !truncatedJson.widget || !truncatedJson.widget.type) {
1647
+ return truncatedJson;
1648
+ }
1649
+ const fieldType = truncatedJson.widget.type || "unknown";
1650
+ if (subItemsOnly && fieldType === "subform") {
1651
+ return defaultBuilder(truncatedJson);
1652
+ }
1653
+ const rebuilder = RebuilderMap[fieldType] || defaultBuilder;
1654
+ return rebuilder(truncatedJson);
1655
+ };
1656
+
1657
+ // src/stream-trasnformer/fields-json-transform-stream.ts
1658
+ var createFieldsJsonTransformStream = (enableJsonParser) => {
1659
+ let parser;
1660
+ let id;
1661
+ const chunkGuard = (chunk) => {
1662
+ if (!enableJsonParser) {
1663
+ return false;
1664
+ }
1665
+ if (chunk.type !== "text-delta" || !("delta" in chunk)) {
1666
+ return false;
1667
+ }
1668
+ return true;
1669
+ };
1670
+ const transformer = {
1671
+ flush: (controller) => {
1672
+ try {
1673
+ controller.terminate();
1674
+ } catch (e) {
1675
+ controller.error("stop error" + e);
1676
+ }
1677
+ },
1678
+ transform: (chunk, controller) => {
1679
+ if (!parser) {
1680
+ console.log("parser not init");
1681
+ return;
1682
+ }
1683
+ try {
1684
+ if (chunkGuard(chunk)) {
1685
+ if ("id" in chunk && "delta" in chunk) {
1686
+ id = chunk.id;
1687
+ parser.write(chunk.delta);
1688
+ }
1689
+ } else {
1690
+ controller.enqueue(chunk);
1691
+ }
1692
+ } catch (e) {
1693
+ controller.error(e);
1694
+ }
1695
+ },
1696
+ start: (controller) => {
1697
+ parser = new import_json.JSONParser({
1698
+ paths: ["$.*"]
1699
+ });
1700
+ const enqueueTextDelta = enableJsonParser ? createTextInfoEnqueuer(controller) : (content) => {
1701
+ };
1702
+ parser.onValue = (parsedInfo) => {
1703
+ const value = parsedInfo.value;
1704
+ if (value.widget) {
1705
+ value.widget.widgetName = `_widget_${Date.now()}`;
1706
+ }
1707
+ enqueueTextDelta(
1708
+ JSON.stringify(value),
1709
+ JSON.stringify({
1710
+ type: "mcp-fields-json",
1711
+ field: rebuildFieldsJsonStructure(value)
1712
+ }),
1713
+ id
1714
+ );
1715
+ };
1716
+ let errorLogged = false;
1717
+ parser.onError = (err) => {
1718
+ if (!errorLogged) {
1719
+ console.error("JsonWidgetStream: JSON Parsing Error:", err);
1720
+ errorLogged = true;
1721
+ }
1722
+ };
1723
+ parser.onEnd = () => {
1724
+ enqueueTextDelta(
1725
+ " ",
1726
+ JSON.stringify({
1727
+ appendConfirm: "save-fields"
1728
+ })
1729
+ );
1730
+ };
1731
+ }
1732
+ };
1733
+ return new TransformStream(transformer);
1734
+ };
1735
+
1736
+ // src/stream-trasnformer/suggestion-transform-stream.ts
1737
+ var SuggestionTransformStream = class extends TransformStream {
1738
+ constructor(enable) {
1739
+ let enqueuer;
1740
+ super({
1741
+ start(controller) {
1742
+ enqueuer = createTextInfoEnqueuer(controller);
1743
+ },
1744
+ transform(chunk, controller) {
1745
+ if (enable && chunk.type === "raw" && chunk.rawValue.type === "follow_up" && enqueuer) {
1746
+ enqueuer(
1747
+ chunk.rawValue.content,
1748
+ JSON.stringify({
1749
+ type: "suggestion"
1750
+ })
1751
+ );
1752
+ } else {
1753
+ controller.enqueue(chunk);
1754
+ }
1755
+ }
1756
+ });
1757
+ }
1758
+ };
1759
+ // Annotate the CommonJS export names for ESM import in node:
1760
+ 0 && (module.exports = {
1761
+ SuggestionTransformStream,
1762
+ createCoze,
1763
+ createFieldsJsonTransformStream,
1764
+ createTextInfoEnqueuer
1765
+ });
1766
+ //# sourceMappingURL=index.js.map