소스 검색

增加配置管理加载的 loading

yanglzh 3 달 전
부모
커밋
38c3dfbfaa
2개의 변경된 파일189개의 추가작업 그리고 182개의 파일을 삭제
  1. 164 161
      src/views/system/basicConfig/basic.vue
  2. 25 21
      src/views/system/basicConfig/safe.vue

+ 164 - 161
src/views/system/basicConfig/basic.vue

@@ -1,196 +1,199 @@
 <template>
-	<el-form :model="state.tableData.param" label-position="top" ref="queryRef" inline label-width="100px">
-		<div class="form-inner-wrap">
-			<div class="left-wrap">
-				<el-form-item label="系统名称" prop="name">
-					<el-input v-model="state.info.name" placeholder="请输入系统名称" clearable />
-				</el-form-item>
-				<el-form-item label="系统简称" prop="abbreviation">
-					<el-input v-model="state.info.abbreviation" placeholder="请输入系统简称" clearable />
-				</el-form-item>
-				<el-form-item label="系统版权" prop="copyright">
-					<el-input v-model="state.info.copyright" placeholder="请输入系统版权" clearable />
-				</el-form-item>
-				<el-row>
-					<el-col :span="12">
-						<el-form-item label="系统LOGO" prop="logo">
-							<uploadVue accept=".jpg,.png,.jpeg,.gif,.svg" :name="'logo'" @set-img="setImg">
-								<el-image style="width: 100%;min-width: 100px;min-height: 100px;" :src="state.info.logo" fit="contain">
-									<template #error>
-										<div class="image-slot">
-											<ele-Picture style="width: 26px;" />
-											图片加载失败
-										</div>
-									</template>
-								</el-image>
-							</uploadVue>
-						</el-form-item>
-					</el-col>
+  <el-form :model="state.tableData.param" label-position="top" ref="queryRef" inline label-width="100px" v-loading="loading">
+    <div class="form-inner-wrap">
+      <div class="left-wrap">
+        <el-form-item label="系统名称" prop="name">
+          <el-input v-model="state.info.name" placeholder="请输入系统名称" clearable />
+        </el-form-item>
+        <el-form-item label="系统简称" prop="abbreviation">
+          <el-input v-model="state.info.abbreviation" placeholder="请输入系统简称" clearable />
+        </el-form-item>
+        <el-form-item label="系统版权" prop="copyright">
+          <el-input v-model="state.info.copyright" placeholder="请输入系统版权" clearable />
+        </el-form-item>
+        <el-row>
+          <el-col :span="12">
+            <el-form-item label="系统LOGO" prop="logo">
+              <uploadVue accept=".jpg,.png,.jpeg,.gif,.svg" :name="'logo'" @set-img="setImg">
+                <el-image style="width: 100%; min-width: 100px; min-height: 100px" :src="state.info.logo" fit="contain">
+                  <template #error>
+                    <div class="image-slot">
+                      <ele-Picture style="width: 26px" />
+                      图片加载失败
+                    </div>
+                  </template>
+                </el-image>
+              </uploadVue>
+            </el-form-item>
+          </el-col>
 
-					<el-col :span="12">
-						<el-form-item label="系统LOGO(小图标)" prop="mini">
-							<uploadVue accept=".jpg,.png,.jpeg,.gif,.svg" :name="'mini'" @set-img="setImg">
-								<el-image style="width: 100%;min-width: 100px;min-height: 100px;" :src="state.info.mini" fit="contain">
-									<template #error>
-										<div class="image-slot">
-											<ele-Picture style="width: 26px;" />
-											图片加载失败
-										</div>
-									</template>
-								</el-image>
-							</uploadVue>
-						</el-form-item>
-					</el-col>
-				</el-row>
-				<el-form-item>
-					<el-button v-auth="'save'" type="primary" class="ml10" @click="setDetails">保存</el-button>
-				</el-form-item>
-			</div>
-			<div class="right-wrap">
-				<el-form-item label="登录展示图" prop="pic">
-					<uploadVue accept=".jpg,.png,.jpeg,.gif,.svg" :name="'pic'" @set-img="setImg">
-						<el-image style="width: 100%;min-width: 100px;min-height: 100px;" :src="state.info.pic" fit="contain">
-							<template #error>
-								<div class="image-slot">
-									<ele-Picture style="width: 26px;" />
-									图片加载失败
-								</div>
-							</template>
-						</el-image>
-					</uploadVue>
-				</el-form-item>
-			</div>
-		</div>
-	</el-form>
+          <el-col :span="12">
+            <el-form-item label="系统LOGO(小图标)" prop="mini">
+              <uploadVue accept=".jpg,.png,.jpeg,.gif,.svg" :name="'mini'" @set-img="setImg">
+                <el-image style="width: 100%; min-width: 100px; min-height: 100px" :src="state.info.mini" fit="contain">
+                  <template #error>
+                    <div class="image-slot">
+                      <ele-Picture style="width: 26px" />
+                      图片加载失败
+                    </div>
+                  </template>
+                </el-image>
+              </uploadVue>
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-form-item>
+          <el-button v-auth="'save'" type="primary" class="ml10" @click="setDetails">保存</el-button>
+        </el-form-item>
+      </div>
+      <div class="right-wrap">
+        <el-form-item label="登录展示图" prop="pic">
+          <uploadVue accept=".jpg,.png,.jpeg,.gif,.svg" :name="'pic'" @set-img="setImg">
+            <el-image style="width: 100%; min-width: 100px; min-height: 100px" :src="state.info.pic" fit="contain">
+              <template #error>
+                <div class="image-slot">
+                  <ele-Picture style="width: 26px" />
+                  图片加载失败
+                </div>
+              </template>
+            </el-image>
+          </uploadVue>
+        </el-form-item>
+      </div>
+    </div>
+  </el-form>
 </template>
 
 <script lang="ts" setup>
