@steedos-widgets/sortable 1.3.14 → 1.3.16

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.
@@ -21247,6 +21247,17 @@
21247
21247
  crudService && crudService.setData({isFieldsFilterEmpty, showFieldsFilter});
21248
21248
  `;
21249
21249
  const onCancelScript = `
21250
+ doAction(
21251
+ {
21252
+ "componentId": 'service_${ctx.crudId}',
21253
+ "actionType": "setValue",
21254
+ "args": {
21255
+ "value": {
21256
+ "__filterFormValues": null
21257
+ }
21258
+ }
21259
+ }
21260
+ )
21250
21261
  const scope = event.context.scoped;
21251
21262
  var filterForm = scope.parent.parent.getComponents().find(function(n){
21252
21263
  return n.props.type === "form";
@@ -21281,7 +21292,9 @@
21281
21292
  removedValues[keywordsSearchBoxName] = filterFormValues[keywordsSearchBoxName];
21282
21293
  }
21283
21294
  filterForm.reset();
21284
- listView.handleFilterSubmit(removedValues);
21295
+ setTimeout(()=>{
21296
+ listView.handleFilterSubmit(removedValues);
21297
+ }, 100);
21285
21298
  const filterService = filterForm.context.getComponents().find(function(n){
21286
21299
  return n.props.type === "service";
21287
21300
  });
@@ -22697,7 +22710,7 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
22697
22710
  // }
22698
22711
  `;
22699
22712
 
22700
- function getObjectHeaderQuickSearchBox(mainObject, fields, formFactor, { isLookup = false, keywordsSearchBoxName = "__keywords" } = {}){
22713
+ function getObjectHeaderQuickSearchBox(mainObject, fields, formFactor, { isLookup = false, keywordsSearchBoxName = "__keywords", crudId } = {}){
22701
22714
  const searchableFieldsLabel = [];
22702
22715
  _.each(mainObject.fields, function (field) {
22703
22716
  if (isFieldQuickSearchable(field, mainObject.NAME_FIELD_KEY)) {
@@ -22734,23 +22747,22 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
22734
22747
  "clearAndSubmit": true,
22735
22748
  "searchImediately": false,
22736
22749
  "onEvent": {
22737
- "blur": {
22750
+ "change": {
22738
22751
  "actions": [
22739
22752
  {
22740
22753
  "actionType": "custom",
22741
22754
  "script": `
22742
- try {
22743
- const scope = event.context.scoped;
22744
- const filterCrud = scope.parent.getComponents().find(function(n) {
22745
- return n.props.type === "crud";
22746
- });
22747
- if (filterCrud && typeof filterCrud.reload === 'function') {
22748
- const keyWords = { '${keywordsSearchBoxName}': event.data.value };
22749
- filterCrud.reload(null, keyWords);
22755
+ doAction(
22756
+ {
22757
+ "componentId": 'service_${crudId}',
22758
+ "actionType": "setValue",
22759
+ "args": {
22760
+ "value": {
22761
+ "__serachBoxValues": event.data
22762
+ }
22750
22763
  }
22751
- } catch (error) {
22752
- console.error('An error occurred:', error);
22753
- }
22764
+ }
22765
+ )
22754
22766
  `
22755
22767
  }
22756
22768
  ]
@@ -22762,7 +22774,7 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
22762
22774
  }
22763
22775
 
22764
22776
  function getObjectHeaderToolbar(mainObject, fields, formFactor, {
22765
- showDisplayAs = false, hiddenCount = false, headerToolbarItems,
22777
+ showDisplayAs = false, hiddenCount = false, headerToolbarItems, crudId,
22766
22778
  filterVisible = true, isLookup = false, keywordsSearchBoxName } = {}){
22767
22779
  // console.log(`getObjectHeaderToolbar====>`, filterVisible)
22768
22780
  // console.log(`getObjectHeaderToolbar`, mainObject)
@@ -22866,7 +22878,7 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
22866
22878
  };
22867
22879
  }
22868
22880
  let toolbarDisplayAsButton = getDisplayAsButton(mainObject?.name);
22869
- let toolbarDQuickSearchBox = getObjectHeaderQuickSearchBox(mainObject, fields, formFactor, { isLookup, keywordsSearchBoxName });
22881
+ let toolbarDQuickSearchBox = getObjectHeaderQuickSearchBox(mainObject, fields, formFactor, { isLookup, keywordsSearchBoxName, crudId });
22870
22882
 
22871
22883
  // toolbars返回的数组元素不可以是空对象{},比如hiddenCount ? {} : {"type": "tpl",...},因为空对象最终还是会生成一个空的.antd-Crud-toolbar-item dom
22872
22884
  // 当出现空的.antd-Crud-toolbar-item dom时会影响toolbar元素的maring-right css样式计算,如果有动态需要应该加到动态数组变量toolbars中
@@ -23032,6 +23044,26 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
23032
23044
  "script": onSubmitSuccScript
23033
23045
  }
23034
23046
  ]
23047
+ },
23048
+ "change": {
23049
+ "actions": [
23050
+ {
23051
+ "actionType": "custom",
23052
+ "script": `
23053
+ doAction(
23054
+ {
23055
+ "componentId": 'service_${options.crudId}',
23056
+ "actionType": "setValue",
23057
+ "args": {
23058
+ "value": {
23059
+ "__filterFormValues": event.data
23060
+ }
23061
+ }
23062
+ }
23063
+ )
23064
+ `
23065
+ }
23066
+ ]
23035
23067
  }
23036
23068
  }
23037
23069
  }
@@ -23235,19 +23267,12 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
23235
23267
 
23236
23268
  const keywordsSearchBoxName = `__keywords_lookup`;
23237
23269
 
23238
- const getReferenceTo = async (field)=>{
23270
+ const getReferenceToFieldSchema = (field, refObjectConfig)=>{
23239
23271
  let referenceTo = field.reference_to;
23240
23272
  if(!referenceTo){
23241
- return ;
23242
- }
23243
-
23244
- if(referenceTo === 'users'){
23245
- referenceTo = 'space_users';
23246
- field.reference_to_field = 'user';
23273
+ return;
23247
23274
  }
23248
23275
 
23249
- const refObjectConfig = await getUISchema(referenceTo);
23250
-
23251
23276
  // 如果lookup 引用的对象未定义
23252
23277
  if (!refObjectConfig)
23253
23278
  return null;
@@ -23270,6 +23295,28 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
23270
23295
  }
23271
23296
  };
23272
23297
 
23298
+ const getReferenceTo = async (field)=>{
23299
+ let referenceTo = field.reference_to;
23300
+ if(referenceTo === 'users'){
23301
+ field.reference_to = 'space_users';
23302
+ field.reference_to_field = 'user';
23303
+ }
23304
+
23305
+ const refObjectConfig = await getUISchema(field.reference_to);
23306
+ return getReferenceToFieldSchema(field, refObjectConfig);
23307
+ };
23308
+
23309
+ function getReferenceToSync(field) {
23310
+ let referenceTo = field.reference_to;
23311
+ if(referenceTo === 'users'){
23312
+ field.reference_to = 'space_users';
23313
+ field.reference_to_field = 'user';
23314
+ }
23315
+
23316
+ const refObjectConfig = getUISchemaSync(field.reference_to);
23317
+ return getReferenceToFieldSchema(field, refObjectConfig);
23318
+ }
23319
+
23273
23320
  function getLookupSapceUserTreeSchema(isMobile){
23274
23321
  const treeSchema = {
23275
23322
  "type": "input-tree",
@@ -23863,7 +23910,7 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
23863
23910
  // [["_id", "=", "$${field.name}._id"],"or",["name", "contains", "$term"]]
23864
23911
  apiInfo.requestAdaptor = `
23865
23912
  var filters = [];
23866
- var top = 10;
23913
+ var top = 200;
23867
23914
  if(api.data.$term){
23868
23915
  filters = [["${referenceTo?.NAME_FIELD_KEY || 'name'}", "contains", api.data.$term]];
23869
23916
  }
@@ -24169,6 +24216,12 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
24169
24216
  return data;
24170
24217
  }
24171
24218
 
24219
+
24220
+ if(typeof window != 'undefined'){
24221
+ window.getReferenceTo = getReferenceTo;
24222
+ window.getReferenceToSync = getReferenceToSync;
24223
+ }
24224
+
24172
24225
  /*
24173
24226
  * @Author: baozhoutao@steedos.com
24174
24227
  * @Date: 2023-01-13 17:27:54
@@ -24346,8 +24399,8 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
24346
24399
  /*
24347
24400
  * @Author: baozhoutao@steedos.com
24348
24401
  * @Date: 2022-10-28 14:15:09
24349
- * @LastEditors: 孙浩林 sunhaolin@steedos.com
24350
- * @LastEditTime: 2023-11-24 13:45:24
24402
+ * @LastEditors: liaodaxue
24403
+ * @LastEditTime: 2023-10-30 17:51:54
24351
24404
  * @Description:
24352
24405
  */
24353
24406
 
@@ -24384,7 +24437,7 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
24384
24437
  <% let fileData = data._display.${steedosField.name}; if (fileData) { %>
24385
24438
  <% if(!Array.isArray(fileData)){ fileData = [fileData]} %>
24386
24439
  <% fileData.forEach(function(item) { %>
24387
- <a href='<%= item.url+"?download=1" %>' target='_self' class='block'><%= item.name %></a>
24440
+ <a href='<%= item.url %>' target='_self' class='block'><%= item.name %></a>
24388
24441
  <% });} %>`
24389
24442
  }
24390
24443
  }
@@ -24958,6 +25011,29 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
24958
25011
  }
24959
25012
  }
24960
25013
  break;
25014
+ case 'table':
25015
+ if(field.subFields){
25016
+ convertData = {
25017
+ type: 'steedos-input-table',
25018
+ showIndex: true,
25019
+ editable: !readonly,
25020
+ addable: !readonly,
25021
+ removable: !readonly,
25022
+ draggable: !readonly,
25023
+ fields: [],
25024
+ amis:{
25025
+ columnsTogglable: false
25026
+ }
25027
+ };
25028
+ for (const subField of field.subFields) {
25029
+ const subFieldName = subField.name.replace(`${field._prefix || ''}${field.name}.$.`, '').replace(`${field.name}.`, '');
25030
+ const gridSub = await convertSFieldToAmisField(Object.assign({}, subField, {name: subFieldName, isTableField: true}), readonly, ctx);
25031
+ if(gridSub){
25032
+ convertData.fields.push(Object.assign({}, subField, {name: subFieldName}));
25033
+ }
25034
+ }
25035
+ }
25036
+ break;
24961
25037
  case 'object':
24962
25038
  if(field.subFields){
24963
25039
  convertData = {
@@ -25029,7 +25105,9 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
25029
25105
  return convertData
25030
25106
  }
25031
25107
  // if(ctx.mode === 'edit'){
25032
- return Object.assign({}, baseData, convertData, { labelClassName: 'text-left', clearValueOnHidden: true, fieldName: field.name}, field.amis, {name: baseData.name});
25108
+ let convertDataResult = Object.assign({}, baseData, convertData, { labelClassName: 'text-left', clearValueOnHidden: true, fieldName: field.name}, field.amis, {name: baseData.name});
25109
+ // console.log("convertDataResult:", convertDataResult);
25110
+ return convertDataResult;
25033
25111
  // }else{
25034
25112
  // return Object.assign({}, baseData, convertData, { labelClassName: 'text-left', clearValueOnHidden: true, fieldName: field.name});
25035
25113
  // }
@@ -25121,38 +25199,9 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
25121
25199
 
25122
25200
  const amisField = await convertSFieldToAmisField(_field, false, Object.assign({}, ctx, {fieldNamePrefix: fieldNamePrefix, required: false, showSystemFields: true, inFilterForm: true}));
25123
25201
  if(amisField){
25124
- const changeActionsFields = ['select', 'boolean', 'toggle', 'date', 'datetime', 'time', 'number', 'currency', 'lookup', 'master_detail'];
25125
- const isChangeActions = changeActionsFields.indexOf(field.type) > -1;
25126
- let additionalProps = {
25202
+ return Object.assign({}, amisField,{
25127
25203
  submitOnChange: false
25128
- };
25129
- if (isChangeActions) {
25130
- additionalProps.submitOnChange = true;
25131
- } else {
25132
- additionalProps.onEvent = {
25133
- blur: {
25134
- actions: [
25135
- {
25136
- actionType: "custom",
25137
- script: `
25138
- try {
25139
- const scope = event.context.scoped;
25140
- const filterForm = scope.parent.parent.parent.getComponents().find(function(n) {
25141
- return n.props.type === "form";
25142
- });
25143
- if (filterForm && typeof filterForm.handleFormSubmit === 'function') {
25144
- filterForm.handleFormSubmit(event);
25145
- }
25146
- } catch (error) {
25147
- console.error('An error occurred:', error);
25148
- }
25149
- `
25150
- }
25151
- ]
25152
- }
25153
- };
25154
- }
25155
- return Object.assign({}, amisField, additionalProps);
25204
+ });
25156
25205
  }
25157
25206
  }
25158
25207
  }
@@ -25401,7 +25450,7 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
25401
25450
  return getUISchemaCache(objectName);
25402
25451
  }
25403
25452
 
25404
- function getUISchemaSync(objectName, force) {
25453
+ function getUISchemaSync$1(objectName, force) {
25405
25454
  if (!objectName) {
25406
25455
  return;
25407
25456
  }
@@ -25585,7 +25634,7 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
25585
25634
 
25586
25635
  if(typeof window != 'undefined'){
25587
25636
  window.getUISchema = getUISchema;
25588
- window.getUISchemaSync = getUISchemaSync;
25637
+ window.getUISchemaSync = getUISchemaSync$1;
25589
25638
  window.getListSchema = getListSchema;
25590
25639
  }
25591
25640
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@steedos-widgets/sortable",
3
- "version": "1.3.14",
3
+ "version": "1.3.16",
4
4
  "main": "dist/sortable.cjs.js",
5
5
  "module": "dist/sortable.esm.js",
6
6
  "unpkg": "dist/sortable.umd.js",
@@ -45,7 +45,7 @@
45
45
  "dependencies": {
46
46
  "@dnd-kit/core": "^6.0.5",
47
47
  "@dnd-kit/sortable": "^7.0.1",
48
- "@steedos-widgets/amis-lib": "1.3.14"
48
+ "@steedos-widgets/amis-lib": "1.3.16"
49
49
  },
50
- "gitHead": "dc2ef13db1c9e63ff77eb708f920b266e77d2756"
50
+ "gitHead": "9dcffb0762807385032d09f79c0cf2bb45e21edf"
51
51
  }