tianheng-ui 0.1.77 → 0.1.79
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/lib/theme-chalk/images/json0.png +0 -0
 - package/lib/theme-chalk/images/json1.png +0 -0
 - package/lib/theme-chalk/images/json3.png +0 -0
 - package/lib/theme-chalk/images/json6.png +0 -0
 - package/lib/theme-chalk/styles/feature.scss +6 -0
 - package/lib/tianheng-ui.js +13 -13
 - package/package.json +1 -1
 - package/packages/FormMaking/WidgetConfig.vue +2 -2
 - package/packages/FormMaking/WidgetGuide.vue +176 -23
 - package/packages/FormMaking/WidgetTools.vue +70 -15
 - package/packages/FormMaking/assets/templates/empty.json +39 -0
 - package/packages/FormMaking/assets/templates/general.json +347 -0
 - package/packages/FormMaking/assets/templates/personalDetails.json +884 -0
 - package/packages/FormMaking/assets/templates/table.json +349 -0
 - package/packages/FormMaking/index.vue +9 -4
 - package/packages/TableMaking/widgetConfig.vue +1 -1
 - package/packages/TableMaking/widgetGuide.vue +23 -26
 
    
        package/package.json
    CHANGED
    
    
| 
         @@ -181,7 +181,7 @@ 
     | 
|
| 
       181 
181 
     | 
    
         
             
                          <el-tooltip
         
     | 
| 
       182 
182 
     | 
    
         
             
                            slot="label"
         
     | 
| 
       183 
183 
     | 
    
         
             
                            effect="light"
         
     | 
| 
       184 
     | 
    
         
            -
                            content=" 
     | 
| 
      
 184 
     | 
    
         
            +
                            content="使用该接口的出参配置可选字段"
         
     | 
| 
       185 
185 
     | 
    
         
             
                            placement="top"
         
     | 
| 
       186 
186 
     | 
    
         
             
                          >
         
     | 
| 
       187 
187 
     | 
    
         
             
                            <span style="color: #409EFF;">字段接口</span>
         
     | 
| 
         @@ -217,7 +217,7 @@ 
     | 
|
| 
       217 
217 
     | 
    
         
             
                          <el-tooltip
         
     | 
| 
       218 
218 
     | 
    
         
             
                            slot="label"
         
     | 
| 
       219 
219 
     | 
    
         
             
                            effect="light"
         
     | 
| 
       220 
     | 
    
         
            -
                            content="开启后,选择数据接口会触发 remote-params  
     | 
| 
      
 220 
     | 
    
         
            +
                            content="开启后,选择数据接口会触发 remote-params 回调,用于从服务器获取字段"
         
     | 
| 
       221 
221 
     | 
    
         
             
                            placement="top"
         
     | 
| 
       222 
222 
     | 
    
         
             
                          >
         
     | 
| 
       223 
223 
     | 
    
         
             
                            <span style="color: #409EFF;">远程字段</span>
         
     | 
| 
         @@ -3,14 +3,94 @@ 
     | 
|
| 
       3 
3 
     | 
    
         
             
                <el-steps :active="step" finish-status="success" simple>
         
     | 
| 
       4 
4 
     | 
    
         
             
                  <el-step title="表单配置" icon="el-icon-s-operation" description="">
         
     | 
| 
       5 
5 
     | 
    
         
             
                  </el-step>
         
     | 
| 
       6 
     | 
    
         
            -
                  <el-step 
     | 
| 
      
 6 
     | 
    
         
            +
                  <el-step
         
     | 
| 
      
 7 
     | 
    
         
            +
                    title="选择初始模板"
         
     | 
| 
      
 8 
     | 
    
         
            +
                    icon="el-icon-set-up"
         
     | 
| 
      
 9 
     | 
    
         
            +
                    description=""
         
     | 
| 
      
 10 
     | 
    
         
            +
                  ></el-step>
         
     | 
| 
      
 11 
     | 
    
         
            +
                  <!-- <el-step
         
     | 
| 
      
 12 
     | 
    
         
            +
                    title="选择初始模板"
         
     | 
| 
      
 13 
     | 
    
         
            +
                    icon="el-icon-set-up"
         
     | 
| 
      
 14 
     | 
    
         
            +
                    description=""
         
     | 
| 
      
 15 
     | 
    
         
            +
                  ></el-step> -->
         
     | 
| 
       7 
16 
     | 
    
         
             
                </el-steps>
         
     | 
| 
       8 
17 
     | 
    
         
             
                <div class="content">
         
     | 
| 
       9 
     | 
    
         
            -
                  < 
     | 
| 
       10 
     | 
    
         
            -
                    <div 
     | 
| 
       11 
     | 
    
         
            -
             
     | 
| 
       12 
     | 
    
         
            -
             
     | 
| 
       13 
     | 
    
         
            -
             
     | 
| 
      
 18 
     | 
    
         
            +
                  <el-form :model="config" label-width="80px" size="small">
         
     | 
| 
      
 19 
     | 
    
         
            +
                    <div v-show="step === 0">
         
     | 
| 
      
 20 
     | 
    
         
            +
                      <el-form-item>
         
     | 
| 
      
 21 
     | 
    
         
            +
                        <el-tooltip
         
     | 
| 
      
 22 
     | 
    
         
            +
                          slot="label"
         
     | 
| 
      
 23 
     | 
    
         
            +
                          effect="light"
         
     | 
| 
      
 24 
     | 
    
         
            +
                          content="字段的配置方式"
         
     | 
| 
      
 25 
     | 
    
         
            +
                          placement="top"
         
     | 
| 
      
 26 
     | 
    
         
            +
                        >
         
     | 
| 
      
 27 
     | 
    
         
            +
                          <span style="color: #409EFF;">字段类型</span>
         
     | 
| 
      
 28 
     | 
    
         
            +
                        </el-tooltip>
         
     | 
| 
      
 29 
     | 
    
         
            +
                        <el-radio-group v-model="config.config.fields.type">
         
     | 
