crabatool 1.0.390 → 1.0.392
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/apis/homeai.js +65 -3
- package/package.json +1 -1
- package/tool/install.js +6 -0
package/apis/homeai.js
CHANGED
|
@@ -20,6 +20,7 @@ var funcList = {
|
|
|
20
20
|
'修改菜单': '_modifyMenuItem',
|
|
21
21
|
'表生页': '_doExcel',
|
|
22
22
|
'文生页': '_createPage',
|
|
23
|
+
'AI报表': '_createPage',
|
|
23
24
|
'新建页面': '_createPage',
|
|
24
25
|
'新建弹窗': '_createPage',
|
|
25
26
|
'修改页面': '_createPage'
|
|
@@ -30,6 +31,7 @@ class homeai {
|
|
|
30
31
|
return path.join(req.app.webPath, 'data/menus.json');
|
|
31
32
|
}
|
|
32
33
|
|
|
34
|
+
|
|
33
35
|
async execute(req, res) {
|
|
34
36
|
var body = utils.getReqBody(req);
|
|
35
37
|
var text = body.text;
|
|
@@ -306,7 +308,7 @@ class homeai {
|
|
|
306
308
|
this._buildPage(data, req);
|
|
307
309
|
|
|
308
310
|
// 输出
|
|
309
|
-
utils.end(res, {
|
|
311
|
+
res && utils.end(res, {
|
|
310
312
|
code: 200,
|
|
311
313
|
msg: '操作成功',
|
|
312
314
|
type: 'menu',
|
|
@@ -337,15 +339,22 @@ class homeai {
|
|
|
337
339
|
}
|
|
338
340
|
|
|
339
341
|
var type = '';
|
|
342
|
+
var method = 'expressToPage';
|
|
343
|
+
var cb = this.createPageSuccess;
|
|
340
344
|
if (name == '文生页') {
|
|
341
345
|
type = 'list'; // 基础资料,列表页面
|
|
346
|
+
} else if (name == 'AI报表') {
|
|
347
|
+
method = 'expressToReport'
|
|
348
|
+
cb = this.createReportSuccess;
|
|
349
|
+
type = "report";
|
|
350
|
+
name = '文生页';
|
|
342
351
|
}
|
|
343
352
|
|
|
344
353
|
var that = this;
|
|
345
354
|
var pageName = crabatool.stringUtils.getPinyinCode(itemName) + crabatool.cuid.newCuid(); // 防止同名菜单重复页面
|
|
346
|
-
this._postAI(
|
|
355
|
+
this._postAI(method, { express: express, name: itemName, enname: pageName, type: type }, function(resdata, error) {
|
|
347
356
|
if (resdata !== false && resdata.code == 200) {
|
|
348
|
-
|
|
357
|
+
cb.apply(that, [name, itemName, resdata, req, res])
|
|
349
358
|
} else {
|
|
350
359
|
utils.end(res, {
|
|
351
360
|
code: 500,
|
|
@@ -355,6 +364,59 @@ class homeai {
|
|
|
355
364
|
});
|
|
356
365
|
}
|
|
357
366
|
|
|
367
|
+
createPageSuccess(name, itemName, resdata, req, res) {
|
|
368
|
+
this._savePage(name, itemName, resdata.data, req, res);
|
|
369
|
+
}
|
|
370
|
+
|
|
371
|
+
|
|
372
|
+
getReportProgress(obj, count) {
|
|
373
|
+
count = count ? count : 1;
|
|
374
|
+
if (count > 1000) {
|
|
375
|
+
return;
|
|
376
|
+
}
|
|
377
|
+
var _this = this;
|
|
378
|
+
this._postAI('getReportProgress', { id: obj.id }, function(resdata, error) {
|
|
379
|
+
if (resdata !== false && resdata.data && resdata.data.status == 'fail') {
|
|
380
|
+
//明确失败了
|
|
381
|
+
return;
|
|
382
|
+
}
|
|
383
|
+
if (resdata !== false && resdata.code == 200) {
|
|
384
|
+
//成功后更新文件
|
|
385
|
+
_this._savePage(obj.name, obj.itemName, resdata.data, {
|
|
386
|
+
app: {
|
|
387
|
+
webPath: obj.webPath
|
|
388
|
+
}
|
|
389
|
+
});
|
|
390
|
+
} else {
|
|
391
|
+
//文件还没生成,继续请求
|
|
392
|
+
setTimeout(function() {
|
|
393
|
+
_this.getReportProgress(obj, count + 1);
|
|
394
|
+
}, 2000);
|
|
395
|
+
}
|
|
396
|
+
})
|
|
397
|
+
}
|
|
398
|
+
|
|
399
|
+
createReportSuccess(name, itemName, resdata, req, res) {
|
|
400
|
+
if (resdata.data.id) {
|
|
401
|
+
//存在id,说明生成的是临时页面,真正页面还没完全生成,需要循环去获取
|
|
402
|
+
this._savePage(name, itemName, resdata.data, req, res);
|
|
403
|
+
this.getReportProgress({
|
|
404
|
+
id: resdata.data.id,
|
|
405
|
+
name: name,
|
|
406
|
+
itemName: itemName,
|
|
407
|
+
webPath: req.app.webPath
|
|
408
|
+
})
|
|
409
|
+
} else {
|
|
410
|
+
utils.mkdirsSync(utils.join(req.app.webPath, "../ai/jsCode/"), true)
|
|
411
|
+
var filePath = utils.join(req.app.webPath, `../ai/jsCode/${resdata.data.enname}.text`)
|
|
412
|
+
fs.writeFileSync(filePath, resdata.data.jsCode);
|
|
413
|
+
utils.mkdirsSync(utils.join(req.app.webPath, "../ai/reportConfig/"), true)
|
|
414
|
+
filePath = utils.join(req.app.webPath, `../ai/reportConfig/${resdata.data.enname}.text`)
|
|
415
|
+
fs.writeFileSync(filePath, resdata.data.reportConfig);
|
|
416
|
+
this._savePage(name, itemName, resdata.data, req, res);
|
|
417
|
+
}
|
|
418
|
+
}
|
|
419
|
+
|
|
358
420
|
_buildChildPage(pdata, req) {
|
|
359
421
|
var datas = pdata.childInfos;
|
|
360
422
|
if (!datas || datas.length == 0) {
|
package/package.json
CHANGED
package/tool/install.js
CHANGED