{"remainingRequest":"D:\\jenkins\\workspace\\xq-web-bpm\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\jenkins\\workspace\\xq-web-bpm\\src\\components\\form\\WidgetDivLayout.vue?vue&type=script&lang=js&","dependencies":[{"path":"D:\\jenkins\\workspace\\xq-web-bpm\\src\\components\\form\\WidgetDivLayout.vue","mtime":1675071992038},{"path":"D:\\jenkins\\workspace\\xq-web-bpm\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\xq-web-bpm\\node_modules\\thread-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\xq-web-bpm\\node_modules\\babel-loader\\lib\\index.js","mtime":315532800000},{"path":"D:\\jenkins\\workspace\\xq-web-bpm\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\xq-web-bpm\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000}],"contextDependencies":[],"result":["//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\r\nimport Draggable from 'vuedraggable'\r\nimport deepmerge from 'deepmerge'\r\nimport WidgetTableLayout from '@/components/form/WidgetTableLayout.vue' // tab布局\r\nimport WidgetCollapseLayout from '@/components/form/WidgetCollapseLayout.vue' // 折叠面板\r\nimport WidgetGridLayout from \"@/components/form/WidgetGridLayout.vue\" // 栅格布局\r\nimport WidgetMainTableLayout from \"@/components/form/WidgetMainTableLayout.vue\" // table表格布局\r\nimport WidgetSubtableLayout from \"@/components/form/WidgetSubtableLayout.vue\" // 子表布局\r\nimport WidgetSubdivLayout from \"@/components/form/WidgetSubDivLayout.vue\" // div子表布局\r\nimport WidgetDataViewLayout from \"@/components/form/WidgetDataViewLayout.vue\" // 数据视图布局\r\nimport WidgetHottableLayout from \"@/components/form/WidgetHottableLayout.vue\" // hotTable布局\r\nimport WidgetFormItem from \"@/components/form/WidgetFormItem.vue\" // 其他布局\r\nimport controlsApi from \"@/api/controlsConfig.js\";\r\n\r\nexport default {\r\n  name: 'WidgetDivLayout',\r\n  components: {\r\n    Draggable,\r\n    WidgetGridLayout,\r\n    WidgetTableLayout,\r\n    WidgetCollapseLayout,\r\n    WidgetSubdivLayout,\r\n    WidgetSubtableLayout,\r\n    WidgetDataViewLayout,\r\n    WidgetHottableLayout,\r\n    WidgetMainTableLayout,\r\n    WidgetFormItem,\r\n  },\r\n  props: [\"element\", \"select\", \"index\", \"data\",\"selectWidgetList\"],\r\n  data() {\r\n    return {\r\n      selectWidget: this.select,\r\n      activeName: 0\r\n    }\r\n  },\r\n  watch: {\r\n    select(val) {\r\n      this.selectWidget = val;\r\n    },\r\n    selectWidget: {\r\n      handler(val) {\r\n        this.$emit(\"update:select\", val);\r\n      },\r\n      deep: true\r\n    }\r\n  },\r\n  methods: {\r\n    handleSelectWidget(index) {\r\n      this.selectWidget = this.data.list[index];\r\n    },\r\n    handleMoveStart: function(evt) {\r\n      console.log(evt)\r\n      // 新增控件时  将控件属性切断联系\r\n      evt.item._underlying_vm_ = deepmerge({}, evt.item._underlying_vm_, {\r\n        clone: true\r\n      });\r\n      evt.item._underlying_vm_.key = Date.parse(new Date()) + \"_\" + Math.ceil(Math.random() * 99999);\r\n    },\r\n    handleMoveEnd({ newIndex, oldIndex }) {\r\n      console.log(\"index\", newIndex, oldIndex);\r\n    },\r\n    handleWidgetColAdd($event, row, colIndex) {\r\n      const newIndex = $event.newIndex;\r\n      const oldIndex = $event.oldIndex;\r\n      const item = $event.item;\r\n      // 防止布局元素的嵌套拖拽\r\n      if (item.className.indexOf(\"data-grid\") >= 0 || item.innerText==\"分页布局\") {\r\n        // 如果是列表中拖拽的元素需要还原到原来位置\r\n        item.tagName === \"DIV\" &&\r\n        this.data.list.splice(\r\n          oldIndex,\r\n          0,\r\n          row.columns[colIndex].list[newIndex]\r\n        );\r\n        row.columns[colIndex].list.splice(newIndex, 1);\r\n        if(item.innerText==\"分页布局\"){\r\n          this.$message.warning(\"div布局中不允许再拖入分页布局\");\r\n        }\r\n        return false;\r\n      }\r\n      controlsApi.handleLayoutComponents(this, row, row.columns[colIndex].list, newIndex);\r\n      this.selectWidget = row.columns[colIndex].list[newIndex];\r\n    },\r\n    handleWidgetDelete(index) {\r\n      if (this.data.list.length - 1 === index) {\r\n        if (index === 0) {\r\n          this.selectWidget = { options: { validateType: \"\" } };\r\n        } else {\r\n          this.selectWidget = this.data.list[index - 1];\r\n        }\r\n      } else {\r\n        this.selectWidget = this.data.list[index + 1];\r\n      }\r\n\r\n      this.$nextTick(() => {\r\n        this.data.list.splice(index, 1);\r\n      });\r\n    }\r\n  }\r\n}\r\n",null]}