@mybricks/to-code-taro 1.0.0

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 (181) hide show
  1. package/dist/cjs/abstractEventTypeDef.d.ts +11 -0
  2. package/dist/cjs/abstractEventTypeDef.js +93 -0
  3. package/dist/cjs/core/comlib/Index.js +45 -0
  4. package/dist/cjs/core/comlib/_ScanQrcode.js +60 -0
  5. package/dist/cjs/core/comlib/_SetStorage.js +76 -0
  6. package/dist/cjs/core/comlib/_ShowToast.js +96 -0
  7. package/dist/cjs/core/mybricks/MyBricksDescriptor.js +213 -0
  8. package/dist/cjs/core/mybricks/Subject.js +115 -0
  9. package/dist/cjs/core/mybricks/constant.js +70 -0
  10. package/dist/cjs/core/mybricks/context.js +33 -0
  11. package/dist/cjs/core/mybricks/createEnv.js +39 -0
  12. package/dist/cjs/core/mybricks/createJSHandle.js +150 -0
  13. package/dist/cjs/core/mybricks/createModuleEventsHandle.js +49 -0
  14. package/dist/cjs/core/mybricks/createReactiveInputHandler.js +63 -0
  15. package/dist/cjs/core/mybricks/event.js +70 -0
  16. package/dist/cjs/core/mybricks/index.js +871 -0
  17. package/dist/cjs/core/mybricks/log.js +38 -0
  18. package/dist/cjs/core/mybricks/utils.js +69 -0
  19. package/dist/cjs/core/mybricks/variables.js +217 -0
  20. package/dist/cjs/core/utils/ComContext.js +39 -0
  21. package/dist/cjs/core/utils/index.js +88 -0
  22. package/dist/cjs/core/utils/useContext.js +53 -0
  23. package/dist/cjs/core/utils/with.js +84 -0
  24. package/dist/cjs/generate/generateTaroProjectJson.d.ts +24 -0
  25. package/dist/cjs/generate/generateTaroProjectJson.js +101 -0
  26. package/dist/cjs/generate/generateTaroTempalteJson.d.ts +15 -0
  27. package/dist/cjs/generate/generateTaroTempalteJson.js +103 -0
  28. package/dist/cjs/generate/utils/appConfig.d.ts +21 -0
  29. package/dist/cjs/generate/utils/appConfig.js +47 -0
  30. package/dist/cjs/generate/utils/commonDir.d.ts +21 -0
  31. package/dist/cjs/generate/utils/commonDir.js +50 -0
  32. package/dist/cjs/generate/utils/fileNode.d.ts +17 -0
  33. package/dist/cjs/generate/utils/fileNode.js +57 -0
  34. package/dist/cjs/generate/utils/index.d.ts +7 -0
  35. package/dist/cjs/generate/utils/index.js +29 -0
  36. package/dist/cjs/generate/utils/tabBarImages.d.ts +14 -0
  37. package/dist/cjs/generate/utils/tabBarImages.js +36 -0
  38. package/dist/cjs/handleCom.d.ts +31 -0
  39. package/dist/cjs/handleCom.js +260 -0
  40. package/dist/cjs/handleDom.d.ts +19 -0
  41. package/dist/cjs/handleDom.js +86 -0
  42. package/dist/cjs/handleExtension.d.ts +10 -0
  43. package/dist/cjs/handleExtension.js +300 -0
  44. package/dist/cjs/handleGlobal.d.ts +21 -0
  45. package/dist/cjs/handleGlobal.js +155 -0
  46. package/dist/cjs/handleModule.d.ts +15 -0
  47. package/dist/cjs/handleModule.js +108 -0
  48. package/dist/cjs/handleSlot.d.ts +27 -0
  49. package/dist/cjs/handleSlot.js +197 -0
  50. package/dist/cjs/index.d.ts +3 -0
  51. package/dist/cjs/index.js +44 -0
  52. package/dist/cjs/taro-template.json +5370 -0
  53. package/dist/cjs/toCodeTaro.d.ts +130 -0
  54. package/dist/cjs/toCodeTaro.js +427 -0
  55. package/dist/cjs/utils/code/component.d.ts +19 -0
  56. package/dist/cjs/utils/code/component.js +85 -0
  57. package/dist/cjs/utils/code/index.d.ts +18 -0
  58. package/dist/cjs/utils/code/index.js +71 -0
  59. package/dist/cjs/utils/code/renderManager.d.ts +22 -0
  60. package/dist/cjs/utils/code/renderManager.js +80 -0
  61. package/dist/cjs/utils/code/scene.d.ts +19 -0
  62. package/dist/cjs/utils/code/scene.js +82 -0
  63. package/dist/cjs/utils/convertNamespace.d.ts +11 -0
  64. package/dist/cjs/utils/convertNamespace.js +43 -0
  65. package/dist/cjs/utils/genJSModules.d.ts +12 -0
  66. package/dist/cjs/utils/genJSModules.js +116 -0
  67. package/dist/cjs/utils/getComponentClassName.d.ts +16 -0
  68. package/dist/cjs/utils/getComponentClassName.js +47 -0
  69. package/dist/cjs/utils/handlePageConfig.d.ts +24 -0
  70. package/dist/cjs/utils/handlePageConfig.js +73 -0
  71. package/dist/cjs/utils/handleProcess.d.ts +9 -0
  72. package/dist/cjs/utils/handleProcess.js +370 -0
  73. package/dist/cjs/utils/index.d.ts +62 -0
  74. package/dist/cjs/utils/index.js +321 -0
  75. package/dist/cjs/utils/pageConfig/converter.d.ts +17 -0
  76. package/dist/cjs/utils/pageConfig/converter.js +83 -0
  77. package/dist/cjs/utils/pageConfig/index.d.ts +10 -0
  78. package/dist/cjs/utils/pageConfig/index.js +33 -0
  79. package/dist/cjs/utils/pageConfig/pageConfig.d.ts +10 -0
  80. package/dist/cjs/utils/pageConfig/pageConfig.js +87 -0
  81. package/dist/cjs/utils/pageConfig/saveBase64Image.d.ts +14 -0
  82. package/dist/cjs/utils/pageConfig/saveBase64Image.js +81 -0
  83. package/dist/cjs/utils/pageConfig/tabBarConfig.d.ts +13 -0
  84. package/dist/cjs/utils/pageConfig/tabBarConfig.js +74 -0
  85. package/dist/cjs/utils/pageConfig/types.d.ts +68 -0
  86. package/dist/cjs/utils/pageConfig/types.js +17 -0
  87. package/dist/cjs/utils/pageConfig/validator.d.ts +13 -0
  88. package/dist/cjs/utils/pageConfig/validator.js +67 -0
  89. package/dist/cjs/utils/pxtransform.d.ts +28 -0
  90. package/dist/cjs/utils/pxtransform.js +102 -0
  91. package/dist/esm/abstractEventTypeDef.d.ts +11 -0
  92. package/dist/esm/abstractEventTypeDef.js +63 -0
  93. package/dist/esm/core/comlib/Index.js +3 -0
  94. package/dist/esm/core/comlib/_ScanQrcode.js +27 -0
  95. package/dist/esm/core/comlib/_SetStorage.js +52 -0
  96. package/dist/esm/core/comlib/_ShowToast.js +68 -0
  97. package/dist/esm/core/mybricks/MyBricksDescriptor.js +232 -0
  98. package/dist/esm/core/mybricks/Subject.js +143 -0
  99. package/dist/esm/core/mybricks/constant.js +18 -0
  100. package/dist/esm/core/mybricks/context.js +5 -0
  101. package/dist/esm/core/mybricks/createEnv.js +9 -0
  102. package/dist/esm/core/mybricks/createJSHandle.js +138 -0
  103. package/dist/esm/core/mybricks/createModuleEventsHandle.js +26 -0
  104. package/dist/esm/core/mybricks/createReactiveInputHandler.js +40 -0
  105. package/dist/esm/core/mybricks/event.js +44 -0
  106. package/dist/esm/core/mybricks/index.js +952 -0
  107. package/dist/esm/core/mybricks/log.js +12 -0
  108. package/dist/esm/core/mybricks/utils.js +41 -0
  109. package/dist/esm/core/mybricks/variables.js +190 -0
  110. package/dist/esm/core/utils/ComContext.js +10 -0
  111. package/dist/esm/core/utils/index.js +57 -0
  112. package/dist/esm/core/utils/useContext.js +24 -0
  113. package/dist/esm/core/utils/with.js +67 -0
  114. package/dist/esm/generate/generateTaroProjectJson.d.ts +24 -0
  115. package/dist/esm/generate/generateTaroProjectJson.js +102 -0
  116. package/dist/esm/generate/generateTaroTempalteJson.d.ts +15 -0
  117. package/dist/esm/generate/generateTaroTempalteJson.js +94 -0
  118. package/dist/esm/generate/utils/appConfig.d.ts +21 -0
  119. package/dist/esm/generate/utils/appConfig.js +30 -0
  120. package/dist/esm/generate/utils/commonDir.d.ts +21 -0
  121. package/dist/esm/generate/utils/commonDir.js +36 -0
  122. package/dist/esm/generate/utils/fileNode.d.ts +17 -0
  123. package/dist/esm/generate/utils/fileNode.js +49 -0
  124. package/dist/esm/generate/utils/index.d.ts +7 -0
  125. package/dist/esm/generate/utils/index.js +8 -0
  126. package/dist/esm/generate/utils/tabBarImages.d.ts +14 -0
  127. package/dist/esm/generate/utils/tabBarImages.js +15 -0
  128. package/dist/esm/handleCom.d.ts +31 -0
  129. package/dist/esm/handleCom.js +297 -0
  130. package/dist/esm/handleDom.d.ts +19 -0
  131. package/dist/esm/handleDom.js +63 -0
  132. package/dist/esm/handleExtension.d.ts +10 -0
  133. package/dist/esm/handleExtension.js +243 -0
  134. package/dist/esm/handleGlobal.d.ts +21 -0
  135. package/dist/esm/handleGlobal.js +117 -0
  136. package/dist/esm/handleModule.d.ts +15 -0
  137. package/dist/esm/handleModule.js +78 -0
  138. package/dist/esm/handleSlot.d.ts +27 -0
  139. package/dist/esm/handleSlot.js +205 -0
  140. package/dist/esm/index.d.ts +3 -0
  141. package/dist/esm/index.js +3 -0
  142. package/dist/esm/taro-template.json +5370 -0
  143. package/dist/esm/toCodeTaro.d.ts +130 -0
  144. package/dist/esm/toCodeTaro.js +452 -0
  145. package/dist/esm/utils/code/component.d.ts +19 -0
  146. package/dist/esm/utils/code/component.js +54 -0
  147. package/dist/esm/utils/code/index.d.ts +18 -0
  148. package/dist/esm/utils/code/index.js +51 -0
  149. package/dist/esm/utils/code/renderManager.d.ts +22 -0
  150. package/dist/esm/utils/code/renderManager.js +62 -0
  151. package/dist/esm/utils/code/scene.d.ts +19 -0
  152. package/dist/esm/utils/code/scene.js +47 -0
  153. package/dist/esm/utils/convertNamespace.d.ts +11 -0
  154. package/dist/esm/utils/convertNamespace.js +27 -0
  155. package/dist/esm/utils/genJSModules.d.ts +12 -0
  156. package/dist/esm/utils/genJSModules.js +44 -0
  157. package/dist/esm/utils/getComponentClassName.d.ts +16 -0
  158. package/dist/esm/utils/getComponentClassName.js +37 -0
  159. package/dist/esm/utils/handlePageConfig.d.ts +24 -0
  160. package/dist/esm/utils/handlePageConfig.js +68 -0
  161. package/dist/esm/utils/handleProcess.d.ts +9 -0
  162. package/dist/esm/utils/handleProcess.js +379 -0
  163. package/dist/esm/utils/index.d.ts +62 -0
  164. package/dist/esm/utils/index.js +345 -0
  165. package/dist/esm/utils/pageConfig/converter.d.ts +17 -0
  166. package/dist/esm/utils/pageConfig/converter.js +105 -0
  167. package/dist/esm/utils/pageConfig/index.d.ts +10 -0
  168. package/dist/esm/utils/pageConfig/index.js +11 -0
  169. package/dist/esm/utils/pageConfig/pageConfig.d.ts +10 -0
  170. package/dist/esm/utils/pageConfig/pageConfig.js +60 -0
  171. package/dist/esm/utils/pageConfig/saveBase64Image.d.ts +14 -0
  172. package/dist/esm/utils/pageConfig/saveBase64Image.js +105 -0
  173. package/dist/esm/utils/pageConfig/tabBarConfig.d.ts +13 -0
  174. package/dist/esm/utils/pageConfig/tabBarConfig.js +82 -0
  175. package/dist/esm/utils/pageConfig/types.d.ts +68 -0
  176. package/dist/esm/utils/pageConfig/types.js +1 -0
  177. package/dist/esm/utils/pageConfig/validator.d.ts +13 -0
  178. package/dist/esm/utils/pageConfig/validator.js +64 -0
  179. package/dist/esm/utils/pxtransform.d.ts +28 -0
  180. package/dist/esm/utils/pxtransform.js +121 -0
  181. package/package.json +74 -0