-import { reactive, onMounted, ref } from 'vue';
-import { ElMessage } from 'element-plus';
-import api from '/@/api/system';
-import uploadVue from '/@/components/upload-wrapper/index.vue';
+import { reactive, onMounted, ref } from "vue";
+import { ElMessage } from "element-plus";
+import api from "/@/api/system";
+import uploadVue from "/@/components/upload-wrapper/index.vue";
 
+const loading = ref(true);
 
 const queryRef = ref();
 const state = reactive({
-	ids: [],
-	info: {
-		name: "",
-		copyright: "",
-		accesskey: "",
-		secretkey: "",
-		abbreviation: "",
-		logo: "",
-		mini: "",
-		pic: ""
-	},
-	data: [],
-	tableData: {
-		data: [],
-		loading: false,
-		param: {
-			pageNum: 1,
-			pageSize: 20,
-			status: -1,
-			keyWord: ""
-		},
-		total: 0
-	},
+  ids: [],
+  info: {
+    name: "",
+    copyright: "",
+    accesskey: "",
+    secretkey: "",
+    abbreviation: "",
+    logo: "",
+    mini: "",
+    pic: "",
+  },
+  data: [],
+  tableData: {
+    data: [],
+    loading: false,
+    param: {
+      pageNum: 1,
+      pageSize: 20,
+      status: -1,
+      keyWord: "",
+    },
+    total: 0,
+  },
 });
 // 初始化表格数据
 const initBasicConfigInfo = () => {
-	queryBasicConfigInfo();
+  queryBasicConfigInfo();
 };
 const queryBasicConfigInfo = () => {
-	state.tableData.loading = true
-	api.basicConfig.getDetails({ types: 0 }).then((res: any) => {
-		state.data = res.data;
-		res.data.forEach((element: any) => {
-			if (element.configName == '系统名称') {
-				state.info.name = element.configValue
-			} else if (element.configName == '系统版权') {
-				state.info.copyright = element.configValue
-			} else if (element.configName == '系统LOGO') {
-				state.info.logo = element.configValue
-			} else if (element.configName == '系统LOGO(小图标)') {
-				state.info.mini = element.configValue
-			} else if (element.configName == '登录展示图') {
-				state.info.pic = element.configValue
-			} else if (element.configName == '系统简称') {
-				state.info.abbreviation = element.configValue
-			}
-		});
-	});
+  state.tableData.loading = true;
+  api.basicConfig
+    .getDetails({ types: 0 })
+    .then((res: any) => {
+      state.data = res.data;
+      res.data.forEach((element: any) => {
+        if (element.configName == "系统名称") {
+          state.info.name = element.configValue;
+        } else if (element.configName == "系统版权") {
+          state.info.copyright = element.configValue;
+        } else if (element.configName == "系统LOGO") {
+          state.info.logo = element.configValue;
+        } else if (element.configName == "系统LOGO(小图标)") {
+          state.info.mini = element.configValue;
+        } else if (element.configName == "登录展示图") {
+          state.info.pic = element.configValue;
+        } else if (element.configName == "系统简称") {
+          state.info.abbreviation = element.configValue;
+        }
+      });
+    })
+    .finally(() => {
+      loading.value = false;
+    });
 };
 
 const setDetails = () => {
-	if (!state.info.name) {
-		ElMessage.error('请填写系统名称');
-		return;
-	}
-	if (!state.info.copyright) {
-		ElMessage.error('请填写系统版权');
-		return;
-	}
-	if (!state.info.logo) {
-		ElMessage.error('请上传系统LOGO');
-		return;
-	}
+  if (!state.info.name) {
+    ElMessage.error("请填写系统名称");
+    return;
+  }
+  if (!state.info.copyright) {
+    ElMessage.error("请填写系统版权");
+    return;
+  }
+  if (!state.info.logo) {
+    ElMessage.error("请上传系统LOGO");
+    return;
+  }
 
-	if (!state.info.mini) {
-		ElMessage.error('请上传LOGO(小图标)');
-		return;
-	} if (!state.info.pic) {
-		ElMessage.error('请上传登录展示图');
-		return;
-	}
-	state.data.forEach((element: any) => {
-		if (element.configName == '系统名称') {
-			element.configValue = state.info.name
-		} else if (element.configName == '系统版权') {
-			element.configValue = state.info.copyright
-		} else if (element.configName == '系统LOGO') {
-			element.configValue = state.info.logo
-		} else if (element.configName == '系统LOGO(小图标)') {
-			element.configValue = state.info.mini
-		} else if (element.configName == '登录展示图') {
-			element.configValue = state.info.pic
-		} else if (element.configName == '系统简称') {
-			element.configValue = state.info.abbreviation
-		}
-	})
-	api.basicConfig.setDetails({ ConfigInfo: state.data }).then(() => {
-		ElMessage.success('设置成功');
-
-	});
+  if (!state.info.mini) {
+    ElMessage.error("请上传LOGO(小图标)");
+    return;
+  }
+  if (!state.info.pic) {
+    ElMessage.error("请上传登录展示图");
+    return;
+  }
+  state.data.forEach((element: any) => {
+    if (element.configName == "系统名称") {
+      element.configValue = state.info.name;
+    } else if (element.configName == "系统版权") {
+      element.configValue = state.info.copyright;
+    } else if (element.configName == "系统LOGO") {
+      element.configValue = state.info.logo;
+    } else if (element.configName == "系统LOGO(小图标)") {
+      element.configValue = state.info.mini;
+    } else if (element.configName == "登录展示图") {
+      element.configValue = state.info.pic;
+    } else if (element.configName == "系统简称") {
+      element.configValue = state.info.abbreviation;
+    }
+  });
+  api.basicConfig.setDetails({ ConfigInfo: state.data }).then(() => {
+    ElMessage.success("设置成功");
+  });
 };
 
 const setImg = (img: string, name: string) => {
-	state.info[name] = img;
-}
+  state.info[name] = img;
+};
 
 // 页面加载时
 onMounted(() => {
-	initBasicConfigInfo();
+  initBasicConfigInfo();
 });