| 
      
 30 
     | 
    
         
            +
                          <el-radio-button label="custom">自定义</el-radio-button>
         
     | 
| 
      
 31 
     | 
    
         
            +
                          <el-radio-button label="api">接口导入</el-radio-button>
         
     | 
| 
      
 32 
     | 
    
         
            +
                        </el-radio-group>
         
     | 
| 
      
 33 
     | 
    
         
            +
                      </el-form-item>
         
     | 
| 
      
 34 
     | 
    
         
            +
                      <el-form-item v-if="config.config.fields.type === 'api'">
         
     | 
| 
      
 35 
     | 
    
         
            +
                        <el-tooltip
         
     | 
| 
      
 36 
     | 
    
         
            +
                          slot="label"
         
     | 
| 
      
 37 
     | 
    
         
            +
                          effect="light"
         
     | 
| 
      
 38 
     | 
    
         
            +
                          content="使用该接口的出参配置可选字段"
         
     | 
| 
      
 39 
     | 
    
         
            +
                          placement="top"
         
     | 
| 
      
 40 
     | 
    
         
            +
                        >
         
     | 
| 
      
 41 
     | 
    
         
            +
                          <span style="color: #409EFF;">字段接口</span>
         
     | 
| 
      
 42 
     | 
    
         
            +
                        </el-tooltip>
         
     | 
| 
      
 43 
     | 
    
         
            +
                        <el-select
         
     | 
| 
      
 44 
     | 
    
         
            +
                          v-model="config.config.fields.api"
         
     | 
| 
      
 45 
     | 
    
         
            +
                          style="width:100%"
         
     | 
| 
      
 46 
     | 
    
         
            +
                          clearable
         
     | 
| 
      
 47 
     | 
    
         
            +
                          placeholder="请选择"
         
     | 
| 
      
 48 
     | 
    
         
            +
                          no-data-text="暂无接口,请前往【接口模块】创建"
         
     | 
| 
      
 49 
     | 
    
         
            +
                          filterable
         
     | 
| 
      
 50 
     | 
    
         
            +
                        >
         
     | 
| 
      
 51 
     | 
    
         
            +
                          <el-option
         
     | 
| 
      
 52 
     | 
    
         
            +
                            v-for="item in apiOptions"
         
     | 
| 
      
 53 
     | 
    
         
            +
                            :key="item.id"
         
     | 
| 
      
 54 
     | 
    
         
            +
                            :label="item.name"
         
     | 
| 
      
 55 
     | 
    
         
            +
                            :value="item.id"
         
     | 
| 
      
 56 
     | 
    
         
            +
                          >
         
     | 
| 
      
 57 
     | 
    
         
            +
                          </el-option>
         
     | 
| 
      
 58 
     | 
    
         
            +
                        </el-select>
         
     | 
| 
      
 59 
     | 
    
         
            +
                      </el-form-item>
         
     | 
| 
      
 60 
     | 
    
         
            +
                      <el-form-item label="表单名称">
         
     | 
| 
      
 61 
     | 
    
         
            +
                        <el-input
         
     | 
| 
      
 62 
     | 
    
         
            +
                          v-model="config.config.title"
         
     | 
| 
      
 63 
     | 
    
         
            +
                          placeholder="请输入"
         
     | 
| 
      
 64 
     | 
    
         
            +
                        ></el-input>
         
     | 
| 
      
 65 
     | 
    
         
            +
                      </el-form-item>
         
     | 
| 
      
 66 
     | 
    
         
            +
                      <el-form-item>
         
     | 
| 
      
 67 
     | 
    
         
            +
                        <el-tooltip
         
     | 
| 
      
 68 
     | 
    
         
            +
                          slot="label"
         
     | 
| 
      
 69 
     | 
    
         
            +
                          effect="light"
         
     | 
| 
      
 70 
     | 
    
         
            +
                          content="开启后,选择数据接口会触发 remote-params 回调,用于从服务器获取字段"
         
     | 
| 
      
 71 
     | 
    
         
            +
                          placement="top"
         
     | 
| 
      
 72 
     | 
    
         
            +
                        >
         
     | 
| 
      
 73 
     | 
    
         
            +
                          <span style="color: #409EFF;">远程字段</span>
         
     | 
| 
      
 74 
     | 
    
         
            +
                        </el-tooltip>
         
     | 
| 
      
 75 
     | 
    
         
            +
                        <el-switch v-model="config.config.fields.remote"> </el-switch>
         
     | 
| 
      
 76 
     | 
    
         
            +
                      </el-form-item>
         
     | 
| 
      
 77 
     | 
    
         
            +
                    </div>
         
     | 
| 
      
 78 
     | 
    
         
            +
                    <div v-show="step === 1" class="formTemplates">
         
     | 
| 
      
 79 
     | 
    
         
            +
                      <div
         
     | 
| 
      
 80 
     | 
    
         
            +
                        :class="
         
     | 
| 
      
 81 
     | 
    
         
            +
                          `formTemplates-item th-border th-hover_boxShadow_light ${
         
     | 
| 
      
 82 
     | 
    
         
            +
                            formTemplateActive === index ? 'th-active' : ''
         
     | 
| 
      
 83 
     | 
    
         
            +
                          }`
         
     | 
| 
      
 84 
     | 
    
         
            +
                        "
         
     | 
| 
      
 85 
     | 
    
         
            +
                        v-for="(item, index) in formTemplates"
         
     | 
| 
      
 86 
     | 
    
         
            +
                        :key="index"
         
     | 
| 
      
 87 
     | 
    
         
            +
                        @click="handleFormTemplateClick(index)"
         
     | 
| 
      
 88 
     | 
    
         
            +
                      >
         
     | 
| 
      
 89 
     | 
    
         
            +
                        <img :src="item.img" alt="" />
         
     | 
| 
      
 90 
     | 
    
         
            +
                        <div>{{ item.name }}</div>
         
     | 
