@steedos-widgets/amis-lib 1.2.0-beta.1 → 1.2.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.
package/dist/index.esm.js CHANGED
@@ -334,7 +334,7 @@ const getSteedosAuth = () => {
334
334
  * @Author: baozhoutao@steedos.com
335
335
  * @Date: 2022-08-16 17:02:08
336
336
  * @LastEditors: baozhoutao@steedos.com
337
- * @LastEditTime: 2023-03-03 14:52:18
337
+ * @LastEditTime: 2023-04-11 09:57:37
338
338
  * @Description:
339
339
  */
340
340
 
@@ -361,10 +361,11 @@ const Router = {
361
361
  },
362
362
  getObjectDetailPath(props){
363
363
  const {formFactor, appId, objectName, recordId, listViewName, _templateType} = props;
364
+ // var urlParams = new URLSearchParams(window.location.search);
364
365
  // if(objectName === 'instances'){
365
366
  // return `/workflow/space/\${context.tenantId}/\${listName}/${recordId}`;
366
367
  // }
367
- const displayAs = Router.getTabDisplayAs(objectName);
368
+ const displayAs = Router.getTabDisplayAs(objectName); //urlParams.get("display") ||
368
369
  if(_templateType === 'JavaScript'){
369
370
  return `/app/${appId}/${objectName}/view/${recordId}?display=${displayAs}&side_object=<%=item.objectName%>&side_listview_id=<%=item.listName%>`;
370
371
  }
@@ -380,7 +381,7 @@ const Router = {
380
381
  * @Author: baozhoutao@steedos.com
381
382
  * @Date: 2022-05-23 09:53:08
382
383
  * @LastEditors: baozhoutao@steedos.com
383
- * @LastEditTime: 2023-03-09 10:00:44
384
+ * @LastEditTime: 2023-04-10 11:22:54
384
385
  * @Description:
385
386
  */
386
387
 
@@ -575,6 +576,7 @@ async function getFieldTpl (field, options){
575
576
  case 'number':
576
577
  case 'currency':
577
578
  return await getNumberTpl(field);
579
+ case 'percent':
578
580
  case 'formula':
579
581
  case 'summary':
580
582
  return getUiFieldTpl(field)
@@ -607,7 +609,7 @@ async function getFieldsTemplate(fields, expand){
607
609
  if(includes(['time','date','datetime','boolean','number','currency'], field.type)){
608
610
  fieldsName.push(`${field.name}`);
609
611
  }
610
- if(includes(['time','filesize','date','datetime','boolean','number','currency', 'select', 'file', 'image', 'avatar', 'formula', 'summary', 'object', 'grid'], field.type)){
612
+ if(includes(['percent','time','filesize','date','datetime','boolean','number','currency', 'select', 'file', 'image', 'avatar', 'formula', 'summary', 'object', 'grid'], field.type)){
611
613
  displayFields.push(`${field.name}`);
612
614
  }
613
615
  }
@@ -1362,7 +1364,7 @@ var config = {
1362
1364
  * @Author: baozhoutao@steedos.com
1363
1365
  * @Date: 2022-11-01 15:51:00
1364
1366
  * @LastEditors: Please set LastEditors
1365
- * @LastEditTime: 2023-04-08 12:05:19
1367
+ * @LastEditTime: 2023-04-11 13:58:24
1366
1368
  * @Description:
1367
1369
  */
1368
1370
 
@@ -1386,16 +1388,20 @@ const getSchema$4 = async (uiSchema, ctx) => {
1386
1388
  const relatedKey = _master.relatedKey;
1387
1389
  const masterObjectName = _master.objectName;
1388
1390
  const recordId = _master.recordId;
1391
+ let relatedKeySaveValue = recordId;
1389
1392
  const fields = ${JSON.stringify(uiSchema.fields)};
1390
1393
  const relatedField = fields[relatedKey];
1394
+ if(relatedField.reference_to_field && relatedField.reference_to_field !== '_id'){
1395
+ relatedKeySaveValue = _master.record[relatedField.reference_to_field];
1396
+ }
1391
1397
  let defaultData = {};
1392
1398
  let relatedKeyValue;
1393
1399
  if(!_.isString(relatedField.reference_to)){
1394
- relatedKeyValue = { o: masterObjectName, ids: [recordId] };
1400
+ relatedKeyValue = { o: masterObjectName, ids: [relatedKeySaveValue] };
1395
1401
  }else if (relatedField.multiple) {
1396
- relatedKeyValue = [recordId];
1402
+ relatedKeyValue = [relatedKeySaveValue];
1397
1403
  } else {
1398
- relatedKeyValue = recordId;
1404
+ relatedKeyValue = relatedKeySaveValue;
1399
1405
  }
1400
1406
  defaultData[relatedKey]=relatedKeyValue;
1401
1407
  if(payload.schema){
@@ -1431,7 +1437,6 @@ const getSchema$4 = async (uiSchema, ctx) => {
1431
1437
  "_master": "${_master}",
1432
1438
  "_master._isRelated": "${_isRelated}",
1433
1439
  "_master.relatedKey": "${relatedKey}",
1434
- "defaultData": "${defaultData}",
1435
1440
  "appId": "${appId}",
1436
1441
  "objectName": "${objectName}",
1437
1442
  "context": "${context}",
@@ -1488,7 +1493,7 @@ const getSchema$4 = async (uiSchema, ctx) => {
1488
1493
  * @Author: baozhoutao@steedos.com
1489
1494
  * @Date: 2022-07-13 15:18:03
1490
1495
  * @LastEditors: baozhoutao@steedos.com
1491
- * @LastEditTime: 2022-11-08 09:35:03
1496
+ * @LastEditTime: 2023-04-11 10:34:26
1492
1497
  * @Description:
1493
1498
  */
1494
1499
 
@@ -1496,6 +1501,13 @@ async function getPage({type, pageId = '', appId, objectName = '', recordId = ''
1496
1501
  const api = `/api/pageSchema/${type}?app=${appId}&objectApiName=${objectName}&recordId=${recordId}&pageId=${pageId}&formFactor=${formFactor}`;
1497
1502
  const page = await fetchAPI(api);
1498
1503
  if (page && page.schema) {
1504
+ page.schema = JSON.parse(page.schema);
1505
+ if(page.schema.data){
1506
+ delete page.schema.data.recordId;
1507
+ delete page.schema.data.objectName;
1508
+ delete page.schema.data.context;
1509
+ delete page.schema.data.global;
1510
+ }
1499
1511
  return page;
1500
1512
  }
1501
1513
  }
@@ -7476,8 +7488,8 @@ const getRecordPermissions = async (objectName, recordId)=>{
7476
7488
  /*
7477
7489
  * @Author: baozhoutao@steedos.com
7478
7490
  * @Date: 2022-07-05 15:55:39
7479
- * @LastEditors: 殷亮辉 yinlianghui@hotoa.com
7480
- * @LastEditTime: 2023-04-08 18:14:55
7491
+ * @LastEditors: Please set LastEditors
7492
+ * @LastEditTime: 2023-04-11 13:13:00
7481
7493
  * @Description:
7482
7494
  */
7483
7495
 
@@ -7599,8 +7611,6 @@ async function getRecordDetailRelatedListSchema(objectName, recordId, relatedObj
7599
7611
  }
7600
7612
  }
7601
7613
  }
7602
-
7603
- let relatedValue = "${recordId}";
7604
7614
  // if(refField.reference_to_field && refField.reference_to_field != '_id'){
7605
7615
  // const masterRecord = await getRecord(objectName, recordId, [refField.reference_to_field]);
7606
7616
  // relatedValue = masterRecord[refField.reference_to_field]
@@ -7662,14 +7672,7 @@ async function getRecordDetailRelatedListSchema(objectName, recordId, relatedObj
7662
7672
  _isRelated: true
7663
7673
  },
7664
7674
  body:[
7665
- {
7666
- ...amisSchema,
7667
- data: {
7668
- defaultData: {
7669
- ...{[relatedKey]: getRelatedFieldValue(objectName, relatedValue, relatedObjectUiSchema, relatedKey)}
7670
- }
7671
- }
7672
- }
7675
+ amisSchema
7673
7676
  ]
7674
7677
  }
7675
7678
  };
@@ -7822,7 +7825,7 @@ async function getRelatedListSchema(
7822
7825
  * @Author: baozhoutao@steedos.com
7823
7826
  * @Date: 2022-07-05 15:55:39
7824
7827
  * @LastEditors: 殷亮辉 yinlianghui@hotoa.com
7825
- * @LastEditTime: 2023-04-08 17:31:57
7828
+ * @LastEditTime: 2023-04-11 11:28:11
7826
7829
  * @Description:
7827
7830
  */
7828
7831
 
@@ -8271,35 +8274,19 @@ async function getRecordDetailSchema(objectName, appId, props = {}){
8271
8274
  amisSchema: {
8272
8275
  "type": "service",
8273
8276
  "body": [
8274
- {
8275
- "type": "steedos-record-detail-header",
8276
- "label": "标题面板",
8277
- "objectApiName": "${objectName}",
8278
- "recordId": "${recordId}",
8279
- "id": "u:48d2c28eb755",
8280
- onEvent: {
8281
- "recordLoaded": {
8282
- "actions": [
8283
- {
8284
- "actionType": "reload",
8285
- "data": {
8286
- "name": `\${event.data.record.${uiSchema?.NAME_FIELD_KEY || 'name'}}`,
8287
- "record": `\${event.data.record}`,
8288
- "_id": "\${event.data.record._id}",
8289
- "recordId": "\${event.data.record._id}",
8290
- "recordLoaded": true,
8291
- }
8292
- }
8293
- ]
8294
- }
8277
+ {
8278
+ "type": "steedos-record-detail-header",
8279
+ "label": "标题面板",
8280
+ "objectApiName": "${objectName}",
8281
+ "recordId": "${recordId}",
8282
+ "id": "u:48d2c28eb755"
8295
8283
  },
8296
- },
8297
- content
8284
+ content
8298
8285
  ],
8299
- // data: {
8300
- // "_master.objectName": "${objectName}",
8301
- // "_master.recordId": "${recordId}"
8302
- // },
8286
+ data: {
8287
+ "_master.objectName": "${objectName}",
8288
+ "_master.recordId": "${recordId}"
8289
+ },
8303
8290
  onEvent: {
8304
8291
  "recordLoaded": {
8305
8292
  "actions": [
@@ -8307,10 +8294,10 @@ async function getRecordDetailSchema(objectName, appId, props = {}){
8307
8294
  "actionType": "reload",
8308
8295
  "data": {
8309
8296
  "name": `\${record.${uiSchema.NAME_FIELD_KEY || 'name'}}`,
8310
- // "_master.record": `\${record}`,
8311
- // // 不清楚reload 如何给对象下的某个key复制, 所以此处重复设置_master的objectName、recordId
8312
- // "_master.objectName": "${objectName}",
8313
- // "_master.recordId": "${recordId}"
8297
+ "_master.record": `\${record}`,
8298
+ // 不清楚reload 如何给对象下的某个key复制, 所以此处重复设置_master的objectName、recordId
8299
+ "_master.objectName": "${objectName}",
8300
+ "_master.recordId": "${recordId}"
8314
8301
  }
8315
8302
  }
8316
8303
  ]