PageEditorHelp.vue 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. <script setup lang="ts">
  2. import {onMounted, ref} from 'vue'
  3. import {collapseData, generateRandomString} from "../../../components/query-components/page-help.ts";
  4. import XcQuery from "../../../components/query-components/XcQuery.vue";
  5. import {componentType, headerType} from "../../../components/query-components/page-help-type";
  6. import PageEditotInfo from "./PageEditorInfo.vue";
  7. import {clone} from "xe-utils";
  8. import PageForm from "../../../views/utilities/page-editor-help/PageForm.vue";
  9. import XcTable from "../../../components/query-components/XcPageTable.vue";
  10. const activeNames = ref(['1', '2', '3'])
  11. const infoRef = ref()
  12. const tabs = ref('form')
  13. const addEl = (val: headerType) => {
  14. let key = generateRandomString(5)
  15. let data = val
  16. if (!val.bind) {
  17. data['bind'] = {}
  18. }
  19. data.key = key
  20. pageJson.value.header.push(clone(data, true))
  21. pageJson.value.queryParam[key] = val.defaultValue
  22. }
  23. const pageJson = ref<componentType>({
  24. header: [],
  25. querySql: "",
  26. queryParam: {},
  27. formConfig: {
  28. inline: true
  29. },
  30. submitEvent: `function func(queryData,config,axios){
  31. }`,
  32. tableConfig: {
  33. border: true,
  34. }
  35. })
  36. const theCurrentComponent = ref(-1)
  37. const itemClick = (data: headerType, index) => {
  38. infoRef.value.editComp(data)
  39. theCurrentComponent.value = index
  40. }
  41. onMounted(() => {
  42. // addEl(collapseData[0].children[0])
  43. // addEl(collapseData[0].children[1])
  44. // addEl(collapseData[1].children[0])
  45. addEl(collapseData[1].children[1])
  46. addEl(collapseData[2].children[0])
  47. })
  48. </script>
  49. <template>
  50. <el-container style="background-color: white">
  51. <el-aside>
  52. <el-collapse v-model="activeNames">
  53. <el-collapse-item :title="item.title"
  54. :name="item.name"
  55. v-for="item in collapseData">
  56. <el-row :gutter="6"
  57. style="margin: 5px">
  58. <el-col :span="12"
  59. @contextmenu.prevent="addEl(child)"
  60. v-for="child in item.children"
  61. class="field-widget-item">
  62. {{ child.label }}
  63. </el-col>
  64. </el-row>
  65. </el-collapse-item>
  66. </el-collapse>
  67. </el-aside>
  68. <el-main>
  69. <el-auto-resizer>
  70. <template #default="{ height, width }">
  71. <div style="display: flex; overflow-y: auto" :style="{height: height -50 +'px'}">
  72. <div style="flex: 1; box-sizing: border-box">
  73. <xc-query v-model:testJson="pageJson"
  74. @delClick="infoRef.setShow(false)"
  75. v-model:current-index="theCurrentComponent"
  76. @item-click="itemClick"/>
  77. <xc-table :test-json="pageJson"/>
  78. </div>
  79. <div class="right_box">
  80. <el-tabs v-model="tabs">
  81. <el-tab-pane label="组件配置" name="subassembly">
  82. <page-editot-info ref="infoRef"
  83. :page-json="pageJson"
  84. v-model:data="pageJson.header[theCurrentComponent]"/>
  85. </el-tab-pane>
  86. <el-tab-pane label="表单配置" name="form">
  87. <page-form :page-json="pageJson"/>
  88. </el-tab-pane>
  89. <el-tab-pane label="表单配置" name="table">
  90. </el-tab-pane>
  91. </el-tabs>
  92. </div>
  93. </div>
  94. </template>
  95. </el-auto-resizer>
  96. </el-main>
  97. </el-container>
  98. </template>
  99. <style scoped lang="scss">
  100. .field-widget-item {
  101. box-sizing: border-box;
  102. white-space: nowrap;
  103. text-overflow: ellipsis;
  104. overflow: hidden;
  105. background: #fff;
  106. border: 1px solid #e8e9eb;
  107. border-radius: 4px;
  108. text-align: center;
  109. }
  110. .right_box {
  111. width: 320px;
  112. border: 1px solid #e8e9eb;
  113. padding: 5px;
  114. height: 100%;
  115. box-sizing: border-box;
  116. overflow-y: auto;
  117. }
  118. </style>