From 671b429b3c000eccf05910452505562f06defa73 Mon Sep 17 00:00:00 2001
From: schangxiang@126.com <schangxiang@126.com>
Date: 周二, 06 5月 2025 07:54:56 +0800
Subject: [PATCH] 222
---
 HIAWms/web/src/components/SettingItem/SettingItem.vue |  117 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 117 insertions(+), 0 deletions(-)
diff --git a/HIAWms/web/src/components/SettingItem/SettingItem.vue b/HIAWms/web/src/components/SettingItem/SettingItem.vue
new file mode 100644
index 0000000..218dab1
--- /dev/null
+++ b/HIAWms/web/src/components/SettingItem/SettingItem.vue
@@ -0,0 +1,117 @@
+<!-- 
+  <SettingItem :title="string?">
+    content
+  </SettingItem>
+ -->
+<template>
+  <div class="setting-item">
+    <el-collapse
+      v-if="props.title"
+      v-model="state.SettingItemModel"
+      :accordion="state.accordion"
+    >
+      <el-collapse-item :title="props.title" :name="props.title">
+        <template #title>
+          <slot name="title" />
+        </template>
+
+        <slot>settingItemCollapse</slot>
+      </el-collapse-item>
+    </el-collapse>
+    <slot v-else>settingItem</slot>
+  </div>
+</template>
+
+<script setup lang="ts">
+import { watch, inject } from 'vue'
+import { state } from './state'
+const isLocal = inject('isLocal')
+
+const props = defineProps({
+  title: {
+    default: '',
+  },
+  /**
+   * 鏄惁鎶樺彔锛岄粯璁alse涓嶆姌鍙�
+   * */
+  fold: {
+    type: Boolean,
+    default: false,
+  },
+})
+
+const initSelect = () => {
+  if (state.accordion) {
+    if (props.title && !state.SettingItemModel) {
+      state.SettingItemModel = props.title
+    }
+  } else {
+    if (isLocal) {
+      if (props.title && !props.fold) {
+        if (Array.isArray(state.SettingItemModel)) {
+          state.SettingItemModel.push(props.title)
+        } else {
+          state.SettingItemModel = [props.title]
+        }
+      }
+    }
+  }
+}
+watch(
+  () => state.init,
+  (val) => {
+    if (val) {
+      initSelect()
+      setTimeout(() => {
+        state.init = false
+      })
+    }
+  },
+  {
+    immediate: true,
+  }
+)
+</script>
+
+<style lang="scss" scoped>
+.setting-item {
+  &::before,
+  &::after {
+    content: '';
+    display: block;
+    margin: 10px;
+    clear: both;
+  }
+
+  min-height: 2em;
+  padding: 0 10px;
+  border: solid 1px #000;
+  border-left: 0;
+  border-right: 0;
+  margin-top: -1px;
+  margin-left: 0;
+  font-size: 12px;
+  color: #949494;
+  :deep(.el-collapse-item__header) {
+    border: 0;
+    width: 100%;
+    cursor: pointer;
+    margin-left: -6px;
+  }
+
+  :deep(.el-collapse-item__content) {
+    padding-bottom: 0;
+    color: #949494;
+  }
+  :deep(.el-collapse-item__arrow) {
+    margin-right: 0;
+  }
+
+  :deep(.cms-el-select-x .el-input__inner) {
+    &::-webkit-input-placeholder {
+      color: #606162;
+      font-weight: bold;
+    }
+  }
+}
+</style>
--
Gitblit v1.9.3