@cloudbase/lowcode-builder 1.1.5-alpha.2 → 1.1.5-alpha.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/builder/core/index.js +3 -1
- package/lib/builder/mp/index.d.ts +3 -1
- package/lib/builder/mp/index.js +3 -2
- package/lib/builder/mp/mp_config.js +1 -0
- package/lib/builder/mp/util.js +1 -1
- package/lib/builder/service/webpack.js +4 -0
- package/lib/builder/util/generateFiles.d.ts +1 -0
- package/lib/builder/util/generateFiles.js +8 -6
- package/lib/builder/util/junk.d.ts +1 -0
- package/lib/builder/util/junk.js +7 -1
- package/lib/builder/util/net.js +4 -0
- package/package.json +3 -3
- package/template/mp/app.js +4 -7
- package/template/mp/common/util.js +26 -11
- package/template/mp/common/widget.js +2 -2
- package/template/mp/datasources/config.js.tpl +4 -0
- package/template/mp/datasources/index.js +3 -1
- package/template/mp/package.json +3 -3
|
@@ -69,6 +69,8 @@ async function buildWedaApp({ cals, subAppCalsList = [], dependencies = [], appK
|
|
|
69
69
|
resourceAppId,
|
|
70
70
|
},
|
|
71
71
|
buildTypeList,
|
|
72
|
+
isBrowserMpBuilder,
|
|
73
|
+
ignoreInstall,
|
|
72
74
|
});
|
|
73
75
|
// 如果是混合模式,则将特定的目录复制到工程下
|
|
74
76
|
// 针对 app.json / package.json 则采用 merge 的操作
|
|
@@ -89,7 +91,7 @@ async function buildWedaApp({ cals, subAppCalsList = [], dependencies = [], appK
|
|
|
89
91
|
});
|
|
90
92
|
// 如果是代开发的模式,则写入ext.json
|
|
91
93
|
await (0, postProcess_1.postprocessDeployExtraJson)(outDir, deployOptions);
|
|
92
|
-
if (!isBrowserMpBuilder && generateMpType === common_1.GenerateMpType.APP) {
|
|
94
|
+
if (!isBrowserMpBuilder && generateMpType === common_1.GenerateMpType.APP && !ignoreInstall) {
|
|
93
95
|
// 模板拷入的 miniprogram_npm 有问题,直接删除使用重新构建的版本
|
|
94
96
|
// 模板需要占位保证 mp 文件夹存在
|
|
95
97
|
fs_extra_1.default.removeSync(path_1.default.resolve(outDir, 'miniprogram_npm'));
|
|
@@ -2,7 +2,7 @@ import { IWeAppData, IPlugin } from '@cloudbase/lowcode-generator/lib/weapps-cor
|
|
|
2
2
|
import { IBuildContext } from './BuildContext';
|
|
3
3
|
import { DEPLOY_MODE } from '../../types';
|
|
4
4
|
import { BuildType, IAppUsedComp, IUsedComps } from '../types/common';
|
|
5
|
-
export declare function generateWxMp({ buildContext, weapps, plugins, deployMode, options, buildTypeList, }: {
|
|
5
|
+
export declare function generateWxMp({ buildContext, weapps, plugins, deployMode, options, buildTypeList, isBrowserMpBuilder, ignoreInstall, }: {
|
|
6
6
|
buildContext: IBuildContext;
|
|
7
7
|
weapps: IWeAppData[];
|
|
8
8
|
plugins: IPlugin[];
|
|
@@ -13,6 +13,8 @@ export declare function generateWxMp({ buildContext, weapps, plugins, deployMode
|
|
|
13
13
|
isCrossAccount: boolean;
|
|
14
14
|
};
|
|
15
15
|
buildTypeList: BuildType[];
|
|
16
|
+
isBrowserMpBuilder: boolean;
|
|
17
|
+
ignoreInstall: boolean;
|
|
16
18
|
}): Promise<{
|
|
17
19
|
miniprogramRoot: string;
|
|
18
20
|
}>;
|
package/lib/builder/mp/index.js
CHANGED
|
@@ -54,9 +54,9 @@ const cals_1 = require("@cloudbase/cals");
|
|
|
54
54
|
const templateDir = `${config_1.appTemplateDir}/mp/`;
|
|
55
55
|
const em = chalk_1.default.blue.bold;
|
|
56
56
|
const error = chalk_1.default.redBright;
|
|
57
|
-
async function generateWxMp({ buildContext, weapps, plugins, deployMode, options, buildTypeList, }) {
|
|
57
|
+
async function generateWxMp({ buildContext, weapps, plugins, deployMode, options, buildTypeList, isBrowserMpBuilder = false, ignoreInstall = false, }) {
|
|
58
58
|
var _a;
|
|
59
|
-
const { appId, projDir, materialLibs: materials, isProduction, mainAppData, domain,
|
|
59
|
+
const { appId, projDir, materialLibs: materials, isProduction, mainAppData, domain, isPrivateMode = false, } = buildContext;
|
|
60
60
|
const operationLabel = em('Wexin MiniProgram Generated');
|
|
61
61
|
console.time(operationLabel);
|
|
62
62
|
console.log(`Generating ${em('Wexin MiniProgram')} to ${projDir}`);
|
|
@@ -215,6 +215,7 @@ async function generateWxMp({ buildContext, weapps, plugins, deployMode, options
|
|
|
215
215
|
}));
|
|
216
216
|
if (!isBrowserMpBuilder && fs.existsSync(path_1.default.join(miniprogramRoot, 'package.json'))) {
|
|
217
217
|
await (0, webpack_1.installDependencies)(miniprogramRoot, {
|
|
218
|
+
ignoreInstall,
|
|
218
219
|
fixNodeModulesMap: { '@cloudbase/js-sdk': !isPrivateMode, mobx: true },
|
|
219
220
|
});
|
|
220
221
|
}
|
|
@@ -48,6 +48,7 @@ function generateMpConfig(weapps, ctx, options) {
|
|
|
48
48
|
const { miniprogramPlugins = [] } = ctx;
|
|
49
49
|
const projConfig = (0, lodash_1.merge)({}, mp_1.defaultProjConfig, {
|
|
50
50
|
projectname: (ctx.mainAppData && ctx.mainAppData.label) || `WeDa-${ctx.appId}`,
|
|
51
|
+
appid: (options === null || options === void 0 ? void 0 : options.mpAppId) || mp_1.defaultProjConfig.appid,
|
|
51
52
|
});
|
|
52
53
|
const pageConfigs = weapps.map((app) => {
|
|
53
54
|
var _a;
|
package/lib/builder/mp/util.js
CHANGED
|
@@ -67,7 +67,7 @@ function generateDataBindMeta(bind) {
|
|
|
67
67
|
imports += (0, lowcode_generator_1.generateExpressionAlias)(value);
|
|
68
68
|
}
|
|
69
69
|
catch (e) {
|
|
70
|
-
console.error('parse expression error', value);
|
|
70
|
+
console.error('parse expression error', value, e === null || e === void 0 ? void 0 : e.message);
|
|
71
71
|
}
|
|
72
72
|
expr = value;
|
|
73
73
|
}
|
|
@@ -455,6 +455,10 @@ async function installDependencies(targetDir, options = {}) {
|
|
|
455
455
|
}
|
|
456
456
|
}
|
|
457
457
|
catch (e) { }
|
|
458
|
+
// 如果generatedFileContents[path.resolve(targetDir, 'package.json')]不存在,说明是不存在缓存文件,isPkgModify必须是true,才不会忽略install
|
|
459
|
+
const isPkgModify = !generateFiles_1.generatedFileContents[path_1.default.resolve(targetDir, 'package.json')]
|
|
460
|
+
? true
|
|
461
|
+
: generateFiles_1.generatedFileContents[path_1.default.resolve(targetDir, 'package.json')].modify;
|
|
458
462
|
if ((options === null || options === void 0 ? void 0 : options.ignoreInstall) && fs_extra_1.default.existsSync(path_1.default.join(targetDir, 'node_modules'))) {
|
|
459
463
|
console.log(`ignore install dependencies in ${targetDir}`);
|
|
460
464
|
return;
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
2
|
import { IBuildContext } from '../mp/BuildContext';
|
|
3
3
|
import { OutputType } from 'jszip';
|
|
4
|
+
export declare const generatedFileContents: {};
|
|
4
5
|
export default function generateFiles(appFileData: any, srcDir: string, dstDir: string, ctx: IBuildContext): Promise<string[]>;
|
|
5
6
|
export declare function writeFile(outFile: string, content: string): Promise<boolean>;
|
|
6
7
|
export declare function removeFile(file: string): void;
|
|
@@ -26,7 +26,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
26
26
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
27
|
};
|
|
28
28
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
-
exports.strToBuf = exports.fileToZip = exports.getFiles = exports.copyRecursiveSync = exports.copyFileSync = exports.copy = exports.copyFiles = exports.cleanDir = exports.removeFile = exports.writeFile = void 0;
|
|
29
|
+
exports.strToBuf = exports.fileToZip = exports.getFiles = exports.copyRecursiveSync = exports.copyFileSync = exports.copy = exports.copyFiles = exports.cleanDir = exports.removeFile = exports.writeFile = exports.generatedFileContents = void 0;
|
|
30
30
|
const fs_extra_1 = __importDefault(require("fs-extra"));
|
|
31
31
|
const path_1 = __importDefault(require("path"));
|
|
32
32
|
const lodash_1 = require("lodash");
|
|
@@ -34,7 +34,7 @@ const junk = __importStar(require("../util/junk"));
|
|
|
34
34
|
const glob_1 = __importDefault(require("glob"));
|
|
35
35
|
const jszip_1 = __importDefault(require("jszip"));
|
|
36
36
|
const buffer_1 = require("buffer");
|
|
37
|
-
|
|
37
|
+
exports.generatedFileContents = {}; // generated files for incrmental build
|
|
38
38
|
async function generateFiles(appFileData, srcDir, dstDir, ctx) {
|
|
39
39
|
const filesGenerated = [];
|
|
40
40
|
// Generating file by template and data
|
|
@@ -67,22 +67,24 @@ async function generateFiles(appFileData, srcDir, dstDir, ctx) {
|
|
|
67
67
|
}
|
|
68
68
|
exports.default = generateFiles;
|
|
69
69
|
async function writeFile(outFile, content) {
|
|
70
|
-
|
|
70
|
+
var _a;
|
|
71
|
+
const generated = (_a = exports.generatedFileContents[outFile]) === null || _a === void 0 ? void 0 : _a.content;
|
|
71
72
|
if (generated === content && fs_extra_1.default.existsSync(outFile)) {
|
|
73
|
+
exports.generatedFileContents[outFile].modify = false;
|
|
72
74
|
return false;
|
|
73
75
|
}
|
|
74
76
|
// console.log(outFile);
|
|
75
77
|
await fs_extra_1.default.ensureFile(outFile);
|
|
76
78
|
await fs_extra_1.default.writeFile(outFile, content);
|
|
77
|
-
generatedFileContents[outFile] = content;
|
|
79
|
+
exports.generatedFileContents[outFile] = { content, modify: true };
|
|
78
80
|
return true;
|
|
79
81
|
}
|
|
80
82
|
exports.writeFile = writeFile;
|
|
81
83
|
function removeFile(file) {
|
|
82
84
|
console.log(`Removing ${file}`);
|
|
83
|
-
Object.keys(generatedFileContents).map((cachedFile) => {
|
|
85
|
+
Object.keys(exports.generatedFileContents).map((cachedFile) => {
|
|
84
86
|
if (cachedFile.indexOf(file) === 0) {
|
|
85
|
-
delete generatedFileContents[cachedFile];
|
|
87
|
+
delete exports.generatedFileContents[cachedFile];
|
|
86
88
|
}
|
|
87
89
|
});
|
|
88
90
|
return fs_extra_1.default.removeSync(file);
|
package/lib/builder/util/junk.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.not = exports.is = void 0;
|
|
3
|
+
exports.isFilePath = exports.not = exports.is = void 0;
|
|
4
4
|
const ignoreList = [
|
|
5
5
|
// # All
|
|
6
6
|
'^npm-debug\\.log$',
|
|
@@ -25,8 +25,14 @@ const ignoreList = [
|
|
|
25
25
|
'^readme.md$',
|
|
26
26
|
'^README.md$',
|
|
27
27
|
];
|
|
28
|
+
const filePathIgnoreList = [
|
|
29
|
+
'__MACOSX', // 路径有__MACOSX就过滤
|
|
30
|
+
];
|
|
28
31
|
const regex = new RegExp(ignoreList.join('|'));
|
|
32
|
+
const filePathRegex = new RegExp(filePathIgnoreList.join('|'));
|
|
29
33
|
const is = (filename) => regex.test(filename);
|
|
30
34
|
exports.is = is;
|
|
31
35
|
const not = (filename) => !(0, exports.is)(filename);
|
|
32
36
|
exports.not = not;
|
|
37
|
+
const isFilePath = (filename) => filePathRegex.test(filename);
|
|
38
|
+
exports.isFilePath = isFilePath;
|
package/lib/builder/util/net.js
CHANGED
|
@@ -34,6 +34,7 @@ const compressing_1 = __importDefault(require("compressing"));
|
|
|
34
34
|
const jszip_1 = __importDefault(require("jszip"));
|
|
35
35
|
const config_1 = require("../config");
|
|
36
36
|
const generateFiles_1 = require("../util/generateFiles");
|
|
37
|
+
const junk_1 = require("../util/junk");
|
|
37
38
|
async function downloadFile(url, filePath) {
|
|
38
39
|
await fs_extra_1.default.ensureDir(path.dirname(filePath));
|
|
39
40
|
const res = await axios_1.default.get(url, { responseType: 'stream' });
|
|
@@ -91,6 +92,9 @@ async function saveFiles(files, dstDir) {
|
|
|
91
92
|
try {
|
|
92
93
|
for (const fileName of Object.keys(files)) {
|
|
93
94
|
const dest = path.join(dstDir, fileName);
|
|
95
|
+
if ((0, junk_1.isFilePath)(dest)) {
|
|
96
|
+
continue;
|
|
97
|
+
}
|
|
94
98
|
if (files[fileName].dir) { // 如果该文件为目录需先创建文件夹
|
|
95
99
|
fs_extra_1.default.mkdirSync(dest, {
|
|
96
100
|
recursive: true
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@cloudbase/lowcode-builder",
|
|
3
|
-
"version": "1.1.5-alpha.
|
|
3
|
+
"version": "1.1.5-alpha.4",
|
|
4
4
|
"description": "云开发 Tencent CloudBase Framework Low Code Plugin,将低码配置生成完整项目并一键部署云开发资源。",
|
|
5
5
|
"author": "yhsunshining@gmail.com",
|
|
6
6
|
"homepage": "https://github.com/TencentCloudBase/cloudbase-framework#readme",
|
|
@@ -38,8 +38,8 @@
|
|
|
38
38
|
"url": "https://github.com/TencentCloudBase/cloudbase-framework/issues"
|
|
39
39
|
},
|
|
40
40
|
"dependencies": {
|
|
41
|
-
"@cloudbase/cals": "^0.
|
|
42
|
-
"@cloudbase/lowcode-generator": "
|
|
41
|
+
"@cloudbase/cals": "^0.5.0",
|
|
42
|
+
"@cloudbase/lowcode-generator": "1.1.2-alpha.1",
|
|
43
43
|
"axios": "^0.21.0",
|
|
44
44
|
"browserfs": "^1.4.3",
|
|
45
45
|
"browserify-zlib": "^0.2.0",
|
package/template/mp/app.js
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
import { app } from './app/weapps-api'
|
|
3
3
|
// 引入数据源管理器并进行初始化
|
|
4
4
|
import { setConfig, getAccessToken, EXTRA_API, createStateDataSourceVar, generateParamsParser } from './datasources/index'
|
|
5
|
-
import { redirectToLogin, findLoginPage, getAuthConfig } from './common/util'
|
|
5
|
+
import { redirectToLogin, findLoginPage, getAuthConfig, checkAnonymous } from './common/util'
|
|
6
6
|
|
|
7
7
|
// 防止报类型不匹配warning
|
|
8
8
|
const originWarn = console.warn;
|
|
@@ -37,7 +37,8 @@ setConfig({
|
|
|
37
37
|
}
|
|
38
38
|
|
|
39
39
|
// 后续做过滤处理
|
|
40
|
-
|
|
40
|
+
const endpointType = app?.__internal__?.getCloudSdkConfig('endpointType');
|
|
41
|
+
if ((params?.data?.mode === 'c' && skip) || (endpointType !== 'tcb-api' && !loginPage)) {
|
|
41
42
|
return params;
|
|
42
43
|
}
|
|
43
44
|
// await initTcb();
|
|
@@ -68,11 +69,7 @@ setConfig({
|
|
|
68
69
|
const loginPage = findLoginPage();
|
|
69
70
|
if (loginPage) {
|
|
70
71
|
const authConfig = await getAuthConfig();
|
|
71
|
-
|
|
72
|
-
try {
|
|
73
|
-
const { accessToken } = await getAccessToken();
|
|
74
|
-
isAnonymous = !accessToken;
|
|
75
|
-
} catch (e) { }
|
|
72
|
+
const isAnonymous = await checkAnonymous();
|
|
76
73
|
if (isAnonymous && authConfig.RejectStrategy == 'to_login') {
|
|
77
74
|
redirectToLogin();
|
|
78
75
|
} else if (authConfig.RejectStrategy == 'show_warning') {
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
import { findForItemsOfWidget, getWidget } from './widget'
|
|
3
|
-
import { observable } from 'mobx';
|
|
4
|
-
import { getAccessToken } from '../datasources/index'
|
|
3
|
+
import { observable, untracked } from 'mobx';
|
|
4
|
+
import { getAccessToken, loginScope } from '../datasources/index'
|
|
5
5
|
import { app } from '../app/weapps-api'
|
|
6
6
|
|
|
7
7
|
/**
|
|
@@ -31,9 +31,13 @@ export function createComputed(funcs, bindContext = null) {
|
|
|
31
31
|
export function generateDataContext(widget) {
|
|
32
32
|
const dataContext = {};
|
|
33
33
|
while (widget?._scope) {
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
34
|
+
const current = widget
|
|
35
|
+
// 此处采用代理的方式,是为了可以获取到最新的 _scope.dataContext 防止 dataContext 引用被重新赋值
|
|
36
|
+
Object.defineProperty(dataContext, current._scope.id, {
|
|
37
|
+
get() {
|
|
38
|
+
return current._scope.dataContext;
|
|
39
|
+
},
|
|
40
|
+
});
|
|
37
41
|
widget = widget.parent;
|
|
38
42
|
}
|
|
39
43
|
return dataContext;
|
|
@@ -57,7 +61,7 @@ export function createEventHandlers(evtListeners) {
|
|
|
57
61
|
const [prefix = ''] = name.split('$');
|
|
58
62
|
// The page event handler
|
|
59
63
|
const { lists = [], itemsById = {} } = !!currentTarget && findForItemsOfWidget(currentTarget) || {}
|
|
60
|
-
const dataContext = generateDataContext(currentTarget)
|
|
64
|
+
const dataContext = untracked(() => generateDataContext(currentTarget))
|
|
61
65
|
|
|
62
66
|
listeners.forEach(async l => {
|
|
63
67
|
let { data = {}, boundData = {} } = l;
|
|
@@ -306,6 +310,21 @@ async function getAccessPermission(app, appId, pageId) {
|
|
|
306
310
|
return isAccess
|
|
307
311
|
}
|
|
308
312
|
|
|
313
|
+
export async function checkAnonymous() {
|
|
314
|
+
let isAnonymous = true;
|
|
315
|
+
try {
|
|
316
|
+
const { accessToken } = await getAccessToken();
|
|
317
|
+
isAnonymous = !accessToken;
|
|
318
|
+
const { app } = getApp();
|
|
319
|
+
// 私密链路有token则不是匿名; tcb链路会匿名登录需要多验证scope === 'anonymous'
|
|
320
|
+
if (accessToken && app.__internal__.getCloudSdkConfig('endpointType') === 'tcb-api') {
|
|
321
|
+
const scope = await loginScope();
|
|
322
|
+
isAnonymous = scope === 'anonymous';
|
|
323
|
+
}
|
|
324
|
+
} catch (e) { }
|
|
325
|
+
return isAnonymous;
|
|
326
|
+
}
|
|
327
|
+
|
|
309
328
|
/**
|
|
310
329
|
* 检查页面权限
|
|
311
330
|
**/
|
|
@@ -323,11 +342,7 @@ export async function checkAuth(app, appId, $page) {
|
|
|
323
342
|
const [isAccess, authConfig] = await Promise.all(requestList);
|
|
324
343
|
app.hideNavigationBarLoading();
|
|
325
344
|
|
|
326
|
-
|
|
327
|
-
try {
|
|
328
|
-
const { accessToken } = await getAccessToken();
|
|
329
|
-
isAnonymousUser = !accessToken;
|
|
330
|
-
} catch (e) { }
|
|
345
|
+
const isAnonymousUser = await checkAnonymous();
|
|
331
346
|
|
|
332
347
|
if (!isAccess) {
|
|
333
348
|
if (isAnonymousUser && loginPage && (authConfig.NeedLogin || authConfig.RejectStrategy == 'to_login')) {
|
|
@@ -221,7 +221,7 @@ function runFor(
|
|
|
221
221
|
clearTimeout(_FOR_ERROR_CACHE_MAP[nodeId]);
|
|
222
222
|
|
|
223
223
|
const $instance = ownerMpInst.getWeAppInst();
|
|
224
|
-
const dataContext = generateDataContext(defaultParent);
|
|
224
|
+
const dataContext = untracked(()=>generateDataContext(defaultParent));
|
|
225
225
|
|
|
226
226
|
forList = dataBinds[nodeId]._waFor.call(
|
|
227
227
|
$instance,
|
|
@@ -364,7 +364,7 @@ function setUpWidgetDataBinds(w, dataBinds, forItems, failedBinds, ctx) {
|
|
|
364
364
|
try {
|
|
365
365
|
clearTimeout(timer);
|
|
366
366
|
|
|
367
|
-
const dataContext = generateDataContext(w);
|
|
367
|
+
const dataContext = untracked(()=>generateDataContext(w));
|
|
368
368
|
|
|
369
369
|
// Computed data bind in the next tick since data bind may read widgets data
|
|
370
370
|
const value = dataBinds[prop].call(ctx, ctx, forItems.lists, forItems.itemsById, undefined, dataContext);
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { _WEDA_CLOUD_SDK as WEDA_CLOUD_SDK, auth} from '@cloudbase/weda-client'
|
|
1
|
+
import { _WEDA_CLOUD_SDK as WEDA_CLOUD_SDK, auth } from '@cloudbase/weda-client'
|
|
2
2
|
const {
|
|
3
3
|
setConfig,
|
|
4
4
|
initTcb,
|
|
@@ -10,6 +10,7 @@ const {
|
|
|
10
10
|
DS_SDK,
|
|
11
11
|
} = WEDA_CLOUD_SDK
|
|
12
12
|
const getAccessToken = auth.getAccessToken
|
|
13
|
+
const loginScope = auth.loginScope
|
|
13
14
|
|
|
14
15
|
export {
|
|
15
16
|
createDataset,
|
|
@@ -20,6 +21,7 @@ export {
|
|
|
20
21
|
DS_SDK,
|
|
21
22
|
setConfig,
|
|
22
23
|
getAccessToken,
|
|
24
|
+
loginScope,
|
|
23
25
|
initTcb,
|
|
24
26
|
}
|
|
25
27
|
|
package/template/mp/package.json
CHANGED
|
@@ -3,10 +3,10 @@
|
|
|
3
3
|
"version": "1.0.8",
|
|
4
4
|
"scripts": {},
|
|
5
5
|
"dependencies": {<% if(isPrivateMode) {%>
|
|
6
|
-
"@cloudbase/js-sdk": "2.5.
|
|
6
|
+
"@cloudbase/js-sdk": "2.5.6-beta.1",<% } %>
|
|
7
7
|
"@cloudbase/oauth": "0.1.1-alpha.5",
|
|
8
|
-
"@cloudbase/weda-client": "0.2.
|
|
9
|
-
"@cloudbase/weda-cloud-sdk": "1.0.24-alpha.
|
|
8
|
+
"@cloudbase/weda-client": "0.2.36",
|
|
9
|
+
"@cloudbase/weda-cloud-sdk": "1.0.24-alpha.3",
|
|
10
10
|
"mobx": "^5.15.4",
|
|
11
11
|
"lodash.get": "^4.4.2",
|
|
12
12
|
"lodash.set": "^4.3.2",
|