| 
      
 91 
     | 
    
         
            +
                      </div>
         
     | 
| 
      
 92 
     | 
    
         
            +
                    </div>
         
     | 
| 
      
 93 
     | 
    
         
            +
                  </el-form>
         
     | 
| 
       14 
94 
     | 
    
         
             
                </div>
         
     | 
| 
       15 
95 
     | 
    
         
             
                <div class="footer">
         
     | 
| 
       16 
96 
     | 
    
         
             
                  <div></div>
         
     | 
| 
         @@ -23,31 +103,43 @@ 
     | 
|
| 
       23 
103 
     | 
    
         
             
                      @click="handleBack"
         
     | 
| 
       24 
104 
     | 
    
         
             
                      >上一步</el-button
         
     | 
| 
       25 
105 
     | 
    
         
             
                    >
         
     | 
| 
       26 
     | 
    
         
            -
                    <el-button 
     | 
| 
       27 
     | 
    
         
            -
                       
     | 
| 
       28 
     | 
    
         
            -
             
     | 
| 
      
 106 
     | 
    
         
            +
                    <el-button
         
     | 
| 
      
 107 
     | 
    
         
            +
                      v-if="step !== 1"
         
     | 
| 
      
 108 
     | 
    
         
            +
                      type="primary"
         
     | 
| 
      
 109 
     | 
    
         
            +
                      size="small"
         
     | 
| 
      
 110 
     | 
    
         
            +
                      @click="handleNext"
         
     | 
| 
      
 111 
     | 
    
         
            +
                    >
         
     | 
| 
      
 112 
     | 
    
         
            +
                      下一步<i class="el-icon-right el-icon--right"></i>
         
     | 
| 
      
 113 
     | 
    
         
            +
                    </el-button>
         
     | 
| 
      
 114 
     | 
    
         
            +
                    <el-button v-else type="success" size="small" @click="handleSave">
         
     | 
| 
      
 115 
     | 
    
         
            +
                      完   成<i class="el-icon-finished el-icon--right"></i>
         
     | 
| 
      
 116 
     | 
    
         
            +
                    </el-button>
         
     | 
| 
       29 
117 
     | 
    
         
             
                  </div>
         
     | 
| 
       30 
118 
     | 
    
         
             
                </div>
         
     | 
| 
       31 
119 
     | 
    
         
             
              </div>
         
     | 
| 
       32 
120 
     | 
    
         
             
            </template>
         
     | 
| 
       33 
121 
     | 
    
         | 
| 
       34 
122 
     | 
    
         
             
            <script>
         
     | 
| 
      
 123 
     | 
    
         
            +
            import EmptyTemplateJson from "./assets/templates/empty.json";
         
     | 
| 
      
 124 
     | 
    
         
            +
            import GeneralTemplateJson from "./assets/templates/general.json";
         
     | 
| 
      
 125 
     | 
    
         
            +
            import PersonalDetailsTemplateJson from "./assets/templates/personalDetails.json";
         
     | 
| 
      
 126 
     | 
    
         
            +
            import TableTemplateJson from "./assets/templates/table.json";
         
     | 
| 
      
 127 
     | 
    
         
            +
            import { deepClone } from "./util";
         
     | 
| 
       35 
