@steedos-widgets/sortable 3.6.0-beta.6 → 3.6.0-beta.9

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.
@@ -21287,7 +21287,6 @@
21287
21287
  {
21288
21288
  "actionType": "custom",
21289
21289
  "script": `
21290
-
21291
21290
  var _display = _.cloneDeep(event.data._display);
21292
21291
  ${displayField}
21293
21292
  doAction({actionType: 'setValue', "args": {"value": {_display}},componentId: "${quickEditId}"});
@@ -21458,6 +21457,23 @@
21458
21457
  "onEvent":{
21459
21458
  "init":{
21460
21459
  "actions":[
21460
+ //amis3.6无法从数据域中直接拿到正确的selectitems,需要通过crud组件的getSelected()函数获取
21461
+ {
21462
+ "actionType": "custom",
21463
+ "script": `
21464
+ crudScoped = event.context.scoped.getComponentById('${options.crudId}');
21465
+ const selectedItems = crudScoped && crudScoped.control.getSelected();
21466
+ doAction({
21467
+ "componentId": "${quickEditId}",
21468
+ "actionType": "setValue",
21469
+ "args": {
21470
+ "value": {
21471
+ selectedItems
21472
+ }
21473
+ }
21474
+ });
21475
+ `
21476
+ },
21461
21477
  {
21462
21478
  "actionType": "setValue",
21463
21479
  "componentId": quickEditId,
@@ -22221,6 +22237,14 @@
22221
22237
 
22222
22238
  }
22223
22239
 
22240
+ const treeConfig = {};
22241
+
22242
+ if(options.enable_tree){
22243
+ treeConfig.expandConfig = {
22244
+ expand: 'first'
22245
+ };
22246
+ }
22247
+
22224
22248
  return {
22225
22249
  mode: "table",
22226
22250
  perPageAvailable: [5, 10, 20, 50, 100, 500],
@@ -22236,6 +22260,7 @@
22236
22260
  labelTpl: `\${${options.labelFieldName}}`,
22237
22261
  autoFillHeight: false, // 自动高度效果不理想,先关闭
22238
22262
  columnsTogglable: false,
22263
+ ...treeConfig
22239
22264
  }
22240
22265
  }
22241
22266
 
@@ -22700,12 +22725,16 @@
22700
22725
  // }
22701
22726
  // listView.handleFilterSubmit(Object.assign({}, removedValues, filterFormValues));
22702
22727
  // 点击搜索的时候自动收起搜索栏
22703
- let resizeWindow = function(){
22704
- //触发amis crud 高度重算
22705
- setTimeout(()=>{
22706
- window.dispatchEvent(new Event("resize"))
22707
- }, 500);
22708
- }
22728
+ //触发amis crud 高度重算
22729
+ doAction({
22730
+ "actionType": "broadcast",
22731
+ "args": {
22732
+ "eventName": "@height.changed.${objectSchema.name}"
22733
+ },
22734
+ "data": {
22735
+ "timeOut": 500
22736
+ }
22737
+ });
22709
22738
  const filterService = filterForm.context.getComponents().find(function(n){
22710
22739
  return n.props.type === "service";
22711
22740
  });
@@ -22807,9 +22836,16 @@
22807
22836
  let filterFormService = SteedosUI.getClosestAmisComponentByType(filterForm.context, "service");
22808
22837
  filterFormService.setData({showFieldsFilter: !!!filterFormService.props.data.showFieldsFilter});
22809
22838
  //触发amis crud 高度重算
22810
- setTimeout(()=>{
22811
- window.dispatchEvent(new Event("resize"))
22812
- }, 100);
22839
+ doAction({
22840
+ "actionType": "broadcast",
22841
+ "args": {
22842
+ "eventName": "@height.changed.${objectSchema.name}"
22843
+ },
22844
+ "data": {
22845
+ "timeOut": 100
22846
+ }
22847
+ });
22848
+
22813
22849
  // 移除搜索按钮上的红点
22814
22850
  // let crudService = scope.getComponentById("service_listview_" + event.data.objectName);
22815
22851
  let crudService = crud && SteedosUI.getClosestAmisComponentByType(crud.context, "service");
@@ -22966,9 +23002,15 @@
22966
23002
  sessionStorage.setItem(listViewPropsStoreKey, JSON.stringify(localListViewProps));
22967
23003
  }
22968
23004
  //触发amis crud 高度重算
22969
- setTimeout(()=>{
22970
- window.dispatchEvent(new Event("resize"))
22971
- }, 100)
23005
+ doAction({
23006
+ "actionType": "broadcast",
23007
+ "args": {
23008
+ "eventName": "@height.changed.${objectSchema.name}"
23009
+ },
23010
+ "data": {
23011
+ "timeOut": 100
23012
+ }
23013
+ });
22972
23014
  // ===END===
22973
23015
  `;
22974
23016
  return {
@@ -24210,13 +24252,16 @@ const filterService = filterForm.context.getComponents().find(function(n){
24210
24252
  });
24211
24253
  let toShowFieldsFilter = !!!filterService.props.data.showFieldsFilter;
24212
24254
  filterService.setData({showFieldsFilter: toShowFieldsFilter});
24213
- let resizeWindow = function(){
24214
- //触发amis crud 高度重算
24215
- setTimeout(()=>{
24216
- window.dispatchEvent(new Event("resize"))
24217
- }, 1000);
24218
- }
24219
- resizeWindow();
24255
+ //触发amis crud 高度重算
24256
+ doAction({
24257
+ "actionType": "broadcast",
24258
+ "args": {
24259
+ "eventName": "@height.changed." + event.data.objectName
24260
+ },
24261
+ "data": {
24262
+ "timeOut": 1000
24263
+ }
24264
+ });
24220
24265
  // 手机端在显示搜索栏时隐藏crud上的刷新按钮,因为点击后crud高度显示有问题
24221
24266
  let crudService = scope.getComponentById("service_listview_" + event.data.objectName);
24222
24267
  crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
@@ -24580,12 +24625,16 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
24580
24625
  return;
24581
24626
  }
24582
24627
  // 列表搜索栏字段值变更后立刻触发提交表单执行crud搜索,所以这里需要额外重算crud高度及筛选按钮红色星号图标显示隐藏
24583
- let resizeWindow = function(){
24584
- //触发amis crud 高度重算
24585
- setTimeout(()=>{
24586
- window.dispatchEvent(new Event("resize"))
24587
- }, 1000);
24588
- }
24628
+ //触发amis crud 高度重算
24629
+ doAction({
24630
+ "actionType": "broadcast",
24631
+ "args": {
24632
+ "eventName": "@height.changed.${objectSchema.name}"
24633
+ },
24634
+ "data": {
24635
+ "timeOut": 1000
24636
+ }
24637
+ });
24589
24638
  resizeWindow();
24590
24639
  const scope = event.context.scoped;
24591
24640
  // let filterFormValues = event.data;
@@ -25647,14 +25696,6 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
25647
25696
  }
