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 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('expressToPage', { express: express, name: itemName, enname: pageName, type: type }, function(resdata, error) {
355
+ this._postAI(method, { express: express, name: itemName, enname: pageName, type: type }, function(resdata, error) {
347
356
  if (resdata !== false && resdata.code == 200) {
348
- that._savePage(name, itemName, resdata.data, req, res);
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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "crabatool",
3
- "version": "1.0.390",
3
+ "version": "1.0.392",
4
4
  "description": "crabatool",
5
5
  "main": "index.js",
6
6
  "bin": {
package/tool/install.js CHANGED
@@ -24,6 +24,12 @@ class Install {
24
24
  this.doIDEA(path.join(JetBrains, folderName));
25
25
  return;
26
26
  }
27
+
28
+ var folderName = utils.searchFolder("Idea", JetBrains);
29
+ if (folderName != "") {
30
+ this.doIDEA(path.join(JetBrains, folderName));
31
+ return;
32
+ }
27
33
  }
28
34
 
29
35