|
@@ -0,0 +1,483 @@
|
|
|
|
+<template>
|
|
|
|
+ <div id="deviceList">
|
|
|
|
+ <el-row class="right">
|
|
|
|
+ <el-col span="4">
|
|
|
|
+ <span style="float:left;">当前选择的系统类型:{{ category.categoryName }}</span>
|
|
|
|
+ </el-col>
|
|
|
|
+
|
|
|
|
+ <el-col span="20" style="text-align: right">
|
|
|
|
+ <el-select v-model="showType" @change="initTable" style="width:125px;margin-right:10px;vertical-align:bottom;">
|
|
|
|
+ <el-option v-for="item in showTypes" :key="item.value" :label="item.label" :value="item.value"></el-option>
|
|
|
|
+ </el-select>
|
|
|
|
+ <span>增加</span>
|
|
|
|
+ <el-input-number v-model="addNum" :controls="false" style="width:50px;" :min="1" :max="50"></el-input-number>
|
|
|
|
+ <span>个{{ category.categoryName }}</span>
|
|
|
|
+ <el-button @click="handleAddTableRow">增加</el-button>
|
|
|
|
+ </el-col>
|
|
|
|
+ </el-row>
|
|
|
|
+ <div class="tableBox">
|
|
|
|
+ <div class="center middle_sty" style="flex:2;" v-show="tableData && !tableData.length">
|
|
|
|
+ <p>
|
|
|
|
+ <i class="icon-wushuju iconfont"></i>
|
|
|
|
+ 暂无数据
|
|
|
|
+ </p>
|
|
|
|
+ </div>
|
|
|
|
+ <div class="tableLeft" v-show="tableData && tableData.length">
|
|
|
|
+ <handson-table ref="table"></handson-table>
|
|
|
|
+ </div>
|
|
|
|
+ </div>
|
|
|
|
+ <el-row class="center">
|
|
|
|
+ <el-button type="primary" size="medium" @click="handleCreateTableData" class="create_button" :disabled="createDisable">创建系统</el-button>
|
|
|
|
+ </el-row>
|
|
|
|
+ <!-- 上传图片组件 -->
|
|
|
|
+ <upload-img-dialog :read="onlyRead ? true : false" @changeFile="imgChange" :keysArr="imgsArr" firmDataType="row" :dialog="myDialog"></upload-img-dialog>
|
|
|
|
+ <!-- 关联楼层 -->
|
|
|
|
+ <editSysfloor ref="editFloor" @relateSuccess="relateSuccess" :isCreate="true"></editSysfloor>
|
|
|
|
+ <!-- 多选枚举类型维护 -->
|
|
|
|
+ <menum :dialog="myDialog" :updateInfoData="updateInfoData" :updateInput="updateInput" @change="handleChangeMenum"></menum>
|
|
|
|
+ </div>
|
|
|
|
+</template>
|
|
|
|
+<script>
|
|
|
|
+import tools from "@/utils/old-adm/scan/tools";
|
|
|
|
+import showTools from "@/utils/old-adm/handsontable/notShow";
|
|
|
|
+import text from "@/utils/old-adm/handsontable/mainText";
|
|
|
|
+import session from "@/utils/storageUtil";
|
|
|
|
+
|
|
|
|
+import editSysfloor from "@/components/old-adm/ledger/components/lib/editSysFloor";
|
|
|
|
+import uploadImgDialog from "@/components/old-adm/dialogs/list/uploadImgDialog"
|
|
|
|
+import handsonTable from "@/components/old-adm/common/handsontable";
|
|
|
|
+import Dict from "@/controller/old-adm/dicController";
|
|
|
|
+
|
|
|
|
+import Scan from '@/controller/old-adm/ScanController'
|
|
|
|
+import { mapGetters, mapActions } from "vuex";
|
|
|
|
+import BuildController from "@/controller/old-adm/buildController"
|
|
|
|
+import menum from "@/components/old-adm/dialogs/list/menum";
|
|
|
|
+
|
|
|
|
+const { getDataDictionary } = Dict
|
|
|
|
+const { createSystemBuildFloor } = Scan
|
|
|
|
+export default {
|
|
|
|
+ components: {
|
|
|
|
+ handsonTable,
|
|
|
|
+ menum,
|
|
|
|
+ editSysfloor,
|
|
|
|
+ uploadImgDialog
|
|
|
|
+ },
|
|
|
|
+ data() {
|
|
|
|
+ return {
|
|
|
|
+ addNum: 1,
|
|
|
|
+ onlyRead: false,
|
|
|
|
+ showTypes: [
|
|
|
|
+ { value: "Visible", label: '只看采集信息' },
|
|
|
|
+ { value: "all", label: '全部' }
|
|
|
|
+ ],
|
|
|
|
+ tableHeader: [],
|
|
|
|
+ tableData: session.get("systemAddData")
|
|
|
|
+ ? session.get("systemAddData").length
|
|
|
|
+ ? session.get("systemAddData")
|
|
|
|
+ : [{}]
|
|
|
|
+ : [{}],
|
|
|
|
+ copyTableData: [],
|
|
|
|
+ category: "", //当前设备类
|
|
|
|
+ myDialog: {
|
|
|
|
+ qrcode: false, //二维码弹窗
|
|
|
|
+ uploadFiles: false, //上传文件
|
|
|
|
+ uploadImgs: false, //上传单个图片
|
|
|
|
+ pic: false, //多个图片
|
|
|
|
+ addDevice: false,
|
|
|
|
+ systemType: false,
|
|
|
|
+ details: false, //详情页
|
|
|
|
+ changeRea: false,
|
|
|
|
+ lookPic: false, //图片查看
|
|
|
|
+ menum: false, //临时多选枚举类型信息点
|
|
|
|
+ },
|
|
|
|
+ inputMap: {
|
|
|
|
+ flowBuild: {
|
|
|
|
+ editable: true,
|
|
|
|
+ code: "flowBuild",
|
|
|
|
+ name: "建筑楼层",
|
|
|
|
+ path: "flowBuild",
|
|
|
|
+ category: 'STATIC',
|
|
|
|
+ dataType: "ENUM"
|
|
|
|
+ }
|
|
|
|
+ }, //信息点和输入方式映射表
|
|
|
|
+ qrcodeUrl: "", //二维码图片地址
|
|
|
|
+ filesArr: [], //保存临时的文件key
|
|
|
|
+ imgsArr: [], //临时保存的图片key数组
|
|
|
|
+ picsArr: [], //临时设备图片keys数组
|
|
|
|
+ systemId: null,
|
|
|
|
+ graphyId: null,
|
|
|
|
+ id: 0,
|
|
|
|
+ showType: this.$route.query.showType,
|
|
|
|
+ EquipmentList: [],
|
|
|
|
+ createDisable: false,
|
|
|
|
+ updateInfoData: {}, //当前信息点信息
|
|
|
|
+ updateInfoPoint: "", //临时维护信息点键
|
|
|
|
+ updateInput: "", //临时维护信息点值
|
|
|
|
+ };
|
|
|
|
+ },
|
|
|
|
+ computed: {
|
|
|
|
+ ...mapGetters("layout", ["projectId", "secret", "userId"])
|
|
|
|
+ },
|
|
|
|
+ created() {
|
|
|
|
+ this.category = this.$route.query;
|
|
|
|
+ this.getBuildData();
|
|
|
|
+ this.getTableHeader();
|
|
|
|
+ },
|
|
|
|
+ methods: {
|
|
|
|
+ //获取建筑数据
|
|
|
|
+ getBuildData() {
|
|
|
|
+ let param = {
|
|
|
|
+ pageNumber: 1,
|
|
|
|
+ pageSize: 1000,
|
|
|
|
+ projection: [
|
|
|
|
+ "id",
|
|
|
|
+ "localName"
|
|
|
|
+ ]
|
|
|
|
+ }
|
|
|
|
+ const res = BuildController.buildingQuery(param);
|
|
|
|
+ let data = res.content.map(t => {
|
|
|
|
+ return {
|
|
|
|
+ Code: t.id,
|
|
|
|
+ Name: t.localName,
|
|
|
|
+ }
|
|
|
|
+ })
|
|
|
|
+ data.unshift({ Code: '', Name: '未明确建筑' })
|
|
|
|
+ this.buildingData = data;
|
|
|
|
+
|
|
|
|
+ },
|
|
|
|
+ // 获取表头数据(初始化表格)
|
|
|
|
+ async getTableHeader() {
|
|
|
|
+ let params = {
|
|
|
|
+ orders: "sort asc, name desc",
|
|
|
|
+ pageNumber: 1,
|
|
|
|
+ pageSize: 1000,
|
|
|
|
+ type: this.category.category
|
|
|
|
+ };
|
|
|
|
+ await getDataDictionary(params, res => {
|
|
|
|
+ this.tableHeader = res.content;
|
|
|
|
+ this.tableHeader.forEach(item => {
|
|
|
|
+ if (item.path) {
|
|
|
|
+ this.inputMap[item.path] = item;
|
|
|
|
+ }
|
|
|
|
+ })
|
|
|
|
+ this.initTable();
|
|
|
|
+ });
|
|
|
|
+ },
|
|
|
|
+ // 创建设备数据
|
|
|
|
+ async handleCreateTableData() {
|
|
|
|
+ let params = {}
|
|
|
|
+ let newData = this.tableData.filter(item => {
|
|
|
|
+ let keys = Object.keys(item);
|
|
|
|
+ keys.map(key => {
|
|
|
|
+ //将值为空字符串的属性删除
|
|
|
|
+ if (item[key] == "") {
|
|
|
|
+ delete item[key];
|
|
|
|
+ }
|
|
|
|
+ });
|
|
|
|
+ let newK = Object.keys(item)
|
|
|
|
+ if (newK.length) {
|
|
|
|
+ return item;
|
|
|
|
+ }
|
|
|
|
+ });
|
|
|
|
+ if (!newData.length) {
|
|
|
|
+ this.$message("创建信息为空,请录入信息后再创建!");
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+ let flag = false;
|
|
|
|
+ newData.map(item => {
|
|
|
|
+ if (!item.localName) {
|
|
|
|
+ flag = true;
|
|
|
|
+ }
|
|
|
|
+ item.classCode = this.category.category
|
|
|
|
+ })
|
|
|
|
+ if (flag) {
|
|
|
|
+ this.$message.info("存在系统的本地名称为空,请检查")
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+ params.content = newData
|
|
|
|
+ this.createDisable = true;
|
|
|
|
+ createSystemBuildFloor(params, res => {
|
|
|
|
+ this.createDisable = false;
|
|
|
|
+ this.$message.success('创建成功')
|
|
|
|
+ session.remove("systemAddData")
|
|
|
|
+ this.$router.push({
|
|
|
|
+ name: "systemlist",
|
|
|
|
+ params: { SysType: this.category.category }
|
|
|
|
+ });
|
|
|
|
+ })
|
|
|
|
+ },
|
|
|
|
+ // 删除表格行
|
|
|
|
+ handleDeleteTableRow(a,b,c,d) {
|
|
|
|
+ if (d && d === 'ContextMenu.removeRow') {
|
|
|
|
+ this.$message.success("删除成功");
|
|
|
|
+ this.formaTableData();
|
|
|
|
+ }
|
|
|
|
+ },
|
|
|
|
+ // 添加行
|
|
|
|
+ handleAddTableRow() {
|
|
|
|
+ let addRowLength = this.addNum;
|
|
|
|
+ for (let i = 0; i < addRowLength; i++) {
|
|
|
|
+ this.tableData.push({});
|
|
|
|
+ }
|
|
|
|
+ this.initTable();
|
|
|
|
+ this.formaTableData();
|
|
|
|
+ },
|
|
|
|
+ //修改
|
|
|
|
+ handleUpdataTable(changeData, source) {
|
|
|
|
+ this.formaTableData();
|
|
|
|
+ },
|
|
|
|
+ //保存去掉空字段的新增数据
|
|
|
|
+ formaTableData() {
|
|
|
|
+ let newData = this.tableData.filter(item => {
|
|
|
|
+ let keys = Object.keys(item);
|
|
|
|
+ keys.map(key => {
|
|
|
|
+ //将值为空字符串的属性删除
|
|
|
|
+ if (item[key] == "") {
|
|
|
|
+ delete item[key];
|
|
|
|
+ }
|
|
|
|
+ });
|
|
|
|
+ if (keys.length && Object.keys(item).length) {
|
|
|
|
+ return item;
|
|
|
|
+ }
|
|
|
|
+ });
|
|
|
|
+ session.set("systemAddData", newData);
|
|
|
|
+ },
|
|
|
|
+ //格式化表头显示的数据
|
|
|
|
+ formatHeaderData(list) {
|
|
|
|
+ let arr = tools.copyArr(list);
|
|
|
|
+ let data = showTools.headerTextFilter(arr, 'system', this.onlyRead, this.showType);
|
|
|
|
+ data.unshift("所属建筑楼层");
|
|
|
|
+ return data;
|
|
|
|
+ },
|
|
|
|
+ formatHeaderType(list) {
|
|
|
|
+ //格式化表头头映射的数据
|
|
|
|
+ let arr = tools.copyArr(list);
|
|
|
|
+ let data = showTools.headerTypeFilter(arr, 'system', this.onlyRead, this.showType);
|
|
|
|
+ data.unshift({
|
|
|
|
+ data: "buildingFloorInfoList",
|
|
|
|
+ renderer: text.sysInBuildFloor
|
|
|
|
+ });
|
|
|
|
+ return data;
|
|
|
|
+ },
|
|
|
|
+ initTable() {
|
|
|
|
+ //实例化表格
|
|
|
|
+ let settings = {
|
|
|
|
+ data: this.tableData,
|
|
|
|
+ colHeaders: this.formatHeaderData(this.tableHeader),
|
|
|
|
+ columns: this.formatHeaderType(this.tableHeader),
|
|
|
|
+ rowHeights: 30,
|
|
|
|
+ fillHandle: 'vertical', //允许纵向填充
|
|
|
|
+ maxRows: this.tableData.length,
|
|
|
|
+ contextMenu: this.onlyRead ? false : {
|
|
|
|
+ items: {
|
|
|
|
+ remove_row: {
|
|
|
|
+ name: "删除该系统"
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ },
|
|
|
|
+ autoColumnSize: true,
|
|
|
|
+ language: "zh-CN",
|
|
|
|
+ manualColumnResize: true,
|
|
|
|
+ manualColumnMove: true,
|
|
|
|
+ // 事件
|
|
|
|
+ afterChange: this.handleUpdataTable, //修改后
|
|
|
|
+ afterFilter: this.trimmedRows, //排序前
|
|
|
|
+ afterRemoveRow: this.handleDeleteTableRow, //右键删除
|
|
|
|
+ afterOnCellMouseDown: this.handleTdClick //鼠标点击
|
|
|
|
+ };
|
|
|
|
+ this.$nextTick(() => {
|
|
|
|
+ this.tableExample = this.$refs.table.init(settings);
|
|
|
|
+ });
|
|
|
|
+ },
|
|
|
|
+ //去除数组中相同的元素
|
|
|
|
+ array_diff(a, b) {
|
|
|
|
+ for (var i = 0; i < b.length; i++) {
|
|
|
|
+ for (var j = 0; j < a.length; j++) {
|
|
|
|
+ if (a[j] == b[i]) {
|
|
|
|
+ a.splice(j, 1);
|
|
|
|
+ j = j - 1;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ return a;
|
|
|
|
+ },
|
|
|
|
+ //表格点击事件
|
|
|
|
+ handleTdClick(el, rowArr) {
|
|
|
|
+ //点击的是表头
|
|
|
|
+ if (rowArr.row < 0) {
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+ //被筛选过后的数组
|
|
|
|
+ let trimmedArr = this.trimmedRows();
|
|
|
|
+ //是否启用了排序
|
|
|
|
+ let isSort = this.tableExample.getPlugin("columnSorting").isSorted();
|
|
|
|
+ if (trimmedArr.length && isSort) {
|
|
|
|
+ let sortArr = this.myHotArr.getPlugin("columnSorting").rowsMapper
|
|
|
|
+ .__arrayMap;
|
|
|
|
+ let infos = this.tableData[trimmedArr[sortArr[rowArr.row]]];
|
|
|
|
+ this.getInfors(infos, { row: sortArr[rowArr.row], col: rowArr.col });
|
|
|
|
+ } else if (isSort) {
|
|
|
|
+ //排序后的数组
|
|
|
|
+ let sortArr = this.tableExample.getPlugin("columnSorting").rowsMapper
|
|
|
|
+ .__arrayMap;
|
|
|
|
+ let infos = this.tableData[sortArr[rowArr.row]];
|
|
|
|
+ this.getInfors(infos, { row: sortArr[rowArr.row], col: rowArr.col });
|
|
|
|
+ } else if (trimmedArr.length) {
|
|
|
|
+ let infos = this.tableData[trimmedArr[rowArr.row]];
|
|
|
|
+ this.getInfors(infos, { row: trimmedArr[rowArr.row], col: rowArr.col });
|
|
|
|
+ } else {
|
|
|
|
+ let infos = this.tableData[rowArr.row];
|
|
|
|
+ this.getInfors(infos, rowArr);
|
|
|
|
+ }
|
|
|
|
+ },
|
|
|
|
+ //获取被筛选掉的行号
|
|
|
|
+ trimmedRows() {
|
|
|
|
+ var plugin = this.tableExample.getPlugin("trimRows").trimmedRows;
|
|
|
|
+ let dataLength = this.tableData.length;
|
|
|
|
+ let dataArr = new Array();
|
|
|
|
+ for (let i = 0; i < dataLength; i++) {
|
|
|
|
+ dataArr.push(i);
|
|
|
|
+ }
|
|
|
|
+ if (plugin.length <= 0) {
|
|
|
|
+ dataArr = undefined;
|
|
|
|
+ } else {
|
|
|
|
+ dataArr = this.array_diff(dataArr, plugin);
|
|
|
|
+ }
|
|
|
|
+ return dataArr || [];
|
|
|
|
+ },
|
|
|
|
+ getInfors(infos, row) {
|
|
|
|
+ let val = this.tableExample.colToProp(row.col);
|
|
|
|
+ let inputData = this.inputMap[val];
|
|
|
|
+ this.row = row.row;
|
|
|
|
+ this.messKey = val;
|
|
|
|
+ switch (val) {
|
|
|
|
+ //操作
|
|
|
|
+ case 'caozuo':
|
|
|
|
+ // window.open(`http://adm.sagacloud.cn:8058/spread?id=${infos.EquipID}&pid=${this.projectId}&secret=${this.secret}`,"_blank")
|
|
|
|
+ this.$message("开发中...")
|
|
|
|
+ break;
|
|
|
|
+ //设备二维码图片
|
|
|
|
+ // case 'EquipQRCode':
|
|
|
|
+ // case "defaultQRCode":
|
|
|
|
+ // this.qrcodeUrl = this.tableData[row.row].EquipQRCode;
|
|
|
|
+ // if (!!this.qrcodeUrl) {
|
|
|
|
+ // this.myDialog.qrcode = true;
|
|
|
|
+ // } else {
|
|
|
|
+ // this.$message("此设备没有设备二维码");
|
|
|
|
+ // }
|
|
|
|
+ // break;
|
|
|
|
+ //关联设备数量
|
|
|
|
+ case 'count':
|
|
|
|
+ if (!this.onlyRead) {
|
|
|
|
+ this.myDialog.relevance = true
|
|
|
|
+ }
|
|
|
|
+ break;
|
|
|
|
+ //所属建筑楼层
|
|
|
|
+ case 'buildingFloorInfoList':
|
|
|
|
+ if (!this.onlyRead) {
|
|
|
|
+ this.$refs.editFloor.showDialog(this.tableData[row.row]);
|
|
|
|
+ }
|
|
|
|
+ break;
|
|
|
|
+ //系统图(F2)
|
|
|
|
+ case "infos.systemChart":
|
|
|
|
+ let SSPPdata = tools.dataForKey(this.tableData[row.row], val);
|
|
|
|
+ this.imgsArr = SSPPdata ? SSPPdata : [];
|
|
|
|
+ this.myDialog.uploadImgs = true;
|
|
|
|
+ return false;
|
|
|
|
+ default:
|
|
|
|
+ break;
|
|
|
|
+ }
|
|
|
|
+ // 维护多选枚举值
|
|
|
|
+ if (!this.onlyRead && inputData.dataType == "MENUM") {
|
|
|
|
+ this.updateInfoData = inputData;
|
|
|
|
+ this.updateInfoPoint = val;
|
|
|
|
+ this.updateInput = tools.dataForKey(this.tableData[row.row], val);
|
|
|
|
+ this.myDialog.menum = true;
|
|
|
|
+ return false;
|
|
|
|
+ }
|
|
|
|
+ if (!this.onlyRead && !inputData.editable) {
|
|
|
|
+ this.$confirm('该信息点的值为自动生成,不可人工维护!', '提示', {
|
|
|
|
+ confirmButtonText: '我知道了',
|
|
|
|
+ showCancelButton: false,
|
|
|
|
+ type: 'warning',
|
|
|
|
+ center: true
|
|
|
|
+ }).then(() => {
|
|
|
|
+ return false;
|
|
|
|
+ });
|
|
|
|
+ }
|
|
|
|
+ },
|
|
|
|
+ //多选枚举类型值修改
|
|
|
|
+ handleChangeMenum(newValue) {
|
|
|
|
+ tools.setDataForKey(
|
|
|
|
+ this.tableData[this.row],
|
|
|
|
+ this.updateInfoPoint,
|
|
|
|
+ newValue
|
|
|
|
+ );
|
|
|
|
+ this.handleUpdataTable(
|
|
|
|
+ [[this.row, this.updateInfoPoint, null, newValue]],
|
|
|
|
+ "edit"
|
|
|
|
+ );
|
|
|
|
+ this.myDialog.menum = false;
|
|
|
|
+ this.updateInput = "";
|
|
|
|
+ },
|
|
|
|
+ //上传图片弹窗触发事件
|
|
|
|
+ imgChange(keys) {
|
|
|
|
+ this.setDataToMain(keys, this.messKey, this.row);
|
|
|
|
+ },
|
|
|
|
+ //建筑楼层
|
|
|
|
+ relateSuccess(data) {
|
|
|
|
+ this.tableData[this.row].buildingFloorInfoList = data
|
|
|
|
+ this.tableExample.render()
|
|
|
|
+ },
|
|
|
|
+ //判断是否有值,有值赋值
|
|
|
|
+ setDataToMain(data, key, row) {
|
|
|
|
+ if (!!data && data != "--") {
|
|
|
|
+ if (!!this.tableData[row]) {
|
|
|
|
+ tools.setDataForKey(this.tableData[row], key, data);
|
|
|
|
+ this.handleUpdataTable([[row, key, null, data]], "edit");
|
|
|
|
+ } else {
|
|
|
|
+ this.tableData[row] = {};
|
|
|
|
+ tools.setDataForKey(this.tableData[row], key, data);
|
|
|
|
+ }
|
|
|
|
+ } else {
|
|
|
|
+ tools.setDataForKey(this.tableData[row], key, "");
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+};
|
|
|
|
+</script>
|
|
|
|
+<style lang="less" scoped>
|
|
|
|
+#deviceList {
|
|
|
|
+ overflow: hidden;
|
|
|
|
+ height: 100%;
|
|
|
|
+ background-color: #fff;
|
|
|
|
+ padding: 10px;
|
|
|
|
+ position: relative;
|
|
|
|
+
|
|
|
|
+ .right {
|
|
|
|
+ background: #fff;
|
|
|
|
+ padding: 16px;
|
|
|
|
+ line-height: 32px;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ .search-header {
|
|
|
|
+ overflow: hidden;
|
|
|
|
+ padding: 0 10px 10px 10px;
|
|
|
|
+ border-bottom: 1px solid #bcbcbc;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ .tableBox {
|
|
|
|
+ display: flex;
|
|
|
|
+ height: calc(100% - 100px);
|
|
|
|
+ margin-top: 10px;
|
|
|
|
+
|
|
|
|
+ .tableLeft {
|
|
|
|
+ flex: 1;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ .create_button {
|
|
|
|
+ padding-top: 10px;
|
|
|
|
+ }
|
|
|
|
+}
|
|
|
|
+</style>
|