128 
     | 
    
         
             
            export default {
         
     | 
| 
       36 
     | 
    
         
            -
              props: {  
     | 
| 
      
 129 
     | 
    
         
            +
              props: { config: Object, apiOptions: Array },
         
     | 
| 
       37 
130 
     | 
    
         
             
              data() {
         
     | 
| 
       38 
131 
     | 
    
         
             
                return {
         
     | 
| 
       39 
     | 
    
         
            -
                   
     | 
| 
       40 
     | 
    
         
            -
                   
     | 
| 
      
 132 
     | 
    
         
            +
                  step: 0,
         
     | 
| 
      
 133 
     | 
    
         
            +
                  formTemplates: [
         
     | 
| 
      
 134 
     | 
    
         
            +
                    EmptyTemplateJson,
         
     | 
| 
      
 135 
     | 
    
         
            +
                    GeneralTemplateJson,
         
     | 
| 
      
 136 
     | 
    
         
            +
                    PersonalDetailsTemplateJson,
         
     | 
| 
      
 137 
     | 
    
         
            +
                    TableTemplateJson
         
     | 
| 
      
 138 
     | 
    
         
            +
                  ],
         
     | 
| 
      
 139 
     | 
    
         
            +
                  formTemplateActive: null
         
     | 
| 
       41 
140 
     | 
    
         
             
                };
         
     | 
| 
       42 
141 
     | 
    
         
             
              },
         
     | 
| 
       43 
     | 
    
         
            -
               
     | 
| 
       44 
     | 
    
         
            -
                visible(val) {
         
     | 
| 
       45 
     | 
    
         
            -
                  this.show = val;
         
     | 
| 
       46 
     | 
    
         
            -
                },
         
     | 
| 
       47 
     | 
    
         
            -
                show(val) {
         
     | 
| 
       48 
     | 
    
         
            -
                  this.$emit("update:visible", val);
         
     | 
| 
       49 
     | 
    
         
            -
                }
         
     | 
| 
       50 
     | 
    
         
            -
              },
         
     | 
| 
      
 142 
     | 
    
         
            +
              computed: {},
         
     | 
| 
       51 
143 
     | 
    
         
             
              created() {},
         
     | 
| 
       52 
144 
     | 
    
         
             
              mounted() {},
         
     | 
| 
       53 
145 
     | 
    
         
             
              methods: {
         
     | 
| 
         @@ -57,8 +149,15 @@ export default { 
     | 
|
| 
       57 
149 
     | 
    
         
             
                handleNext() {
         
     | 
| 
       58 
150 
     | 
    
         
             
                  this.step++;
         
     | 
| 
       59 
151 
     | 
    
         
             
                },
         
     | 
| 
       60 
     | 
    
         
            -
                 
     | 
| 
       61 
     | 
    
         
            -
                  this. 
     | 
| 
      
 152 
     | 
    
         
            +
                handleSave() {
         
     | 
| 
      
 153 
     | 
    
         
            +
                  if (this.formTemplateActive !== null) {
         
     | 
| 
      
 154 
     | 
    
         
            +
                    const list = this.formTemplates[this.formTemplateActive].data.list;
         
     | 
| 
      
 155 
     | 
    
         
            +
                    this.config.list = deepClone(list);
         
     | 
| 
      
 156 
     | 
    
         
            +
                  }
         
     | 
| 
      
 157 
     | 
    
         
            +
                  this.$emit("save");
         
     | 
| 
      
 158 
     | 
    
         
            +
                },
         
     | 
| 
      
 159 
     | 
    
         
            +
                handleFormTemplateClick(index) {
         
     | 
| 
      
 160 
     | 
    
         
            +
                  this.formTemplateActive = index;
         
     | 
| 
       62 
161 
     | 
    
         
             
                }
         
     | 
| 
       63 
162 
     | 
    
         
             
              }
         
     | 
| 
       64 
163 
     | 
    
         
             
            };
         
     | 
| 
         @@ -70,7 +169,13 @@ export default { 
     | 
|
| 
       70 
169 
     | 
    
         
             
              height: 100%;
         
     | 
| 
       71 
170 
     | 
    
         | 
| 
       72 
171 
     | 
    
         
             
              .content {
         
     | 
| 
       73 
     | 
    
         
            -
                height: calc(100% -  
     | 
| 
      
 172 
     | 
    
         
            +
                height: calc(100% - 96px);
         
     | 
| 
      
 173 
     | 
    
         
            +
                padding-top: 10px;
         
     | 
| 
      
 174 
     | 
    
         
            +
                overflow-y: scroll;
         
     | 
| 
      
 175 
     | 
    
         
            +
             
     | 
| 
      
 176 
     | 
    
         
            +
                .tools-item {
         
     | 
| 
      
 177 
     | 
    
         
            +
                  margin-bottom: 10px;
         
     | 
| 
      
 178 
     | 
    
         
            +
                }
         
     | 
| 
       74 
179 
     | 
    
         
             
              }
         
     | 
| 
       75 
180 
     | 
    
         
             
              .footer {
         
     | 
| 
       76 
181 
     | 
    
         
             
                height: 50px;
         
     | 
| 
         @@ -78,9 +183,57 @@ export default { 
     | 
|
| 
       78 
183 
     | 
    
         
             
                align-items: center;
         
     | 
| 
       79 
184 
     | 
    
         
             
                justify-content: space-between;
         
     | 
| 
       80 
185 
     | 
    
         
             
                box-sizing: border-box;
         
     | 
| 
      
 186 
     | 
    
         
            +
                background-color: white;
         
     | 
| 
       81 
187 
     | 
    
         | 
| 
       82 
188 
     | 
    
         
             
                .stepView {
         
     | 
| 
       83 
189 
     | 
    
         
             
                }
         
     | 
| 
       84 
190 
     | 
    
         
             
              }
         
     | 
| 
      
 191 
     | 
    
         
            +
              .fields-item {
         
     | 
| 
      
 192 
     | 
    
         
            +
                span {
         
     | 
| 
      
 193 
     | 
    
         
            +
                  padding: 0px 8px 2px 8px;
         
     | 
| 
      
 194 
     | 
    
         
            +
                  border-radius: 4px;
         
     | 
| 
      
 195 
     | 
    
         
            +
                }
         
     | 
| 
      
 196 
     | 
    
         
            +
                span:nth-child(1) {
         
     | 
| 
      
 197 
     | 
    
         
            +
                  color: #1890ff;
         
     | 
| 
      
 198 
     | 
    
         
            +
                  background-color: #e8f4ff;
         
     | 
| 
      
 199 
     | 
    
         
            +
                }
         
     | 
| 
      
 200 
     | 
    
         
            +
                span:nth-child(2) {
         
     | 
| 
      
 201 
     | 
    
         
            +
                  color: #13ce66;
         
     | 
| 
      
 202 
     | 
    
         
            +
                  background-color: #e7faf0;
         
     | 
| 
      
 203 
     | 
    
         
            +
                }
         
     | 
| 
      
 204 
     | 
    
         
            +
                span:nth-child(3) {
         
     | 
| 
      
 205 
     | 
    
         
            +
                  color: #909399;
         
     | 
| 
      
 206 
     | 
    
         
            +
                  background-color: #f4f4f5;
         
     | 
| 
      
 207 
     | 
    
         
            +
                }
         
     | 
| 
      
 208 
     | 
    
         
            +
              }
         
     | 
| 
      
 209 
     | 
    
         
            +
              .formTemplates {
         
     | 
| 
      
 210 
     | 
    
         
            +
                .formTemplates-item {
         
     | 
| 
      
 211 
     | 
    
         
            +
                  display: inline-block;
         
     | 
| 
      
 212 
     | 
    
         
            +
                  margin: 10px;
         
     | 
| 
      
 213 
     | 
    
         
            +
                  padding: 10px;
         
     | 
| 
      
 214 
     | 
    
         
            +
                  width: 230px;
         
     | 
| 
      
 215 
     | 
    
         
            +
                  border-radius: 4px;
         
     | 
| 
      
 216 
     | 
    
         
            +
                  transition: 0.25s;
         
     | 
| 
      
 217 
     | 
    
         
            +
                  box-sizing: border-box;
         
     | 
| 
      
 218 
     | 
    
         
            +
             
     | 
| 
      
 219 
     | 
    
         
            +
                  img {
         
     | 
| 
      
 220 
     | 
    
         
            +
                    width: 100%;
         
     | 
| 
      
 221 
     | 
    
         
            +
                    height: 230px;
         
     | 
| 
      
 222 
     | 
    
         
            +
                    object-fit: contain;
         
     | 
| 
      
 223 
     | 
    
         
            +
                  }
         
     | 
| 
      
 224 
     | 
    
         
            +
                }
         
     | 
| 
      
 225 
     | 
    
         
            +
              }
         
     | 
| 
      
 226 
     | 
    
         
            +
            }
         
     | 
| 
      
 227 
     | 
    
         
            +
            </style>
         
     | 
| 
      
 228 
     | 
    
         
            +
             
     | 
| 
      
 229 
     | 
    
         
            +
            <style lang="scss">
         
     | 
| 
      
 230 
     | 
    
         
            +
            .widgetGuide {
         
     | 
| 
      
 231 
     | 
    
         
            +
              .el-transfer {
         
     | 
| 
      
 232 
     | 
    
         
            +
                display: flex;
         
     | 
| 
      
 233 
     | 
    
         
            +
                align-items: center;
         
     | 
| 
      
 234 
     | 
    
         
            +
              }
         
     | 
| 
      
 235 
     | 
    
         
            +
              .el-transfer-panel {
         
     | 
| 
      
 236 
     | 
    
         
            +
                flex: 1;
         
     | 
| 
      
 237 
     | 
    
         
            +
              }
         
     | 
| 
       85 
238 
     | 
    
         
             
            }
         
     | 
| 
       86 
239 
     | 
    
         
             
            </style>
         
     | 
| 
         @@ -74,7 +74,6 @@ 
     | 
|
| 
       74 
74 
     | 
    
         
             
                        <el-button
         
     | 
| 
       75 
75 
     | 
    
         
             
                          type="text"
         
     | 
| 
       76 
76 
     | 
    
         
             
                          size="medium"
         
     | 
| 
       77 
     | 
    
         
            -
                          disabled
         
     | 
| 
       78 
77 
     | 
    
         
             
                          @click="handleDialogOpen('importTemplate')"
         
     | 
| 
       79 
78 
     | 
    
         
             
                          >导入模板
         
     | 
| 
       80 
79 
     | 
    
         
             
                        </el-button>
         
     | 
| 
         @@ -120,7 +119,8 @@ 
     | 
|
| 
       120 
119 
     | 
    
         
             
                  :showFooter="
         
     | 
| 
       121 
120 
     | 
    
         
             
                    dialog.action === 'previewPc' ||
         
     | 
| 
       122 
121 
     | 
    
         
             
                      dialog.action === 'previewH5' ||
         
     | 
| 
       123 
     | 
    
         
            -
                      dialog.action === 'importJson'
         
     | 
| 
      
 122 
     | 
    
         
            +
                      dialog.action === 'importJson' ||
         
     | 
| 
      
 123 
     | 
    
         
            +
                      dialog.action === 'importTemplate'
         
     | 
| 
       124 
124 
     | 
    
         
             
                  "
         
     | 
| 
       125 
125 
     | 
    
         
             
                  @on-close="handleDialogClose"
         
     | 
| 
       126 
126 
     | 
    
         
             
                  @on-affirm="handleDialogAffirm"
         
     | 
| 
         @@ -133,7 +133,21 @@ 
     | 
|
| 
       133 
133 
     | 
    
         
             
                    ></el-alert>
         
     | 
| 
       134 
134 
     | 
    
         
             
                    <th-code-editor v-model="dialog.data" ref="codeEditor"></th-code-editor>
         
     | 
| 
       135 
135 
     | 
    
         
             
                  </template>
         
     | 
| 
       136 
     | 
    
         
            -
                  < 
     | 
| 
      
 136 
     | 
    
         
            +
                  <div v-if="dialog.action === 'importTemplate'" class="formTemplates">
         
     | 
| 
      
 137 
     | 
    
         
            +
                    <div
         
     | 
| 
      
 138 
     | 
    
         
            +
                      :class="
         
     | 
| 
      
 139 
     | 
    
         
            +
                        `formTemplates-item th-border th-hover_boxShadow_light ${
         
     | 
| 
      
 140 
     | 
    
         
            +
                          formTemplateActive === index ? 'th-active' : ''
         
     | 
| 
      
 141 
     | 
    
         
            +
                        }`
         
     | 
| 
      
 142 
     | 
    
         
            +
                      "
         
     | 
| 
      
 143 
     | 
    
         
            +
                      v-for="(item, index) in formTemplates"
         
     | 
| 
      
 144 
     | 
    
         
            +
                      :key="index"
         
     | 
| 
      
 145 
     | 
    
         
            +
                      @click="handleFormTemplateClick(index)"
         
     | 
| 
      
 146 
     | 
    
         
            +
                    >
         
     | 
| 
      
 147 
     | 
    
         
            +
                      <img :src="item.img" alt="" />
         
     | 
| 
      
 148 
     | 
    
         
            +
                      <div>{{ item.name }}</div>
         
     | 
| 
      
 149 
     | 
    
         
            +
                    </div>
         
     | 
| 
      
 150 
     | 
    
         
            +
                  </div>
         
     | 
| 
       137 
151 
     | 
    
         
             
                  <template v-if="dialog.action === 'generateJson'">
         
     | 
| 
       138 
152 
     | 
    
         
             
                    <th-code-editor v-model="dialog.data" ref="codeEditor"></th-code-editor>
         
     | 
| 
       139 
153 
     | 
    
         
             
                  </template>
         
     | 
| 
         @@ -164,7 +178,7 @@ 
     | 
|
| 
       164 
178 
     | 
    
         
             
                  <template v-if="dialog.action === 'previewPc'">
         
     | 
| 
       165 
179 
     | 
    
         
             
                    <generate-form
         
     | 
| 
       166 
180 
     | 
    
         
             
                      v-if="dialog.show"
         
     | 
| 
       167 
     | 
    
         
            -
                      :config=" 
     | 
| 
      
 181 
     | 
    
         
            +
                      :config="formConfig"
         
     | 
| 
       168 
182 
     | 
    
         
             
                      :oauthConfig="oauthConfig"
         
     | 
| 
       169 
183 
     | 
    
         
             
                      :slotKeys="slotKeys"
         
     | 
| 
       170 
184 
     | 
    
         
             
                      @change="handleDataChange"
         
     | 
| 
         @@ -188,7 +202,7 @@ 
     | 
|
| 
       188 
202 
     | 
    
         
             
                      <generate-form
         
     | 
| 
       189 
203 
     | 
    
         
             
                        v-if="dialog.show"
         
     | 
| 
       190 
204 
     | 
    
         
             
                        class="box"
         
     | 
| 
       191 
     | 
    
         
            -
                        :config=" 
     | 
| 
      
 205 
     | 
    
         
            +
                        :config="formConfig"
         
     | 
| 
       192 
206 
     | 
    
         
             
                        :oauthConfig="oauthConfig"
         
     | 
| 
       193 
207 
     | 
    
         
             
                        @change="handleDataChange"
         
     | 
| 
       194 
208 
     | 
    
         
             
                        @button-submit="handleButtonSubmit"
         
     | 
| 
         @@ -230,13 +244,17 @@ import { deepClone } from "./util/index"; 
     | 
|
| 
       230 
244 
     | 
    
         
             
            import * as XLSX from "xlsx/xlsx.mjs";
         
     | 
| 
       231 
245 
     | 
    
         
             
            import generateCode from "./util/generateCode.js";
         
     | 
| 
       232 
246 
     | 
    
         
             
            import GenerateForm from "./GenerateForm";
         
     | 
| 
      
 247 
     | 
    
         
            +
            import EmptyTemplateJson from "./assets/templates/empty.json";
         
     | 
| 
      
 248 
     | 
    
         
            +
            import GeneralTemplateJson from "./assets/templates/general.json";
         
     | 
| 
      
 249 
     | 
    
         
            +
            import PersonalDetailsTemplateJson from "./assets/templates/personalDetails.json";
         
     | 
| 
      
 250 
     | 
    
         
            +
            import TableTemplateJson from "./assets/templates/table.json";
         
     | 
| 
       233 
251 
     | 
    
         
             
            export default {
         
     | 
| 
       234 
252 
     | 
    
         
             
              props: {
         
     | 
| 
       235 
253 
     | 
    
         
             
                baseConfig: Object,
         
     | 
| 
       236 
254 
     | 
    
         
             
                permissions: Array,
         
     | 
| 
       237 
255 
     | 
    
         
             
                basicComponents: Array,
         
     | 
| 
       238 
256 
     | 
    
         
             
                layoutComponents: Array,
         
     | 
| 
       239 
     | 
    
         
            -
                 
     | 
| 
      
 257 
     | 
    
         
            +
                formConfig: Object,
         
     | 
| 
       240 
258 
     | 
    
         
             
                oauthConfig: Object,
         
     | 
| 
       241 
259 
     | 
    
         
             
                apiOptions: Array
         
     | 
| 
       242 
260 
     | 
    
         
             
              },
         
     | 
| 
         @@ -249,7 +267,6 @@ export default { 
     | 
|
| 
       249 
267 
     | 
    
         
             
                    data: null
         
     | 
| 
       250 
268 
     | 
    
         
             
                  },
         
     | 
| 
       251 
269 
     | 
    
         
             
                  dialogResultData: { show: false, data: null },
         
     | 
| 
       252 
     | 
    
         
            -
             
     | 
| 
       253 
270 
     | 
    
         
             
                  dialogTitles: {
         
     | 
| 
       254 
271 
     | 
    
         
             
                    previewPc: "预览-电脑端",
         
     | 
| 
       255 
272 
     | 
    
         
             
                    previewH5: "预览-移动端",
         
     | 
| 
         @@ -258,7 +275,14 @@ export default { 
     | 
|
| 
       258 
275 
     | 
    
         
             
                    generateJson: "生成JSON",
         
     | 
| 
       259 
276 
     | 
    
         
             
                    generateCode: "生成代码"
         
     | 
| 
       260 
277 
     | 
    
         
             
                  },
         
     | 
| 
       261 
     | 
    
         
            -
                   
     | 
| 
      
 278 
     | 
    
         
            +
                  formTemplates: [
         
     | 
| 
      
 279 
     | 
    
         
            +
                    EmptyTemplateJson,
         
     | 
| 
      
 280 
     | 
    
         
            +
                    GeneralTemplateJson,
         
     | 
| 
      
 281 
     | 
    
         
            +
                    PersonalDetailsTemplateJson,
         
     | 
| 
      
 282 
     | 
    
         
            +
                    TableTemplateJson
         
     | 
| 
      
 283 
     | 
    
         
            +
                  ],
         
     | 
| 
      
 284 
     | 
    
         
            +
                  formTemplateActive: null,
         
     | 
| 
      
 285 
     | 
    
         
            +
                  slotKeys: []
         
     | 
| 
       262 
286 
     | 
    
         
             
                };
         
     | 
| 
       263 
287 
     | 
    
         
             
              },
         
     | 
| 
       264 
288 
     | 
    
         
             
              created() {},
         
     | 
| 
         @@ -418,13 +442,13 @@ export default { 
     | 
|
| 
       418 
442 
     | 
    
         
             
                  let data = "";
         
     | 
| 
       419 
443 
     | 
    
         
             
                  switch (action) {
         
     | 
| 
       420 
444 
     | 
    
         
             
                    case "generateJson":
         
     | 
| 
       421 
     | 
    
         
            -
                      data = JSON.stringify(this. 
     | 
| 
      
 445 
     | 
    
         
            +
                      data = JSON.stringify(this.formConfig, null, 2);
         
     | 
| 
       422 
446 
     | 
    
         
             
                      break;
         
     | 
| 
       423 
447 
     | 
    
         
             
                    case "generateCode":
         
     | 
| 
       424 
448 
     | 
    
         
             
                      data = {
         
     | 
| 
       425 
449 
     | 
    
         
             
                        generate: generateCode(
         
     | 
| 
       426 
450 
     | 
    
         
             
                          {
         
     | 
| 
       427 
     | 
    
         
            -
                            formConfig: JSON.stringify(this. 
     | 
| 
      
 451 
     | 
    
         
            +
                            formConfig: JSON.stringify(this.formConfig, null, 2),
         
     | 
| 
       428 
452 
     | 
    
         
             
                            apiOptions: JSON.stringify(this.apiOptions, null, 2),
         
     | 
| 
       429 
453 
     | 
    
         
             
                            oauthConfig: JSON.stringify(this.oauthConfig, null, 2)
         
     | 
| 
       430 
454 
     | 
    
         
             
                          },
         
     | 
| 
         @@ -432,7 +456,7 @@ export default { 
     | 
|
| 
       432 
456 
     | 
    
         
             
                        ),
         
     | 
| 
       433 
457 
     | 
    
         
             
                        making: generateCode(
         
     | 
| 
       434 
458 
     | 
    
         
             
                          {
         
     | 
| 
       435 
     | 
    
         
            -
                            formConfig: JSON.stringify(this. 
     | 
| 
      
 459 
     | 
    
         
            +
                            formConfig: JSON.stringify(this.formConfig, null, 2),
         
     | 
| 
       436 
460 
     | 
    
         
             
                            apiOptions: JSON.stringify(this.apiOptions, null, 2),
         
     | 
| 
       437 
461 
     | 
    
         
             
                            oauthConfig: JSON.stringify(this.oauthConfig, null, 2)
         
     | 
| 
       438 
462 
     | 
    
         
             
                          },
         
     | 
| 
         @@ -440,6 +464,9 @@ export default { 
     | 
|
| 
       440 
464 
     | 
    
         
             
                        )
         
     | 
| 
       441 
465 
     | 
    
         
             
                      };
         
     | 
| 
       442 
466 
     | 
    
         
             
                      break;
         
     | 
| 
      
 467 
     | 
    
         
            +
                    case "importTemplate":
         
     | 
| 
      
 468 
     | 
    
         
            +
                      this.formTemplateActive = null;
         
     | 
| 
      
 469 
     | 
    
         
            +
                      break;
         
     | 
| 
       443 
470 
     | 
    
         | 
| 
       444 
471 
     | 
    
         
             
                    default:
         
     | 
| 
       445 
472 
     | 
    
         
             
                      break;
         
     | 
| 
         @@ -453,6 +480,14 @@ export default { 
     | 
|
| 
       453 
480 
     | 
    
         
             
                  if (this.dialog.action === "importJson") {
         
     | 
| 
       454 
481 
     | 
    
         
             
                    this.handleClick("import-json", JSON.parse(this.dialog.data));
         
     | 
| 
       455 
482 
     | 
    
         
             
                  }
         
     | 
| 
      
 483 
     | 
    
         
            +
                  if (
         
     | 
| 
      
 484 
     | 
    
         
            +
                    this.dialog.action === "importTemplate" &&
         
     | 
| 
      
 485 
     | 
    
         
            +
                    this.formTemplateActive !== null
         
     | 
| 
      
 486 
     | 
    
         
            +
                  ) {
         
     | 
| 
      
 487 
     | 
    
         
            +
                    const list = this.formTemplates[this.formTemplateActive].data.list;
         
     | 
| 
      
 488 
     | 
    
         
            +
                    this.formConfig.list = deepClone(list);
         
     | 
| 
      
 489 
     | 
    
         
            +
                    this.$emit("importTemplate");
         
     | 
| 
      
 490 
     | 
    
         
            +
                  }
         
     | 
| 
       456 
491 
     | 
    
         
             
                  this.handleDialogClose();
         
     | 
| 
       457 
492 
     | 
    
         
             
                },
         
     | 
| 
       458 
493 
     | 
    
         
             
                handleDialogFullscreen() {
         
     | 
| 
         @@ -472,8 +507,8 @@ export default { 
     | 
|
| 
       472 
507 
     | 
    
         
             
                },
         
     | 
| 
       473 
508 
     | 
    
         
             
                handleNetworkConfig() {
         
     | 
| 
       474 
509 
     | 
    
         
             
                  const fieldsApi = {
         
     | 
| 
       475 
     | 
    
         
            -
                    fields: this. 
     | 
| 
       476 
     | 
    
         
            -
                    mounted: this. 
     | 
| 
      
 510 
     | 
    
         
            +
                    fields: this.formConfig.config.fields.api,
         
     | 
| 
      
 511 
     | 
    
         
            +
                    mounted: this.formConfig.config.mounted.api
         
     | 
| 
       477 
512 
     | 
    
         
             
                  };
         
     | 
| 
       478 
513 
     | 
    
         
             
                  const initList = list => {
         
     | 
| 
       479 
514 
     | 
    
         
             
                    for (const item of list) {
         
     | 
| 
         @@ -490,13 +525,16 @@ export default { 
     | 
|
| 
       490 
525 
     | 
    
         
             
                      }
         
     | 
| 
       491 
526 
     | 
    
         
             
                    }
         
     | 
| 
       492 
527 
     | 
    
         
             
                  };
         
     | 
| 
       493 
     | 
    
         
            -
                  initList(this. 
     | 
| 
      
 528 
     | 
    
         
            +
                  initList(this.formConfig.list);
         
     | 
| 
       494 
529 
     | 
    
         
             
                  const apis = Object.values(fieldsApi);
         
     | 
| 
       495 
530 
     | 
    
         
             
                  const network = {};
         
     | 
| 
       496 
531 
     | 
    
         
             
                  this.apiOptions.map(item => {
         
     | 
| 
       497 
532 
     | 
    
         
             
                    if (apis.includes(item.id)) network[item.id] = item;
         
     | 
| 
       498 
533 
     | 
    
         
             
                  });
         
     | 
| 
       499 
     | 
    
         
            -
                  this. 
     | 
| 
      
 534 
     | 
    
         
            +
                  this.formConfig.config.network = network;
         
     | 
| 
      
 535 
     | 
    
         
            +
                },
         
     | 
| 
      
 536 
     | 
    
         
            +
                handleFormTemplateClick(index) {
         
     | 
| 
      
 537 
     | 
    
         
            +
                  this.formTemplateActive = index;
         
     | 
| 
       500 
538 
     | 
    
         
             
                }
         
     | 
| 
       501 
539 
     | 
    
         
             
              }
         
     | 
| 
       502 
540 
     | 
    
         
             
            };
         
     | 
| 
         @@ -520,6 +558,23 @@ export default { 
     | 
|
| 
       520 
558 
     | 
    
         
             
                justify-content: right;
         
     | 
| 
       521 
559 
     | 
    
         
             
              }
         
     | 
| 
       522 
560 
     | 
    
         | 
| 
      
 561 
     | 
    
         
            +
              .formTemplates {
         
     | 
| 
      
 562 
     | 
    
         
            +
                .formTemplates-item {
         
     | 
| 
      
 563 
     | 
    
         
            +
                  display: inline-block;
         
     | 
| 
      
 564 
     | 
    
         
            +
                  margin: 10px;
         
     | 
| 
      
 565 
     | 
    
         
            +
                  padding: 10px;
         
     | 
| 
      
 566 
     | 
    
         
            +
                  width: 230px;
         
     | 
| 
      
 567 
     | 
    
         
            +
                  border-radius: 4px;
         
     | 
| 
      
 568 
     | 
    
         
            +
                  transition: 0.25s;
         
     | 
| 
      
 569 
     | 
    
         
            +
             
     | 
| 
      
 570 
     | 
    
         
            +
                  img {
         
     | 
| 
      
 571 
     | 
    
         
            +
                    width: 100%;
         
     | 
| 
      
 572 
     | 
    
         
            +
                    height: 230px;
         
     | 
| 
      
 573 
     | 
    
         
            +
                    object-fit: contain;
         
     | 
| 
      
 574 
     | 
    
         
            +
                  }
         
     | 
| 
      
 575 
     | 
    
         
            +
                }
         
     | 
| 
      
 576 
     | 
    
         
            +
              }
         
     | 
| 
      
 577 
     | 
    
         
            +
             
     | 
| 
       523 
578 
     | 
    
         
             
              .previewH5 {
         
     | 
| 
       524 
579 
     | 
    
         
             
                width: 300px;
         
     | 
| 
       525 
580 
     | 
    
         
             
                height: 649px;
         
     | 
| 
         @@ -0,0 +1,39 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            {
         
     | 
| 
      
 2 
     | 
    
         
            +
              "name": "空白表单",
         
     | 
| 
      
 3 
     | 
    
         
            +
              "data": {
         
     | 
| 
      
 4 
     | 
    
         
            +
                "list": [],
         
     | 
| 
      
 5 
     | 
    
         
            +
                "config": {
         
     | 
| 
      
 6 
     | 
    
         
            +
                  "fields": {
         
     | 
| 
      
 7 
     | 
    
         
            +
                    "type": "api",
         
     | 
| 
      
 8 
     | 
    
         
            +
                    "api": "",
         
     | 
| 
      
 9 
     | 
    
         
            +
                    "remote": true
         
     | 
| 
      
 10 
     | 
    
         
            +
                  },
         
     | 
| 
      
 11 
     | 
    
         
            +
                  "ui": "element",
         
     | 
| 
      
 12 
     | 
    
         
            +
                  "title": "",
         
     | 
| 
      
 13 
     | 
    
         
            +
                  "width": "",
         
     | 
| 
      
 14 
     | 
    
         
            +
                  "labelWidth": 100,
         
     | 
| 
      
 15 
     | 
    
         
            +
                  "labelPosition": "right",
         
     | 
| 
      
 16 
     | 
    
         
            +
                  "labelSuffix": ":",
         
     | 
| 
      
 17 
     | 
    
         
            +
                  "size": "small",
         
     | 
| 
      
 18 
     | 
    
         
            +
                  "disabled": false,
         
     | 
| 
      
 19 
     | 
    
         
            +
                  "hideLabel": false,
         
     | 
| 
      
 20 
     | 
    
         
            +
                  "mounted": {
         
     | 
| 
      
 21 
     | 
    
         
            +
                    "api": ""
         
     | 
| 
      
 22 
     | 
    
         
            +
                  },
         
     | 
| 
      
 23 
     | 
    
         
            +
                  "eventScript": [
         
     | 
| 
      
 24 
     | 
    
         
            +
                    {
         
     | 
| 
      
 25 
     | 
    
         
            +
                      "id": "mounted",
         
     | 
| 
      
 26 
     | 
    
         
            +
                      "label": "mounted",
         
     | 
| 
      
 27 
     | 
    
         
            +
                      "value": ""
         
     | 
| 
      
 28 
     | 
    
         
            +
                    },
         
     | 
| 
      
 29 
     | 
    
         
            +
                    {
         
     | 
| 
      
 30 
     | 
    
         
            +
                      "id": "refresh",
         
     | 
| 
      
 31 
     | 
    
         
            +
                      "label": "refresh",
         
     | 
| 
      
 32 
     | 
    
         
            +
                      "value": ""
         
     | 
| 
      
 33 
     | 
    
         
            +
                    }
         
     | 
| 
      
 34 
     | 
    
         
            +
                  ],
         
     | 
| 
      
 35 
     | 
    
         
            +
                  "network": {}
         
     | 
| 
      
 36 
     | 
    
         
            +
                }
         
     | 
| 
      
 37 
     | 
    
         
            +
              },
         
     | 
| 
      
 38 
     | 
    
         
            +
              "img": ""
         
     | 
| 
      
 39 
     | 
    
         
            +
            }
         
     |