25648
25697
  });
25649
25698
  payload.data.rows = treeRecords;
25650
- try{
25651
- setTimeout(() => {
25652
- $('.amis-dialog-widget.antd-Modal .antd-Table-content .antd-Table-table thead .antd-Table-expandBtn')[0]?.click();
25653
- }, 600);
25654
- }
25655
- catch(ex){
25656
- console.error("tree数据格式展开异常:", ex);
25657
- }
25658
25699
  }
25659
25700
  return payload;
25660
25701
  `;
@@ -25681,6 +25722,7 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
25681
25722
  labelFieldName,
25682
25723
  top: top,
25683
25724
  isLookup: true,
25725
+ enable_tree: refObjectConfig.enable_tree,
25684
25726
  ...ctx
25685
25727
  });
25686
25728
 
@@ -26099,18 +26141,28 @@ crudService && crudService.setData({showFieldsFilter: toShowFieldsFilter});
26099
26141
  enableEnhancedLookup = true;
26100
26142
  }
26101
26143
  }
26144
+ let amisSchema;
26102
26145
  // 默认使用下拉框模式显示lookup选项,只能配置了enable_enhanced_lookup才使用弹出增强模式
26103
26146
  if(enableEnhancedLookup == true){
26104
- return await lookupToAmisPicker(field, readonly, ctx);
26147
+ amisSchema = await lookupToAmisPicker(field, readonly, ctx);
26105
26148
  }else if(refObject.enable_tree) {
26106
- return await lookupToAmisTreeSelect(field, readonly, Object.assign({}, ctx, {
26149
+ amisSchema = await lookupToAmisTreeSelect(field, readonly, Object.assign({}, ctx, {
26107
26150
  labelField: referenceTo.labelField?.name || 'name',
26108
26151
  valueField: referenceTo.valueField?.name || '_id',
26109
26152
  objectName: referenceTo.objectName
26110
26153
  }));
26111
26154
  }else {
26112
- return await lookupToAmisSelect(field, readonly, ctx);
26155
+ amisSchema = await lookupToAmisSelect(field, readonly, ctx);
26156
+ }
26157
+ let refLookupPage = refObject.pages && refObject.pages.lookup;
26158
+ if(refLookupPage){
26159
+ if(typeof refLookupPage == 'string'){
26160
+ refLookupPage = JSON.parse(refLookupPage);
26161
+ }
26162
+ // Object.assign(amisSchema, refLookupPage);
26163
+ // amisSchema = _.defaultsDeep({}, refLookupPage, amisSchema);
26113
26164
  }
26165
+ return amisSchema;
26114
26166
  }
26115
26167
 
26116
26168
  async function lookupToAmisIdsPicker(field, readonly, ctx){
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@steedos-widgets/sortable",
3
- "version": "3.6.0-beta.6",
3
+ "version": "3.6.0-beta.9",
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": "3.6.0-beta.6"
48
+ "@steedos-widgets/amis-lib": "3.6.0-beta.9"
49
49
  },
50
- "gitHead": "11c3240e1faf4d5ae87634df9b6777268bd08c6f"
50
+ "gitHead": "a47b50fa1c03832ad0814bc769193e445ef9f30a"
51
51
  }