7 changed files with 672 additions and 3 deletions
@ -0,0 +1,309 @@ |
|||
<!-- |
|||
@ 作者: 鲁智强 |
|||
@ 时间: 2023-08-15 11:34:38 |
|||
@ 备注: |
|||
--> |
|||
<template> |
|||
<div class="box"> |
|||
<el-button type="danger" @click="handleBatchDelete">批量删除</el-button> |
|||
<el-button class="new_btn" type="primary" @click="handleNew" |
|||
>新增</el-button |
|||
> |
|||
<el-button type="warning" :icon="Star" circle |
|||
><el-icon><RefreshRight /></el-icon |
|||
></el-button> |
|||
<span class="aaa"> |
|||
<el-form-item label="" style="width: 50"> |
|||
<el-select v-model="form.region" placeholder="请选分厂"> |
|||
<el-option label="请选分厂" value="0"></el-option> |
|||
<el-option label="甲醇分厂" value="1"></el-option> |
|||
<el-option label="化产分厂" value="2"></el-option> |
|||
<el-option label="动力分厂" value="3"></el-option> |
|||
<el-option label="机焦车间" value="4"></el-option> |
|||
<el-option label="质检中心" value="5"></el-option> |
|||
<el-option label="安环部" value="6"></el-option> |
|||
<el-option label="备煤车间" value="7"></el-option> |
|||
<el-option label="保卫部" value="8"></el-option> |
|||
<el-option label="企管部" value="9"></el-option> |
|||
<el-option label="高管" value="10"></el-option> |
|||
<el-option label="综合办" value="11"></el-option> |
|||
<el-option label="人力资源部" value="12"></el-option> |
|||
<el-option label="财务部" value="13"></el-option> |
|||
<el-option label="营销部" value="14"></el-option> |
|||
<el-option label="生产部" value="15"></el-option> |
|||
<el-option label="仓储中心" value="16"></el-option> |
|||
<el-option label="物流中心" value="17"></el-option> |
|||
<el-option label="办公室" value="18"></el-option> |
|||
<el-option label="审计监察部" value="19"></el-option> |
|||
<el-option label="法律事务部" value="20"></el-option> |
|||
<el-option label="财务部" value="21"></el-option> |
|||
<el-option label="供应部" value="22"></el-option> |
|||
<el-option label="销售部" value="23"></el-option> |
|||
<el-option label="生产计划部" value="24"></el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-form-item label=""> |
|||
<el-select v-model="form.section" placeholder="请选工段"> </el-select> |
|||
</el-form-item> |
|||
<el-form-item label=""> |
|||
<el-select v-model="form.position" placeholder="请选职务"> </el-select> |
|||
</el-form-item> |
|||
<el-form-item label=""> |
|||
<el-select v-model="form.column" placeholder="请选栏目"> |
|||
<el-option label="请选栏目" value="0"></el-option> |
|||
<el-option label="流程制度" value="1"></el-option> |
|||
<el-option label="工艺技术" value="2"></el-option> |
|||
<el-option label="设备管理" value="3"></el-option> |
|||
<el-option label="仪控仪表" value="4"></el-option> |
|||
<el-option label="机电维修" value="5"></el-option> |
|||
<el-option label="安全生产" value="6"></el-option> |
|||
<el-option label="质量管理" value="7"></el-option> |
|||
<el-option label="财务管理" value="8"></el-option> |
|||
<el-option label="人力资源" value="9"></el-option> |
|||
<el-option label="仓储物流" value="10"></el-option> |
|||
<el-option label="营销采购" value="11"></el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-input |
|||
v-model="form.name" |
|||
style="width: 170px" |
|||
placeholder="请输入题目" |
|||
></el-input> |
|||
<el-button type="primary" style="width: 80px" @click="onSubmit" |
|||
>查询</el-button |
|||
> |
|||
</span> |
|||
<el-table |
|||
ref="multipleTableRef" |
|||
:data="studentInfo" |
|||
border |
|||
style="width: 100%" |
|||
stripe |
|||
@selection-change="handleSelectionChange" |
|||
> |
|||
<el-table-column type="selection" width="55" /> |
|||
<el-table-column prop="name" label="文章标题" /> |
|||
<el-table-column prop="sex" label="所属栏目" /> |
|||
<el-table-column prop="age" label="可见范围" /> |
|||
<el-table-column prop="num" label="访问数据" width="440" /> |
|||
<el-table-column prop="abc" label="状态" width="120"> |
|||
<template #default="row"> |
|||
<el-switch v-model="row.row.status" /> |
|||
</template> |
|||
</el-table-column> |
|||
<el-table-column fixed="right" label="操作"> |
|||
<template #default="{ row }"> |
|||
<el-button type="success" size="small" @click="handleEdit(row)" |
|||
>修改</el-button |
|||
> |
|||
<el-button type="danger" size="small" @click="handleDel(row)" |
|||
>删除</el-button |
|||
> |
|||
</template> |
|||
</el-table-column> |
|||
</el-table> |
|||
<!-- 新建/编辑弹框 --> |
|||
<Dialog |
|||
v-if="dialogShow" |
|||
v-model:dialogShow="dialogShow" |
|||
:row-info="rowInfo" |
|||
:title="title" |
|||
:array-num="studentInfo.length" |
|||
@addRow="addRow" |
|||
@editRow="editRow" |
|||
@save="handleSave" |
|||
/> |
|||
<!-- 详情弹窗 --> |
|||
<Detail v-if="detailShow" :row-info="rowInfo" @closeDetail="closeDetail" /> |
|||
</div> |
|||
</template> |
|||
|
|||
<script> |
|||
import { reactive, ref, toRefs, computed, onMounted } from "vue"; |
|||
import { countdownEmits, ElMessageBox, ElTable } from "element-plus"; |
|||
import { Timer } from "@element-plus/icons-vue"; |
|||
import Dialog from "./dialog.vue"; |
|||
import Detail from "./detail.vue"; |
|||
export default { |
|||
// eslint-disable-next-line vue/no-reserved-component-names |
|||
components: { Dialog, Detail }, |
|||
setup() { |
|||
const data = reactive({ |
|||
dialogShow: false, // 新增/编辑弹框 |
|||
detailShow: false, // 详情弹窗 |
|||
rowInfo: {}, // 新增/编辑的数据 |
|||
title: "", // 是新建还是修改 |
|||
form: { |
|||
name: "", |
|||
region: "", |
|||
date1: "", |
|||
date2: "", |
|||
delivery: false, |
|||
type: [], |
|||
resource: "", |
|||
desc: "", |
|||
section: "", |
|||
position: "", |
|||
column: "", |
|||
}, |
|||
studentInfo: [ |
|||
{ |
|||
id: 1, |
|||
name: "办公区域6S及办公用品检查通报", |
|||
sex: "其他", |
|||
age: "公开", |
|||
num: "阅读量:195 评论数:0 收藏数:0点赞数:1 踩:1 综合评分:0", |
|||
iop: "1", |
|||
ccc: "", |
|||
ade: "", |
|||
ddd: "", |
|||
}, |
|||
{ |
|||
id: 2, |
|||
name: "山东恒信高科能源有限公司--管理手册", |
|||
sex: "流程制度", |
|||
age: "公开", |
|||
num: "阅读量:14 评论数:0 收藏数:0点赞数:2 踩:0 综合评分:0", |
|||
iop: "2", |
|||
ccc: "", |
|||
ade: "", |
|||
ddd: "", |
|||
}, |
|||
{ |
|||
id: 3, |
|||
name: "山东恒信高科能源有限公司--程序文件汇编", |
|||
sex: "流程制度", |
|||
age: "公开", |
|||
num: " 阅读量:0 评论数:0 收藏数:0点赞数:3 踩:0 综合评分:0", |
|||
iop: "1", |
|||
ccc: "", |
|||
ade: "", |
|||
ddd: "", |
|||
}, |
|||
], |
|||
}); |
|||
const searchName = ref(""); // 用于查询的输入值 |
|||
const filterTableData = computed(() => |
|||
data.studentInfo.filter( |
|||
(item) => !searchName.value || item.name.includes(searchName.value) |
|||
) |
|||
); |
|||
const multipleSelection = ref([]); |
|||
const method = reactive({ |
|||
handleNew() { |
|||
data.title = "新增"; |
|||
data.rowInfo = {}; |
|||
data.dialogShow = true; |
|||
}, |
|||
handleDetail(val) { |
|||
data.detailShow = true; |
|||
data.rowInfo = val; |
|||
}, |
|||
handleEdit(val) { |
|||
data.title = "修改"; |
|||
data.dialogShow = true; |
|||
data.rowInfo = val; |
|||
}, |
|||
handleDel(val) { |
|||
ElMessageBox.confirm("你确定删除这条信息吗?", "提示", { |
|||
confirmButtonText: "确认", |
|||
cancelButtonText: "取消", |
|||
type: "warning", |
|||
}) |
|||
.then(() => { |
|||
method.handleSure(val); |
|||
}) |
|||
.catch(() => { |
|||
// catch error |
|||
}); |
|||
}, |
|||
handleSure(val) { |
|||
this.dialogVisible = false; |
|||
const index = data.studentInfo.findIndex((item) => item.id === val.id); |
|||
data.studentInfo.splice(index, 1); |
|||
}, |
|||
// 添加行 |
|||
addRow(val) { |
|||
data.studentInfo.push(val); |
|||
}, |
|||
// 编辑行 |
|||
editRow(val) { |
|||
let index = data.studentInfo.findIndex( |
|||
(item, index) => item.id === val.id |
|||
); |
|||
data.studentInfo.splice(index, 1, val); |
|||
}, |
|||
// 关闭详情弹窗 |
|||
closeDetail() { |
|||
data.detailShow = false; |
|||
}, |
|||
handleSelectionChange(val) { |
|||
multipleSelection.value = val; |
|||
}, |
|||
handleBatchDelete() { |
|||
if (multipleSelection.value.length === 0) { |
|||
ElMessageBox.alert("请选择要删除的数据", "提示", { |
|||
confirmButtonText: "确定", |
|||
}); |
|||
return; |
|||
} |
|||
|
|||
ElMessageBox.confirm("确定要批量删除所选数据吗?", "提示", { |
|||
confirmButtonText: "确定", |
|||
cancelButtonText: "取消", |
|||
type: "warning", |
|||
}) |
|||
.then(() => { |
|||
data.studentInfo = data.studentInfo.filter( |
|||
(item) => !multipleSelection.value.includes(item) |
|||
); |
|||
multipleSelection.value = []; // Clear selection |
|||
}) |
|||
.catch(() => { |
|||
// 用户取消删除 |
|||
}); |
|||
}, |
|||
handleSave(formData) { |
|||
formData.id = this.studentInfo.length + 1; // Generate a unique ID |
|||
data.studentInfo.push(formData); // Add the new data to the array |
|||
}, |
|||
onSubmit() { |
|||
// 使用查询条件过滤数据 |
|||
const { name, region, section, position, column } = data.form; |
|||
const filteredData = data.studentInfo.filter((item) => { |
|||
return ( |
|||
(!name || item.name.includes(name)) && |
|||
(!region || item.region === region) && |
|||
(!section || item.section === section) && |
|||
(!position || item.position === position) && |
|||
(!column || item.column === column) |
|||
); |
|||
}); |
|||
// 更新过滤后的数据 |
|||
data.filterTableData = filteredData; |
|||
}, |
|||
}); |
|||
return { ...toRefs(data), ...method, ...filterTableData, searchName }; |
|||
}, |
|||
}; |
|||
</script> |
|||
<style lang="scss" scoped> |
|||
.aab { |
|||
display: grid; |
|||
grid-template-columns: repeat(6, 1fr); /* 五列 */ |
|||
align-items: start; /* 顶格对齐 */ |
|||
float: right; |
|||
width: 800px; |
|||
height: 30px; |
|||
background-color: burlywood; |
|||
} |
|||
|
|||
.aaa { |
|||
display: grid; |
|||
grid-template-columns: repeat(6, 1fr); /* 五列 */ |
|||
align-items: start; /* 顶格对齐 */ |
|||
float: right; |
|||
width: 700px; |
|||
height: 30px; |
|||
} |
|||
</style> |
|||
@ -0,0 +1,57 @@ |
|||
<!-- |
|||
@ 作者: 鲁智强 |
|||
@ 时间: 2023-08-15 11:34:38 |
|||
@ 备注: |
|||
--> |
|||
<template> |
|||
<el-dialog :model-value="true" title="详情" @close="handleClose"> |
|||
<p> |
|||
<label for="name">文章标题:</label> |
|||
<span id="name"> {{ studentInfo.name }} </span> |
|||
</p> |
|||
<p> |
|||
<label for="sex">所属范围:</label> |
|||
<span id="sex"> {{ studentInfo.sex }} </span> |
|||
</p> |
|||
<p> |
|||
<label for="age">可见范围:</label> |
|||
<span id="age"> {{ studentInfo.age }} </span> |
|||
</p> |
|||
<p> |
|||
<label for="num">访问数据:</label> |
|||
<span id="num"> {{ studentInfo.age }} </span> |
|||
</p> |
|||
<p> |
|||
<label for="abc">状态:</label> |
|||
<span id="abc"> {{ studentInfo.age }} </span> |
|||
</p> |
|||
</el-dialog> |
|||
</template> |
|||
|
|||
<script> |
|||
import { computed, toRefs } from "vue"; |
|||
export default { |
|||
props: { |
|||
rowInfo: { |
|||
type: Object, |
|||
default() { |
|||
return {}; |
|||
}, |
|||
}, |
|||
}, |
|||
emit: ["closeDetail"], |
|||
setup(props, { emit }) { |
|||
const data = { |
|||
studentInfo: computed(() => props.rowInfo).value, |
|||
}; |
|||
const method = { |
|||
handleClose() { |
|||
emit("closeDetail"); |
|||
}, |
|||
}; |
|||
return { ...toRefs(data), ...method }; |
|||
}, |
|||
}; |
|||
</script> |
|||
|
|||
<style lang="less" scoped></style> |
|||
@ -0,0 +1,269 @@ |
|||
<!-- |
|||
@ 作者: 鲁智强 |
|||
@ 时间: 2023-08-15 11:34:38 |
|||
@ 备注: |
|||
--> |
|||
<template> |
|||
<el-dialog :model-value="true" :title="title" @close="handleClose"> |
|||
<Editor v-model="editContvalue" style="height: calc(100vh - 124px)" /> |
|||
<el-form |
|||
ref="ruleFormRef" |
|||
:model="formData" |
|||
label-width="120px" |
|||
class="demo-ruleForm" |
|||
> |
|||
<el-form-item label="文章标题:" prop="name" :rules="nameRules"> |
|||
<el-input v-model="formData.name" placeholder="请输入标题"></el-input> |
|||
</el-form-item> |
|||
<el-form-item label="所属栏目:" prop="sex"> |
|||
<el-select v-model="formData.sex"> |
|||
<el-option label="工艺技术" value="工艺技术" /> |
|||
<el-option label="流程制度" value="流程制度" /> |
|||
<el-option label="设备管理" value="设备管理" /> |
|||
<el-option label="仪控仪表" value="仪控仪表" /> |
|||
<el-option label="机电维修" value="机电维修" /> |
|||
<el-option label="安全生产" value="安全生产" /> |
|||
<el-option label="质量管理" value="质量管理" /> |
|||
<el-option label="财务管理" value="财务管理" /> |
|||
<el-option label="人力资源" value="人力资源" /> |
|||
<el-option label="仓储物流" value="仓储物流" /> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-form-item label="文档来源"> |
|||
<el-radio-group v-model="formData.iop"> |
|||
<el-radio label="1" size="large" border>原创</el-radio> |
|||
<el-radio label="2" size="large" border>转贴</el-radio> |
|||
</el-radio-group> |
|||
</el-form-item> |
|||
<el-form-item label="上传封面"> |
|||
<el-upload action="#" list-type="picture-card" :auto-upload="false"> |
|||
<el-icon><Plus /></el-icon> |
|||
<template #file="{ file }"> |
|||
<div> |
|||
<img |
|||
class="el-upload-list__item-thumbnail" |
|||
:src="file.url" |
|||
alt="" |
|||
/> |
|||
<span class="el-upload-list__item-actions"> |
|||
<span |
|||
class="el-upload-list__item-preview" |
|||
@click="handlePictureCardPreview(file)" |
|||
> |
|||
<el-icon><zoom-in /></el-icon> |
|||
</span> |
|||
<span |
|||
v-if="!disabled" |
|||
class="el-upload-list__item-delete" |
|||
@click="handleDownload(file)" |
|||
> |
|||
<el-icon><Download /></el-icon> |
|||
</span> |
|||
<span |
|||
v-if="!disabled" |
|||
class="el-upload-list__item-delete" |
|||
@click="handleRemove(file)" |
|||
> |
|||
<el-icon><Delete /></el-icon> |
|||
</span> |
|||
</span> |
|||
</div> |
|||
</template> |
|||
</el-upload> |
|||
</el-form-item> |
|||
<el-form-item label="文档标签:"> |
|||
<el-input |
|||
v-model="formData.ccc" |
|||
placeholder="请输入文本文档,每个标签请用,隔开!" |
|||
/> |
|||
</el-form-item> |
|||
<el-form-item label="文档描述:"> |
|||
<el-input |
|||
v-model="formData.ade" |
|||
:autosize="{ minRows: 2, maxRows: 4 }" |
|||
type="textarea" |
|||
placeholder="对于本次检查发现的问题,望相关责任单位安排专人严格按照时间节点及要求进行整改,整改后及时回复。企管部、综合办进行复查。" |
|||
/> |
|||
</el-form-item> |
|||
<el-form-item label="附件下载:"> |
|||
<el-switch v-model="childBorder" /> |
|||
</el-form-item> |
|||
<el-form-item label="排序:"> |
|||
<el-input |
|||
v-model="formData.ddd" |
|||
style="width: 200px" |
|||
placeholder="请输入文档序号" |
|||
/> |
|||
</el-form-item> |
|||
<el-form-item label="评论设置:"> |
|||
<el-switch v-model="parentBorder" placeholder="启用" /> |
|||
</el-form-item> |
|||
<el-form-item label="访问权限:" prop="age"> |
|||
<el-radio-group v-model="formData.age"> |
|||
<el-radio :label="'公开'">公开</el-radio> |
|||
<el-radio :label="'分厂'">分厂</el-radio> |
|||
<el-radio :label="'工段'">工段</el-radio> |
|||
<el-radio :label="'自定义'">自定义</el-radio> |
|||
</el-radio-group> |
|||
</el-form-item> |
|||
<el-form-item> |
|||
<el-button type="primary" @click="submitForm()">确定</el-button> |
|||
<el-button @click="resetForm()">重置</el-button> |
|||
</el-form-item> |
|||
</el-form> |
|||
</el-dialog> |
|||
</template> |
|||
<script lang="ts"> |
|||
import { reactive, toRefs, ref, onMounted } from "vue"; |
|||
import { Delete, Download, Plus, ZoomIn } from "@element-plus/icons-vue"; |
|||
import { ElMessage } from "element-plus"; |
|||
import type { UploadProps, UploadFile } from "element-plus"; |
|||
import Editor from "@/components/WangEditor/index.vue"; |
|||
interface FormInfo { |
|||
id: string; |
|||
age: string; |
|||
name: string; |
|||
sex: string; |
|||
ccc: string; |
|||
ade: string; |
|||
iop: string; |
|||
ddd: string; |
|||
} |
|||
const childBorder = ref(false); |
|||
const parentBorder = ref(false); |
|||
const editContvalue = ref("初始内容"); |
|||
const dialogImageUrl = ref(""); |
|||
const dialogVisible = ref(false); |
|||
const disabled = ref(false); |
|||
const imageUrl = ref(""); |
|||
const handleRemove = (file: UploadFile) => { |
|||
console.log(file); |
|||
}; |
|||
const handlePictureCardPreview = (file: UploadFile) => { |
|||
dialogImageUrl.value = file.url!; |
|||
dialogVisible.value = true; |
|||
}; |
|||
const handleDownload = (file: UploadFile) => { |
|||
console.log(file); |
|||
}; |
|||
const nameRules = [ |
|||
{ required: true, message: "文章标题不能为空", trigger: "blur" }, |
|||
// Other validation rules for the name field |
|||
]; |
|||
const handleAvatarSuccess: UploadProps["onSuccess"] = ( |
|||
response, |
|||
uploadFile |
|||
) => { |
|||
imageUrl.value = URL.createObjectURL(uploadFile.raw!); |
|||
}; |
|||
export default { |
|||
props: { |
|||
title: { |
|||
type: String, |
|||
default: "", |
|||
}, |
|||
dialogShow: { |
|||
type: Boolean, |
|||
default: false, |
|||
}, |
|||
rowInfo: { |
|||
type: Object as () => FormInfo, |
|||
default() { |
|||
return {}; |
|||
}, |
|||
}, |
|||
arrayNum: { |
|||
type: Number, |
|||
default: 0, |
|||
}, |
|||
}, |
|||
setup(props, { emit }) { |
|||
const data = reactive({ |
|||
dialogFlag: false, |
|||
formData: { |
|||
id: props.arrayNum.toString(), |
|||
age: "'公开'", |
|||
name: "", |
|||
sex: "", |
|||
ccc: "", |
|||
ade: "", |
|||
iop: "1", |
|||
ddd: "", |
|||
}, |
|||
}); |
|||
const method = reactive({ |
|||
// 关闭弹窗 |
|||
handleClose() { |
|||
emit("update:dialogShow", false); |
|||
}, |
|||
// 重置 |
|||
resetForm() { |
|||
data.formData = Object.assign({}, props.rowInfo); |
|||
}, |
|||
// 提交表单内容 |
|||
submitForm() { |
|||
method.handleClose(); |
|||
if (props.rowInfo.name) { |
|||
// 修改 |
|||
const id = props.rowInfo; |
|||
emit("editRow", data.formData); |
|||
} else { |
|||
// 新增 |
|||
data.formData["id"] = (props.arrayNum + 1).toString(); |
|||
emit("addRow", data.formData); |
|||
} |
|||
}, |
|||
}); |
|||
onMounted(() => { |
|||
data.formData = Object.assign({}, props.rowInfo); |
|||
}); |
|||
const handlePictureCardPreview = (file: UploadFile) => {}; |
|||
const disabled = ref(false); |
|||
const handleRemove = (file: UploadFile) => {}; |
|||
const handleDownload = (file: UploadFile) => {}; |
|||
return { |
|||
...toRefs(data), |
|||
...method, |
|||
disabled, |
|||
handleRemove, |
|||
handlePictureCardPreview, |
|||
handleDownload, |
|||
editContvalue, |
|||
nameRules, |
|||
parentBorder, |
|||
childBorder, |
|||
}; |
|||
}, |
|||
}; |
|||
</script> |
|||
|
|||
<style scoped> |
|||
.avatar-uploader .avatar { |
|||
display: block; |
|||
width: 178px; |
|||
height: 178px; |
|||
} |
|||
</style> |
|||
|
|||
<style lang="scss"> |
|||
.avatar-uploader .el-upload { |
|||
position: relative; |
|||
overflow: hidden; |
|||
cursor: pointer; |
|||
border: 1px dashed var(--el-border-color); |
|||
border-radius: 6px; |
|||
transition: var(--el-transition-duration-fast); |
|||
} |
|||
|
|||
.avatar-uploader .el-upload:hover { |
|||
border-color: var(--el-color-primary); |
|||
} |
|||
|
|||
.el-icon.avatar-uploader-icon { |
|||
width: 178px; |
|||
height: 178px; |
|||
font-size: 28px; |
|||
color: #8c939d; |
|||
text-align: center; |
|||
} |
|||
</style> |
|||
@ -0,0 +1,34 @@ |
|||
<!-- |
|||
@ 作者: 鲁智强 |
|||
@ 时间: 2023-08-15 11:34:38 |
|||
@ 备注: |
|||
--> |
|||
<script lang="ts" setup> |
|||
import { ref } from "vue"; |
|||
import { ElButton, ElDialog /* ...其他引入的组件 */ } from "element-plus"; |
|||
import aaComponent from "./aa.vue"; |
|||
import bbComponent from "./bb.vue"; |
|||
</script> |
|||
<template> |
|||
<div class="ccc"> |
|||
<bb-component></bb-component> |
|||
</div> |
|||
</template> |
|||
<style lang="scss" scoped> |
|||
* { |
|||
background-color: #fff; |
|||
} |
|||
|
|||
.oba { |
|||
position: absolute; |
|||
top: -9px; |
|||
} |
|||
|
|||
.oaa { |
|||
position: absolute; |
|||
top: 5px; |
|||
left: 970px; |
|||
width: 700px; |
|||
margin-top: 3.5px; |
|||
} |
|||
</style> |
|||
Loading…
Reference in new issue