-
 </script>
 
-
 <style scoped lang="scss">
 :deep(.el-form) {
-	width: 100%;
+  width: 100%;
 }
 
 :deep(.form-inner-wrap) {
-	width: 100%;
-	display: flex;
-	justify-content: space-between;
-
-	.left-wrap,
-	.right-wrap {
-		width: 100%;
-	}
+  width: 100%;
+  display: flex;
+  justify-content: space-between;
 
+  .left-wrap,
+  .right-wrap {
+    width: 100%;
+  }
 }
 </style>

+ 25 - 21
src/views/system/basicConfig/safe.vue

@@ -1,5 +1,5 @@
 <template>
-	<el-form :model="form" ref="queryRef" label-width="155px">
+	<el-form :model="form" ref="queryRef" label-width="155px" v-loading="loading">
 		<div :style="{ width: '450px' }">
 			<el-descriptions title="安全控制" v-if="form.security!== undefined || form.rsaEnabled!== undefined"></el-descriptions>
 			<el-form-item label="是否启用安全控制" prop="security" v-if="form.security!== undefined">
@@ -111,31 +111,33 @@
 </template>
 
 <script lang="ts" setup>
-import { reactive } from 'vue';
+import { reactive, ref } from 'vue';
 import { ElMessage } from 'element-plus';
 import api from '/@/api/system';
 
 const emailConfigMap: any = {}
 
+const loading = ref(true)
+
 const form = reactive({
-	singleLogin: '',
-	expiryDate: '',
-	refresh: '',
-	uppercase: '',
-	lowercase: '',
-	digit: '',
-	complexity: '',
-	minimum: '',
-	errorNum: '',
-	againLoginDate: '',
-	changePeriod: '',
-	button: '',
-	column: '',
-	api: '',
-	security: '',
-	changePeriodSwitch: '',
-	changePwdFirstLogin: '',
-	rsaEnabled: '',
+	singleLogin: undefined,
+	expiryDate: undefined,
+	refresh: undefined,
+	uppercase: undefined,
+	lowercase: undefined,
+	digit: undefined,
+	complexity: undefined,
+	minimum: undefined,
+	errorNum: undefined,
+	againLoginDate: undefined,
+	changePeriod: undefined,
+	button: undefined,
+	column: undefined,
+	api: undefined,
+	security: undefined,
+	changePeriodSwitch: undefined,
+	changePwdFirstLogin: undefined,
+	rsaEnabled: undefined,
 })
 
 // 是否包含大写字母
@@ -169,7 +171,9 @@ api.basicConfig.getDetails({ types: 1 }).then((res: any) => {
 	form.api = get('sys.api.switch')
 	form.security = get('sys.is.security.control.enabled')
 	form.rsaEnabled = get('sys.is.rsa.enabled')
-});
+}).finally(() => {
+	loading.value = false
+})
 
 function saveEmailConfig() {
 	set('sys.is.single.login', form.singleLogin)