浏览代码

增加产品详情中的接入页面

yanglzh 2 年之前
父节点
当前提交
1ee0788774

+ 2 - 0
src/api/device/index.ts

@@ -5,6 +5,8 @@ export default {
     singleImg: (data: object) => post('/common/singleImg', data),
   },
   product: {
+    // 获取设备接入信息 /product/?id=35
+    connect_intro: (id: string) => get('/product/connect_intro', {id}),
     getList: (params: object) => get('/product/page_list', params),
     getLists: (params: object) => get('/product/list', params),
     add: (data: object) => post('/product/add', data),

+ 67 - 98
src/views/iot/device/product/component/deviceIn.vue

@@ -1,107 +1,76 @@
 <template>
-	<el-form ref="formRef" :model="formData" :rules="ruleForm" label-width="80px" @keyup.enter="onSubmit">
-		<!-- <el-form-item label="上级分类" prop="parentId">
-			<el-cascader :options="typeData" :props="{ checkStrictly: true, multiple: false, emitPath: false, value: 'id', label: 'name' }" placeholder="请选择关联页面" clearable class="w100" v-model="formData.parentId"></el-cascader>
+	<div class="title">接入方式</div>
+	<div class="text">{{ data.name }}</div>
+	<div class="title">消息协议</div>
+	<div class="text">{{ data.protocol }}</div>
+	<div class="title">认证说明</div>
+	<div class="text">{{ data.description }}</div>
+	<div class="title">链接信息</div>
+	<div class="text">{{ data.link }}</div>
+	<div class="title">认证配置</div>
+
+	<template v-if="data.authType === 1 || data.authType === 2">
+		<el-form-item label="认证方式" prop="">
+			<el-radio-group v-model="data.authType">
+				<el-radio :label="1">Basic</el-radio>
+				<el-radio :label="2">AccessToken</el-radio>
+			</el-radio-group>
 		</el-form-item>
-		<el-form-item label="关联页面" prop="menuIds">
-			<el-cascader :options="menuData" :props="{ checkStrictly: false, multiple: true, emitPath: false, value: 'id', label: 'title' }" placeholder="请选择关联页面" clearable class="w100" v-model="formData.menuIds"></el-cascader>
+		<template v-if="data.authType === 1">
+			<el-form-item label="用户名" prop="authUser" label-width="80px">
+				<el-input v-model="data.authUser" readonly  style="width: 300px;" />
+			</el-form-item>
+			<el-form-item label="密码" prop="authPasswd" label-width="80px">
+				<el-input v-model="data.authPasswd" readonly style="width: 300px;" />
+			</el-form-item>
+		</template>
+		<template v-else>
+			<el-form-item label="Aceess Token" prop="accessToken">
+				<el-input v-model="data.accessToken" readonly/>
+			</el-form-item>
+		</template>
+	</template>
+	<template v-else-if="data.authType === 3">
+		<el-form-item label="认证证书" prop="certificateId">
+			<el-select v-model="data.certificateId" disabled>
+				<el-option v-for="cert in certList" :key="cert.id" :label="cert.name" :value="cert.id"> </el-option>
+			</el-select>
 		</el-form-item>
-		<el-form-item label="接口名称" prop="name">
-			<el-input v-model="formData.name" placeholder="输入接口名称" />
-		</el-form-item>
-		<el-form-item label="接口地址" prop="address">
-			<el-input v-model="formData.address" placeholder="接口地址" />
-		</el-form-item> -->
-	</el-form>
+	</template>
 </template>
 
 <script lang="ts" setup>
 import { ref, reactive, nextTick, watch } from 'vue';
-import api from '/@/api/system';
-import { ApiRow } from '/@/api/model/system/menu';
-import { ruleRequired } from '/@/utils/validator';
-import { ElMessage } from 'element-plus';
-import apiDatahub from '/@/api/datahub';
-
-// TODO 这个页面还没开始开发
-
-const emit = defineEmits(['getList']);
-
-const showDialog = ref(false);
-const formRef = ref();
-const menuData = ref<any[]>([]);
-const typeData = ref<any[]>([]);
-const methodOptions = ref<any[]>([]);
-
-const baseForm: ApiRow = {
-	menuIds: [],
-	id: undefined,
-	parentId: undefined,
-	name: '',
-	types: 2,
-	address: '',
-	method: '',
-	remark: '',
-	status: 1,
-};
-
-const formData = reactive<ApiRow>({
-	...baseForm,
-});
-
-// 切换分类时清空上级分类的选择。因为接口里不能选择跟分类节点
-watch(
-	() => formData.types,
-	() => {
-		formData.parentId = undefined;
-	}
-);
-
-const ruleForm = {
-	parentId: [ruleRequired('上级分类不能为空', 'change')],
-	menuIds: [ruleRequired('关联页面不能为空', 'change')],
-	method: [ruleRequired('请求方式不能为空', 'change')],
-	name: [ruleRequired('接口名称不能为空')],
-	address: [ruleRequired('接口地址不能为空')],
-};
-
-apiDatahub.template.getDictData({ DictType: 'api_methods' }).then((res: any) => {
-	methodOptions.value = res.values;
-});
-
-// 加载菜单列表
-api.menu.getList({ status: -1 }).then((res: any[]) => {
-	menuData.value = res;
-});
-
-const onSubmit = async () => {
-	await formRef.value.validate();
-
-	const theApi = formData.id ? api.api.edit : api.api.add;
-
-	await theApi(formData);
-
-	ElMessage.success('操作成功');
-	resetForm();
-	showDialog.value = false;
-	emit('getList');
-};
-
-const resetForm = async () => {
-	Object.assign(formData, { ...baseForm });
-	formRef.value && formRef.value.resetFields();
-};
-
-const open = async (row: any) => {
-	resetForm();
-	showDialog.value = true;
-	api.api.getList({ types: 1, status: -1 }).then((res: any) => {
-		typeData.value = res.Info;
-	});
-	nextTick(() => {
-		Object.assign(formData, { method: methodOptions.value.length ? methodOptions.value[0].value : '', ...row });
-	});
-};
+import api from '/@/api/device';
+import { useRoute } from 'vue-router';
+
+const route = useRoute();
+
+const certList = ref([])
+const data = reactive({
+	"name": "",
+	"protocol": "",
+	"description": "",
+	"link": "",
+	"authType": 0,
+	"authUser": "",
+	"authPasswd": "",
+	"accessToken": "",
+	"certificateId": 0
+})
+
+api.product.connect_intro(route.params.id as string).then((res: any) => {
+	console.log(res.data)
+	Object.assign(data, res.data)
+})
 
-defineExpose({ open });
 </script>
+<style lang="scss" scoped>
+.title {
+	font-weight: bold;
+	line-height: 1.2;
+	border-left: 4px solid #409eff;
+	padding-left: 8px;
+	margin: 20px 0 14px;
+}
+</style>

+ 0 - 558
src/views/iot/device/product/component/editEvent copy.vue

@@ -1,558 +0,0 @@
-<template>
-	<div class="system-edit-dic-container">
-		<el-dialog :title="(ruleForm.id !== 0 ? '修改' : '添加') + '事件定义'" v-model="isShowDialog" width="769px">
-			<el-form :model="ruleForm" ref="formRef" :rules="rules" size="default" label-width="120px">
-				<el-form-item label="事件定义标识" prop="key">
-					<el-input v-model="ruleForm.key" placeholder="请输入事件定义标识" :disabled="ruleForm.id !== 0 ? true : false" />
-				</el-form-item>
-				<el-form-item label="事件定义名称" prop="name">
-					<el-input v-model="ruleForm.name" placeholder="请输入事件定义名称" />
-				</el-form-item>
-
-				<el-form-item label="事件级别" prop="level">
-					<el-radio-group v-model="ruleForm.level">
-						<el-radio :label="0">普通</el-radio>
-						<el-radio :label="1">警告</el-radio>
-						<el-radio :label="2">紧急</el-radio>
-					</el-radio-group>
-				</el-form-item>
-
-				<el-form-item label="输出参数" prop="maxLength">
-					<div v-for="(item, index) in inputsdata" :key="index" class="jslist">
-						<div class="jsonlist">
-							<div>参数名称:</div>
-							<div style="width: 60%">{{ item.name }}</div>
-							<div class="jsonoption">
-								<!-- <el-link type="primary">编辑</el-link> -->
-								<el-link type="primary" @click="deljson(index, 'fun')">删除</el-link>
-							</div>
-						</div>
-					</div>
-
-					<div style="display: block; width: 100%">
-						<div class="input-options" @click="addJson('fun')">
-							<el-icon>
-								<Plus />
-							</el-icon>
-							<div>添加参数</div>
-						</div>
-					</div>
-				</el-form-item>
-
-				<el-form-item label="输出参数" prop="type">
-					<el-select v-model="valueType.type" placeholder="请选择数据类型" @change="seletChange">
-						<el-option-group v-for="group in typeData" :key="group.label" :label="group.label">
-							<el-option v-for="item in group.options" :key="item.type" :label="item.title" :value="item.type" />
-						</el-option-group>
-					</el-select>
-				</el-form-item>
-
-				<!--根据数据类型输出不同表单-->
-
-				<el-form-item label="精度" prop="decimals" v-if="type == 'float' || type == 'double'">
-					<el-input v-model="valueType.decimals" placeholder="请输入精度" />
-				</el-form-item>
-
-				<el-form-item label="单位" prop="unit" v-if="type == 'int' || type == 'long' || type == 'float' || type == 'double'">
-					<el-input v-model="valueType.unit" placeholder="请输入单位" />
-				</el-form-item>
-
-				<el-form-item label="最大长度" prop="maxLength" v-if="type == 'string'">
-					<el-input v-model="valueType.maxLength" placeholder="请输入最大长度" />
-				</el-form-item>
-
-				<el-form-item label="时间格式" prop="maxLength" v-if="type == 'date'">
-					<el-input v-model="valueType.maxLength" placeholder="请输入时间格式" />
-				</el-form-item>
-
-				<el-form-item label="布尔值" prop="trueText" v-if="type == 'boolean'">
-					<div class="input-box">
-						<el-input v-model="valueType.trueText" placeholder="请输入布尔值" value="是" /><span style="margin: 0px 10px">~</span>
-						<el-input v-model="valueType.trueValue" placeholder="请输入布尔值" value="true" />
-					</div>
-
-					<div class="input-box">
-						<el-input v-model="valueType.falseText" placeholder="请输入布尔值" value="否" /> <span style="margin: 0px 10px">~</span>
-						<el-input v-model="valueType.falseValue" placeholder="请输入布尔值" value="false" />
-					</div>
-				</el-form-item>
-
-				<el-form-item label="枚举项" prop="maxLength" v-if="type == 'enum'">
-					<div class="input-box" v-for="(item, index) in enumdata" :key="index">
-						<el-input v-model="item.text" placeholder="请输入枚举文本" /><span style="margin: 0px 10px"><el-icon>
-								<Right />
-							</el-icon></span>
-						<el-input v-model="item.value" placeholder="请输入枚举值" />
-						<div class="input-option">
-							<el-icon @click="addEnum" v-if="index == 0">
-								<Plus />
-							</el-icon>
-							<el-icon @click="delEnum(index)" v-if="index != 0">
-								<Minus />
-							</el-icon>
-						</div>
-					</div>
-				</el-form-item>
-
-				<el-form-item label="JSON对象" prop="maxLength" v-if="type == 'object'">
-					<div v-for="(item, index) in jsondata" :key="index" class="jslist">
-						<div class="jsonlist">
-							<div>参数名称:</div>
-							<div style="width: 60%">{{ item.name }}</div>
-							<div class="jsonoption">
-								<!-- <el-link type="primary">编辑</el-link> -->
-								<el-link type="primary" @click="deljson(index)">删除</el-link>
-							</div>
-						</div>
-					</div>
-
-					<div style="display: block; width: 100%">
-						<div class="input-options" @click="addJson">
-							<el-icon>
-								<Plus />
-							</el-icon>
-							<div>添加参数</div>
-						</div>
-					</div>
-				</el-form-item>
-
-				<div v-if="type == 'array'">
-					<el-form-item label="元素类型" prop="types">
-						<el-select v-model="elementType.type" placeholder="请选择元素类型" @change="seletChanges">
-							<el-option-group v-for="group in typeData" :key="group.label" :label="group.label">
-								<el-option v-for="item in group.options" :key="item.type" :label="item.title" :value="item.type" :disabled="item.type == 'array'" />
-							</el-option-group>
-						</el-select>
-					</el-form-item>
-
-					<el-form-item label="精度" prop="decimals" v-if="types == 'float' || types == 'double'">
-						<el-input v-model="elementType.decimals" placeholder="请输入精度" />
-					</el-form-item>
-
-					<el-form-item label="单位" prop="unit" v-if="types == 'int' || types == 'long' || types == 'float' || types == 'double'">
-						<el-input v-model="elementType.unit" placeholder="请输入单位" />
-					</el-form-item>
-
-					<el-form-item label="最大长度" prop="maxLength" v-if="types == 'string'">
-						<el-input v-model="elementType.maxLength" placeholder="请输入最大长度" />
-					</el-form-item>
-
-					<el-form-item label="时间格式" prop="maxLength" v-if="types == 'date'">
-						<el-input v-model="elementType.maxLength" placeholder="请输入时间格式" />
-					</el-form-item>
-
-					<el-form-item label="布尔值" prop="maxLength" v-if="types == 'boolean'">
-						<div class="input-box">
-							<el-input v-model="elementType.trueText" placeholder="请输入布尔值" value="是" /><span style="margin: 0px 10px">~</span>
-							<el-input v-model="elementType.trueValue" placeholder="请输入布尔值" value="true" />
-						</div>
-
-						<div class="input-box">
-							<el-input v-model="elementType.falseText" placeholder="请输入布尔值" value="否" /> <span style="margin: 0px 10px">~</span>
-							<el-input v-model="elementType.falseValue" placeholder="请输入布尔值" value="false" />
-						</div>
-					</el-form-item>
-
-					<el-form-item label="枚举项" prop="maxLength" v-if="types == 'enum'">
-						<div class="input-box" v-for="(item, index) in enumdata" :key="index">
-							<el-input v-model="item.text" placeholder="请输入枚举值" /><span style="margin: 0px 10px"><el-icon>
-									<Right />
-								</el-icon></span>
-							<el-input v-model="item.value" placeholder="请输入枚举文本" />
-							<div class="input-option">
-								<el-icon @click="addEnum" v-if="index == 0">
-									<Plus />
-								</el-icon>
-								<el-icon @click="delEnum(index)" v-if="index != 0">
-									<Minus />
-								</el-icon>
-							</div>
-						</div>
-					</el-form-item>
-				</div>
-
-				<el-form-item label="JSON对象" prop="maxLength" v-if="types == 'object'">
-					<div v-for="(item, index) in jsondata" :key="index" class="jslist">
-						<div class="jsonlist">
-							<div>参数名称:</div>
-							<div style="width: 60%">{{ item.data.name }}</div>
-							<div class="jsonoption">
-								<el-link type="primary">编辑</el-link>
-								<el-link type="primary">删除</el-link>
-							</div>
-						</div>
-					</div>
-
-					<div style="display: block; width: 100%">
-						<div class="input-options" @click="addJson">
-							<el-icon>
-								<Plus />
-							</el-icon>
-							<div>添加参数</div>
-						</div>
-					</div>
-				</el-form-item>
-
-				<!--根据数据类型输出不同表单-->
-
-				<el-form-item label="事件定义描述	" prop="desc">
-					<el-input v-model="ruleForm.desc" type="textarea" placeholder="请输入事件定义描述"></el-input>
-				</el-form-item>
-			</el-form>
-			<template #footer>
-				<span class="dialog-footer">
-					<el-button @click="onCancel" size="default">取 消</el-button>
-					<el-button type="primary" @click="onSubmit" size="default">{{ ruleForm.id !== 0 ? '修 改' : '添 加' }}</el-button>
-				</span>
-			</template>
-		</el-dialog>
-		<EditOption ref="editOptionRef" @typeList="getOptionData" />
-	</div>
-</template>
-
-<script lang="ts">
-import { reactive, toRefs, defineComponent, ref, unref } from 'vue';
-import api from '/@/api/device';
-import uploadVue from '/@/components/upload/index.vue';
-import { Plus, Minus, Right } from '@element-plus/icons-vue';
-import EditOption from './editOption.vue';
-
-import { ElMessage, UploadProps } from 'element-plus';
-
-interface RuleFormState {
-	id: number;
-	productId: number;
-	key: string;
-	level: number;
-	name: string;
-	dictType: string;
-	valueType: Object;
-	status: number;
-	desc: string;
-}
-interface DicState {
-	isShowDialog: boolean;
-	ruleForm: RuleFormState;
-	typeData: RuleFormState[];
-	rules: {};
-}
-
-export default defineComponent({
-	name: 'deviceEditPro',
-	components: { Plus, Minus, Right, EditOption },
-	setup(prop, { emit }) {
-		const formRef = ref<HTMLElement | null>(null);
-		const editOptionRef = ref();
-		const state = reactive<DicState>({
-			isShowDialog: false,
-			typeData: [], //
-			type: '',
-			types: '',
-			productId: 0,
-			valueType: {
-				type: '',
-				maxLength: '',
-				trueText: '是',
-				trueValue: 'true',
-				falseText: '否',
-				falseValue: 'false',
-			},
-			elementType: {
-				type: '',
-				maxLength: '',
-			},
-			enumdata: [
-				{
-					text: '',
-					value: '',
-				},
-			],
-
-			jsondata: [],
-			inputsdata: [],
-			ruleForm: {
-				id: 0,
-				productId: 0,
-				level: 0,
-				name: '',
-				key: '',
-				status: 1,
-				valueType: {
-					type: '',
-					maxLength: '',
-				},
-
-				desc: '',
-			},
-			rules: {
-				name: [{ required: true, message: '事件定义名称不能为空', trigger: 'blur' }],
-				key: [{ required: true, message: '事件定义标识不能为空', trigger: 'blur' }],
-				level: [{ required: true, message: '请选择事件级别', trigger: 'blur' }],
-				type: [{ required: true, message: '请选择数据类型', trigger: 'blur' }],
-			},
-		});
-
-		// 打开弹窗
-		const openDialog = (row: RuleFormState | null, productId: number | null) => {
-			resetForm();
-			api.product.getDataType({ status: -1 }).then((res: any) => {
-				const datat = Object.values(res.dataType);
-				datat.forEach((item, index) => {
-					if (index == 0) {
-						datat[index]['label'] = '基础类型';
-						datat[index]['options'] = item;
-					} else {
-						datat[index]['label'] = '扩展类型';
-						datat[index]['options'] = item;
-					}
-				});
-				console.log(row);
-				console.log(productId);
-				state.typeData = datat || [];
-			});
-			state.ruleForm = row;
-			if (row.valueType) {
-				state.ruleForm = row;
-
-				state.productId = productId;
-				state.valueType = row.valueType;
-				state.ruleForm.valueType.type = row.valueType.type;
-				state.ruleForm.type = row.valueType.type;
-				state.type = row.valueType.type;
-				state.ruleForm.accessMode = row.accessMode;
-				if (row.valueType.elementType) {
-					state.elementType = row.valueType.elementType;
-					state.types = row.valueType.elementType.type;
-				}
-
-				if (row.type == 'enum') {
-					state.enumdata = row.valueType.elements;
-				}
-
-				if (row.type == 'object') {
-					state.jsondata = row.valueType.properties;
-				}
-
-				if (row.type == 'array' && state.types == 'enum') {
-					state.enumdata = row.valueType.elementType.elements;
-				}
-				if (row.type == 'array' && state.types == 'object') {
-					state.jsondata = row.valueType.elementType.properties;
-				}
-			}
-			state.isShowDialog = true;
-		};
-		const resetForm = () => {
-			state.ruleForm = {
-				name: '',
-				key: '',
-				accessMode: '0',
-				status: 1,
-				valueType: {
-					type: '',
-					maxLength: '',
-				},
-
-				desc: '',
-			};
-			state.type = '';
-			state.types = '';
-			state.valueType = {};
-			state.elementType = {};
-			state.jsondata = [];
-			state.enumdata = [
-				{
-					text: '',
-					value: '',
-				},
-			];
-		};
-
-		const seletChange = (val) => {
-			state.type = val;
-			state.ruleForm.type = val;
-
-			console.log(val);
-		};
-		const seletChanges = (val) => {
-			console.log(val);
-			state.types = val;
-			console.log(val);
-		};
-
-		const addEnum = () => {
-			state.enumdata.push({
-				text: '',
-				value: '',
-			});
-		};
-		const delEnum = (index) => {
-			state.enumdata.splice(index, 1);
-		};
-
-		const deljson = (index) => {
-			state.jsondata.splice(index, 1);
-		};
-
-		const addJson = () => {
-			editOptionRef.value.openDialog({ product_id: 0, id: 0 });
-		};
-		const getOptionData = (data) => {
-			state.jsondata.push(data);
-
-			console.log(state.jsondata);
-		};
-		// 关闭弹窗
-		const closeDialog = () => {
-			state.isShowDialog = false;
-		};
-		// 取消
-		const onCancel = () => {
-			closeDialog();
-		};
-		// 新增
-		const onSubmit = () => {
-			const formWrap = unref(formRef) as any;
-			if (!formWrap) return;
-			formWrap.validate((valid: boolean) => {
-				if (valid) {
-					if (state.ruleForm.id !== 0) {
-						//修改
-						if (state.type == 'enum') {
-							state.valueType.elements = state.enumdata;
-						}
-
-						if (state.type == 'object') {
-							state.valueType.properties = state.jsondata;
-						}
-
-						if (state.type == 'array') {
-							state.valueType.elementType = state.elementType;
-							//如果是选中数组,并选择了枚举
-							if (state.types == 'enum') {
-								state.valueType.elementType = {
-									elements: state.enumdata,
-									type: 'enum',
-								};
-							}
-							//如果是选中数组,并选择了object
-							if (state.types == 'object') {
-								state.valueType.elementType = {
-									properties: state.jsondata,
-									type: 'object',
-								};
-							}
-						}
-
-						console.log(state.valueType);
-
-						state.ruleForm.valueType = state.valueType;
-						state.ruleForm.productId = state.productId;
-						api.model.eventedit(state.ruleForm).then(() => {
-							ElMessage.success('事件定义类型修改成功');
-							closeDialog(); // 关闭弹窗
-							emit('typeList');
-						});
-					} else {
-						//添加
-						if (state.type == 'enum') {
-							state.valueType.elements = state.enumdata;
-						}
-
-						if (state.type == 'object') {
-							state.valueType.properties = state.jsondata;
-						}
-
-						if (state.type == 'array') {
-							state.valueType.elementType = state.elementType;
-							//如果是选中数组,并选择了枚举
-							if (state.types == 'enum') {
-								state.valueType.elementType = {
-									elements: state.enumdata,
-									type: 'enum',
-								};
-							}
-							//如果是选中数组,并选择了object
-							if (state.types == 'object') {
-								state.valueType.elementType = {
-									properties: state.jsondata,
-									type: 'object',
-								};
-							}
-						}
-
-						state.ruleForm.valueType = state.valueType;
-						api.model.eventadd(state.ruleForm).then(() => {
-							ElMessage.success('事件定义类型添加成功');
-							closeDialog(); // 关闭弹窗
-							emit('typeList');
-						});
-					}
-				}
-			});
-		};
-
-		return {
-			editOptionRef,
-			getOptionData,
-			openDialog,
-			deljson,
-			addEnum,
-			delEnum,
-			addJson,
-			seletChange,
-			seletChanges,
-			closeDialog,
-			onCancel,
-			onSubmit,
-			formRef,
-			...toRefs(state),
-		};
-	},
-});
-</script>
-<style>
-.input-box {
-	display: flex;
-	flex-direction: row;
-	justify-content: space-between;
-	margin-top: 10px;
-}
-
-.input-option {
-	line-height: 30px;
-	padding-top: 5px;
-	width: 140px;
-}
-
-.input-option i {
-	margin: 0px 5px;
-	border: 1px solid #c3c3c3;
-	font-size: 16px;
-}
-
-.input-options {
-	display: flex;
-	align-items: center;
-	color: #409eff;
-	cursor: pointer;
-}
-
-.jslist {
-	width: 100%;
-	border: 1px solid #e8e8e8;
-	padding: 10px;
-	margin-bottom: 10px;
-}
-
-.jsonlist {
-	display: flex;
-	flex-direction: row;
-	justify-content: space-between;
-}
-
-.jsonoption {}
-
-.jsonoption a {
-	margin: 0px 10px;
-}</style>

+ 2 - 2
src/views/iot/device/product/detail.vue

@@ -412,7 +412,7 @@ export default defineComponent({
 		};
 
 		const handleClick = (tab: TabsPaneContext, event: Event) => {
-			console.log(tab, event);
+			// console.log(tab, event);
 		};
 
 		const updateScript = (scriptInfo: string) => {
@@ -469,7 +469,7 @@ export default defineComponent({
 	},
 });
 </script>
-<style>
+<style scoped>
 .content {
 	background: #fff;
 	width: 100%;