@@ -0,0 +1,370 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: true });
8
+ };
9
+ var __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from === "object" || typeof from === "function") {
11
+ for (let key of __getOwnPropNames(from))
12
+ if (!__hasOwnProp.call(to, key) && key !== except)
13
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
14
+ }
15
+ return to;
16
+ };
17
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
+
19
+ // src/utils/handleProcess.ts
20
+ var handleProcess_exports = {};
21
+ __export(handleProcess_exports, {
22
+ handleProcess: () => handleProcess
23
+ });
24
+ module.exports = __toCommonJS(handleProcess_exports);
25
+ var import_index = require("./index");
26
+ var isJsCalculationComponent = (namespace) => {
27
+ return namespace === "mybricks.taro._muilt-inputJs" || namespace === "mybricks.core-comlib.js-ai";
28
+ };
29
+ var isJsApiComponent = (namespace, rtType) => {
30
+ return namespace.startsWith("mybricks.taro._") && (rtType == null ? void 0 : rtType.match(/^js/gi)) !== null;
31
+ };
32
+ var handleProcess = (event, config) => {
33
+ let code = "";
34
+ const { process } = event;
35
+ const indent = (0, import_index.indentation)(config.codeStyle.indent * config.depth);
36
+ const indent2 = (0, import_index.indentation)(config.codeStyle.indent * (config.depth + 1));
37
+ const hasJsCalculationComponent = process.nodesDeclaration.some(
38
+ ({ meta }) => isJsCalculationComponent(meta.def.namespace)
39
+ );
40
+ if (hasJsCalculationComponent) {
41
+ config.addParentDependencyImport({
42
+ packageName: "../../common/index",
43
+ dependencyNames: ["jsModules"],
44
+ importType: "named"
45
+ });
46
+ }
47
+ process.nodesDeclaration.forEach(({ meta, props }) => {
48
+ var _a;
49
+ if (meta.def.namespace.startsWith("mybricks.taro.module")) {
50
+ return;
51
+ }
52
+ const isJsCalc = isJsCalculationComponent(meta.def.namespace);
53
+ const isJsApi = isJsApiComponent(meta.def.namespace, meta.def.rtType);
54
+ const { importInfo, name, callName } = config.getComponentMeta(meta);
55
+ const componentName = name;
56
+ if (isJsCalc) {
57
+ code += generateJsCalculationComponentCode({
58
+ meta,
59
+ props,
60
+ componentName,
61
+ config,
62
+ event,
63
+ indent,
64
+ indent2
65
+ });
66
+ return;
67
+ }
68
+ if (isJsApi) {
69
+ code += generateJsApiComponentCode({
70
+ meta,
71
+ props,
72
+ componentName,
73
+ callName,
74
+ importInfo,
75
+ config,
76
+ event,
77
+ indent,
78
+ indent2
79
+ });
80
+ return;
81
+ }
82
+ config.addParentDependencyImport({
83
+ packageName: importInfo.from,
84
+ dependencyNames: [importInfo.name],
85
+ importType: importInfo.type
86
+ });
87
+ const componentNameWithId = ((_a = config.getEventNodeName) == null ? void 0 : _a.call(config, {
88
+ com: meta,
89
+ scene: config.getCurrentScene(),
90
+ type: "declaration",
91
+ event
92
+ })) || `${componentName}_${meta.id}`;
93
+ config.addParentDependencyImport({
94
+ packageName: config.getComponentPackageName(),
95
+ dependencyNames: ["useAppContext"],
96
+ importType: "named"
97
+ });
98
+ code += `${indent}/** ${meta.title} */
99
+ ${indent}const ${componentNameWithId} = ${callName || componentName}({` + (config.verbose ? `
100
+ ${indent2}title: "${meta.title}",` : "") + (props.data ? `
101
+ ${indent2}data: ${(0, import_index.genObjectCode)(props.data, {
102
+ initialIndent: config.codeStyle.indent * (config.depth + 1),
103
+ indentSize: config.codeStyle.indent
104
+ })},` : "") + (props.inputs ? `
105
+ ${indent2}inputs: [${props.inputs.map((input) => `"${input}"`).join(", ")}],` : "") + (props.outputs ? `
106
+ ${indent2}outputs: [${props.outputs.map((output) => `"${output}"`).join(", ")}],` : "") + `
107
+ ${indent}}, appContext)
108
+ `;
109
+ });
110
+ process.nodesInvocation.forEach((props) => {
111
+ var _a, _b;
112
+ const { componentType, category, runType } = props;
113
+ let nextValue = getNextValue(props, config, event);
114
+ const isSameScope = checkIsSameScope(event, props);
115
+ const nextCode = getNextCode(props, config, isSameScope, event);
116
+ if (code) {
117
+ code += "\n";
118
+ }
119
+ if (componentType === "js") {
120
+ if (category === "scene") {
121
+ config.addParentDependencyImport({
122
+ packageName: config.getComponentPackageName(),
123
+ dependencyNames: ["page"],
124
+ importType: "named"
125
+ });
126
+ const _sceneId = props.meta.model.data._sceneId;
127
+ const operateName = props.meta.model.data.openType === "redirect" ? "replace" : "open";
128
+ code += `${indent}/** 打开 ${props.meta.title} */
129
+ ${indent}${nextCode}page.${operateName}("${((_a = config.getPageId) == null ? void 0 : _a.call(config, _sceneId)) || _sceneId}", ${nextValue})`;
130
+ } else if (category === "normal") {
131
+ let componentNameWithId = getComponentNameWithId(props, config, event);
132
+ code += `${indent}/** 调用 ${props.meta.title} */
133
+ ${indent}${nextCode}${componentNameWithId}(${runType === "input" ? nextValue : ""})`;
134
+ } else if (category === "var") {
135
+ if (props.meta.global) {
136
+ config.addParentDependencyImport({
137
+ packageName: config.getComponentPackageName(),
138
+ dependencyNames: ["globalVars"],
139
+ importType: "named"
140
+ });
141
+ code += `${indent}/** ${props.title} 全局变量 ${props.meta.title} */
142
+ ${indent}${nextCode}globalVars.${props.meta.title}.${props.id}(${nextValue})`;
143
+ } else {
144
+ const currentProvider = getCurrentProvider(
145
+ { isSameScope, props },
146
+ config
147
+ );
148
+ code += `${indent}/** ${props.title} 变量 ${props.meta.title} */
149
+ ${indent}${nextCode}this.${currentProvider.name}_Vars.${props.meta.title}.${props.id}(${nextValue})`;
150
+ }
151
+ } else if (category === "fx") {
152
+ if (props.meta.global) {
153
+ config.addParentDependencyImport({
154
+ packageName: config.getComponentPackageName(),
155
+ dependencyNames: ["globalFxs"],
156
+ importType: "named"
157
+ });
158
+ code += `${indent}/** 调用全局Fx ${props.meta.title} */
159
+ ${indent}${nextCode}globalFxs.${props.meta.ioProxy.id}(${nextValue})`;
160
+ } else {
161
+ const currentProvider = getCurrentProvider(
162
+ { isSameScope, props },
163
+ config
164
+ );
165
+ code += `${indent}/** 调用Fx ${props.meta.title} */
166
+ ${indent}${nextCode}this.${currentProvider.name}_Fxs.${props.meta.ioProxy.id}(${nextValue})`;
167
+ }
168
+ }
169
+ } else {
170
+ const currentProvider = getCurrentProvider({ isSameScope, props }, config);
171
+ currentProvider.controllers.add(props.meta.id);
172
+ const componentController = ((_b = config.getComponentController) == null ? void 0 : _b.call(config, {
173
+ com: props.meta,
174
+ scene: config.getCurrentScene()
175
+ })) || `controller_${props.meta.id}`;
176
+ code += `${indent}/** 调用 ${props.meta.title} 的 ${props.title} */
177
+ ${indent}${nextCode}this.${currentProvider.name}.${componentController}.${props.id}(${nextValue})`;
178
+ }
179
+ });
180
+ if (["fx", "extension-api", "extension-bus"].includes(event.type)) {
181
+ const returnCode = Object.entries(event.frameOutputs).reduce(
182
+ (pre, [, { id, outputs }]) => {
183
+ if (!outputs) {
184
+ return pre + `${indent2}${id}: undefined,
185
+ `;
186
+ } else {
187
+ const next = outputs.map((output) => {
188
+ return getNextValueWithParam(output, config, event);
189
+ }).join(", ");
190
+ return pre + `${indent2}${id}: ${next},
191
+ `;
192
+ }
193
+ },
194
+ ""
195
+ );
196
+ if (returnCode) {
197
+ code += `
198
+ ${indent}return {
199
+ ${returnCode}${indent}}`;
200
+ }
201
+ }
202
+ return code;
203
+ };
204
+ var checkIsSameScope = (event, props) => {
205
+ if (event.type === "com" && event.meta.parentComId === props.meta.parentComId && event.meta.frameId === props.meta.frameId) {
206
+ return true;
207
+ } else if (event.type === "slot" && event.comId === props.meta.parentComId && event.slotId === props.meta.frameId) {
208
+ return true;
209
+ } else if (event.type === "fx" && event.parentComId === props.meta.parentComId && event.parentSlotId === props.meta.frameId) {
210
+ return true;
211
+ }
212
+ return false;
213
+ };
214
+ var getComponentNameWithId = (props, config, event) => {
215
+ if (isJsCalculationComponent(props.meta.def.namespace)) {
216
+ if (config.getEventNodeName) {
217
+ const componentName = config.getEventNodeName({
218
+ com: props.meta,
219
+ scene: config.getCurrentScene(),
220
+ event,
221
+ type: "declaration"
222
+ });
223
+ if (componentName) {
224
+ return componentName;
225
+ }
226
+ }
227
+ return `jsModules_${props.meta.id}`;
228
+ }
229
+ if (config.getEventNodeName) {
230
+ const componentName = config.getEventNodeName({
231
+ com: props.meta,
232
+ scene: config.getCurrentScene(),
233
+ event,
234
+ type: "declaration"
235
+ });
236
+ if (componentName) {
237
+ return componentName;
238
+ }
239
+ }
240
+ const { name } = config.getComponentMeta(props.meta);
241
+ const sanitizedName = name.replace(/-/g, "_");
242
+ return `${sanitizedName}_${props.meta.id}`;
243
+ };
244
+ var getNextCode = (props, config, isSameScope, event) => {
245
+ const { nextParam } = props;
246
+ if (!nextParam.length) {
247
+ return "";
248
+ }
249
+ const componentNameWithId = getComponentNameWithId(props, config, event);
250
+ return `const ${componentNameWithId}_result = `;
251
+ };
252
+ var getNextValue = (props, config, event) => {
253
+ const { paramSource } = props;
254
+ const nextValue = paramSource.map((param) => {
255
+ if (param.type === "params") {
256
+ const params = config.getParams();
257
+ return params[param.id];
258
+ } else if (param.type === "constant") {
259
+ return JSON.stringify(param.value);
260
+ }
261
+ const componentNameWithId = getComponentNameWithId(param, config, event);
262
+ if (param.connectId) {
263
+ return `${componentNameWithId}_${param.connectId}.${param.id}`;
264
+ }
265
+ return `${componentNameWithId}_result.${param.id}`;
266
+ });
267
+ return nextValue.join(", ");
268
+ };
269
+ var getNextValueWithParam = (param, config, event) => {
270
+ if (param.type === "params") {
271
+ const params = config.getParams();
272
+ return params[param.id];
273
+ }
274
+ const componentNameWithId = getComponentNameWithId(param, config, event);
275
+ if (param.connectId) {
276
+ return `${componentNameWithId}_${param.connectId}.${param.id}`;
277
+ }
278
+ return `${componentNameWithId}_result.${param.id}`;
279
+ };
280
+ var getCurrentProvider = (params, config) => {
281
+ var _a;
282
+ const providerMap = config.getProviderMap();
283
+ const { isSameScope, props } = params;
284
+ const { meta } = props;
285
+ const { parentComId, frameId } = meta;
286
+ const providerName = ((_a = config.getProviderName) == null ? void 0 : _a.call(config, { com: meta, scene: config.getCurrentScene() })) || (!parentComId ? "slot_Index" : `slot_${frameId[0].toUpperCase() + frameId.slice(1)}_${parentComId}`);
287
+ const provider = providerMap[providerName];
288
+ if (!isSameScope) {
289
+ config.addConsumer(provider);
290
+ }
291
+ return provider;
292
+ };
293
+ var generateJsCalculationComponentCode = (params) => {
294
+ var _a;
295
+ const { meta, props, componentName, config, event, indent, indent2 } = params;
296
+ const componentNameWithId = ((_a = config.getEventNodeName) == null ? void 0 : _a.call(config, {
297
+ com: meta,
298
+ scene: config.getCurrentScene(),
299
+ type: "declaration",
300
+ event
301
+ })) || `jsModules_${meta.id}`;
302
+ const jsData = {};
303
+ if (props.data && "runImmediate" in props.data) {
304
+ jsData.runImmediate = props.data.runImmediate;
305
+ }
306
+ return `${indent}/** ${meta.title} */
307
+ ${indent}const ${componentNameWithId} = jsModules.${meta.id}({` + (config.verbose ? `
308
+ ${indent2}title: "${meta.title}",` : "") + (Object.keys(jsData).length > 0 ? `
309
+ ${indent2}data: ${(0, import_index.genObjectCode)(jsData, {
310
+ initialIndent: config.codeStyle.indent * (config.depth + 1),
311
+ indentSize: config.codeStyle.indent
312
+ })},` : "") + (props.inputs ? `
313
+ ${indent2}inputs: [${props.inputs.map((input) => `"${input}"`).join(", ")}],` : "") + (props.outputs ? `
314
+ ${indent2}outputs: [${props.outputs.map((output) => `"${output}"`).join(", ")}],` : "") + `
315
+ ${indent}}, appContext)
316
+ `;
317
+ };
318
+ var generateJsApiComponentCode = (params) => {
319
+ var _a;
320
+ const {
321
+ meta,
322
+ props,
323
+ componentName,
324
+ callName,
325
+ importInfo,
326
+ config,
327
+ event,
328
+ indent,
329
+ indent2
330
+ } = params;
331
+ config.addParentDependencyImport({
332
+ packageName: "../../core/mybricks/index",
333
+ dependencyNames: ["createJSHandle"],
334
+ importType: "named"
335
+ });
336
+ config.addParentDependencyImport({
337
+ packageName: importInfo.from,
338
+ dependencyNames: [importInfo.name],
339
+ importType: importInfo.type
340
+ });
341
+ const componentNameWithId = ((_a = config.getEventNodeName) == null ? void 0 : _a.call(config, {
342
+ com: meta,
343
+ scene: config.getCurrentScene(),
344
+ type: "declaration",
345
+ event
346
+ })) || `${componentName}_${meta.id}`;
347
+ config.addParentDependencyImport({
348
+ packageName: config.getComponentPackageName(),
349
+ dependencyNames: ["useAppContext"],
350
+ importType: "named"
351
+ });
352
+ return `${indent}/** ${meta.title} */
353
+ ${indent}const ${componentNameWithId} = createJSHandle(${callName || componentName}, {
354
+ ${indent2}props: {` + (config.verbose ? `
355
+ ${indent2} title: "${meta.title}",` : "") + (props.data ? `
356
+ ${indent2} data: ${(0, import_index.genObjectCode)(props.data, {
357
+ initialIndent: config.codeStyle.indent * (config.depth + 2),
358
+ indentSize: config.codeStyle.indent
359
+ })},` : "") + (props.inputs ? `
360
+ ${indent2} inputs: [${props.inputs.map((input) => `"${input}"`).join(", ")}],` : "") + (props.outputs ? `
361
+ ${indent2} outputs: [${props.outputs.map((output) => `"${output}"`).join(", ")}],` : "") + `
362
+ ${indent2}},
363
+ ${indent2}appContext
364
+ ${indent}})
365
+ `;
366
+ };
367
+ // Annotate the CommonJS export names for ESM import in node:
368
+ 0 && (module.exports = {
369
+ handleProcess
370
+ });
@@ -0,0 +1,62 @@
1
+ import type { ToTaroCodeConfig } from "../toCodeTaro";
2
+ export interface Style {
3
+ layout?: "smart" | "flex-column" | "flex-row" | {
4
+ display?: string;
5
+ position?: string;
6
+ flexDirection?: string;
7
+ alignItems?: string;
8
+ justifyContent?: string;
9
+ flexWrap?: string;
10
+ rowGap?: number;
11
+ columnGap?: number;
12
+ };
13
+ width?: string | number;
14
+ height?: string | number;
15
+ styleAry?: Array<{
16
+ selector: string;
17
+ css: Record<string, any>;
18
+ }>;
19
+ slots?: Record<string, {
20
+ layout?: string | object;
21
+ [key: string]: any;
22
+ }>;
23
+ [key: string]: any;
24
+ }
25
+ type ImportType = "default" | "named" | "module";
26
+ /** 导入依赖收集、解析 */
27
+ export declare class ImportManager {
28
+ private _config;
29
+ private _imports;
30
+ constructor(_config: ToTaroCodeConfig);
31
+ /** 添加依赖 */
32
+ addImport({ packageName, dependencyNames, importType, }: {
33
+ packageName: string;
34
+ dependencyNames: string[];
35
+ importType: ImportType;
36
+ }): void;
37
+ /** 依赖解析为code */
38
+ toCode(): string;
39
+ }
40
+ /** 将第一个字符转大写 */
41
+ export declare const firstCharToUpperCase: (str: string) => string;
42
+ /** 将第一个字符转小写 */
43
+ export declare const firstCharToLowerCase: (str: string) => string;
44
+ /** 缩进 */
45
+ export declare const indentation: (level: number) => string;
46
+ /** 驼峰转中划线 */
47
+ export declare const camelToKebab: (str: string) => string;
48
+ /** 中划线转驼峰 */
49
+ export declare const kebabToCamel: (str: string) => string;
50
+ /** 转换根节点样式 */
51
+ export declare const convertRootStyle: (style: Style) => Record<string, string | number>;
52
+ /** 转换组件样式为 Taro/React 样式 */
53
+ export declare const convertComponentStyle: (style: Style) => Record<string, Record<string, string | number>>;
54
+ /** 转换 styleAry 为 CSS 字符串 */
55
+ export declare const convertStyleAryToCss: (styleAry: any[], parentSelector?: string) => string;
56
+ /** 生成对象代码 */
57
+ export declare const genObjectCode: (object: any, config: {
58
+ initialIndent: number;
59
+ indentSize: number;
60
+ }) => string;
61
+ export { getUiComponentCode } from "./code";
62
+ export { getRootComponentClassName } from "./getComponentClassName";