Compare commits
No commits in common. "2cf0e718f7c4b4bbc6346ee19acb734c47de2669" and "a312117ea34c6a4d3da35ebaf7e632ac00c1385f" have entirely different histories.
2cf0e718f7
...
a312117ea3
@ -1,63 +0,0 @@
|
|||||||
/**
|
|
||||||
* 用于动态表结构的 tableProps 生成
|
|
||||||
* @param {*} nameData
|
|
||||||
* @returns
|
|
||||||
*/
|
|
||||||
export function handleNameData(nameData) {
|
|
||||||
const props = step1(nameData.filter((item) => item.tree == 1));
|
|
||||||
step2(
|
|
||||||
props,
|
|
||||||
nameData.filter((item) => item.tree == 2)
|
|
||||||
);
|
|
||||||
// console.log('level 1', JSON.stringify(props, null, 2));
|
|
||||||
return props;
|
|
||||||
}
|
|
||||||
|
|
||||||
function step1(tree1) {
|
|
||||||
return Array.from(new Set(tree1.map((item) => item.name)))
|
|
||||||
.sort()
|
|
||||||
.map((item) => ({
|
|
||||||
prop: item,
|
|
||||||
label: item,
|
|
||||||
align: 'center',
|
|
||||||
children: [],
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
|
|
||||||
function step2(firstTierProps, tree2) {
|
|
||||||
tree2.map((nd) => {
|
|
||||||
const parent = firstTierProps.find(
|
|
||||||
({ prop }) => nd.parentId.indexOf(prop) > -1
|
|
||||||
);
|
|
||||||
if (notRepeat(parent.children, nd.name)) {
|
|
||||||
parent.children.push({
|
|
||||||
label: nd.name,
|
|
||||||
prop: `${parent.prop}-${nd.name}`,
|
|
||||||
align: 'center',
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function notRepeat(propArray, name) {
|
|
||||||
return propArray.every((item) => item.label !== name);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 用于调整服务器返回的动态数据
|
|
||||||
* @param {*} dynamicData
|
|
||||||
* @returns
|
|
||||||
*/
|
|
||||||
export function handleDynamicData(dynamicData) {
|
|
||||||
return dynamicData.map((dd) => {
|
|
||||||
const initData = {
|
|
||||||
inspectionContent: dd.inspectionDetContent,
|
|
||||||
};
|
|
||||||
dd.data.forEach((column) => {
|
|
||||||
column.children.forEach((ch) => {
|
|
||||||
initData[`${column.dynamicName}-${ch.dynamicName}`] = ch.dynamicValue;
|
|
||||||
});
|
|
||||||
});
|
|
||||||
return initData;
|
|
||||||
});
|
|
||||||
}
|
|
@ -1,191 +1,99 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="app-container">
|
<div class="app-container">
|
||||||
|
|
||||||
<!-- 搜索工作栏 -->
|
<!-- 搜索工作栏 -->
|
||||||
<SearchBar
|
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
|
||||||
:formConfigs="searchBarFormConfig"
|
<el-form-item label="分组编码" prop="code">
|
||||||
ref="search-bar"
|
<el-input v-model="queryParams.code" placeholder="请输入分组编码" clearable @keyup.enter.native="handleQuery"/>
|
||||||
@headBtnClick="handleSearchBarBtnClick" />
|
</el-form-item>
|
||||||
|
<el-form-item label="分组名字" prop="name">
|
||||||
|
<el-input v-model="queryParams.name" placeholder="请输入分组名字" clearable @keyup.enter.native="handleQuery"/>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item>
|
||||||
|
<el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button>
|
||||||
|
<el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
|
||||||
|
<!-- 操作工具栏 -->
|
||||||
|
<el-row :gutter="10" class="mb8">
|
||||||
|
<el-col :span="1.5">
|
||||||
|
<el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd"
|
||||||
|
v-hasPermi="['base:equipment-group:create']">新增</el-button>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="1.5">
|
||||||
|
<el-button type="warning" plain icon="el-icon-download" size="mini" @click="handleExport" :loading="exportLoading"
|
||||||
|
v-hasPermi="['base:equipment-group:export']">导出</el-button>
|
||||||
|
</el-col>
|
||||||
|
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
|
||||||
|
</el-row>
|
||||||
|
|
||||||
<!-- 列表 -->
|
<!-- 列表 -->
|
||||||
<base-table
|
<el-table v-loading="loading" :data="list">
|
||||||
:table-props="tableProps"
|
<el-table-column label="ID" align="center" prop="id" />
|
||||||
:page="queryParams.pageNo"
|
<el-table-column label="分组编码" align="center" prop="code" />
|
||||||
:limit="queryParams.pageSize"
|
<el-table-column label="分组名字" align="center" prop="name" />
|
||||||
:table-data="list"
|
<el-table-column label="备注" align="center" prop="remark" />
|
||||||
@emitFun="handleEmitFun">
|
<el-table-column label="创建时间" align="center" prop="createTime" width="180">
|
||||||
<method-btn
|
<template v-slot="scope">
|
||||||
v-if="tableBtn.length"
|
<span>{{ parseTime(scope.row.createTime) }}</span>
|
||||||
slot="handleBtn"
|
</template>
|
||||||
label="操作"
|
</el-table-column>
|
||||||
:method-list="tableBtn"
|
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
||||||
@clickBtn="handleTableBtnClick" />
|
<template v-slot="scope">
|
||||||
</base-table>
|
<el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)"
|
||||||
|
v-hasPermi="['base:equipment-group:update']">修改</el-button>
|
||||||
|
<el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)"
|
||||||
|
v-hasPermi="['base:equipment-group:delete']">删除</el-button>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
</el-table>
|
||||||
<!-- 分页组件 -->
|
<!-- 分页组件 -->
|
||||||
<pagination
|
<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize"
|
||||||
v-show="total > 0"
|
@pagination="getList"/>
|
||||||
:total="total"
|
|
||||||
:page.sync="queryParams.pageNo"
|
|
||||||
:limit.sync="queryParams.pageSize"
|
|
||||||
@pagination="getList" />
|
|
||||||
|
|
||||||
<!-- 对话框(添加 / 修改) -->
|
<!-- 对话框(添加 / 修改) -->
|
||||||
<base-dialog
|
<el-dialog :title="title" :visible.sync="open" width="500px" v-dialogDrag append-to-body>
|
||||||
:dialogTitle="title"
|
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
|
||||||
:dialogVisible="open"
|
<el-form-item label="分组编码" prop="code">
|
||||||
width="500px"
|
<el-input v-model="form.code" placeholder="请输入分组编码" />
|
||||||
@close="cancel"
|
</el-form-item>
|
||||||
@cancel="cancel"
|
<el-form-item label="分组名字" prop="name">
|
||||||
@confirm="submitForm">
|
<el-input v-model="form.name" placeholder="请输入分组名字" />
|
||||||
<DialogForm v-if="open" ref="form" :dataForm="form" :rows="rows" />
|
</el-form-item>
|
||||||
</base-dialog>
|
<el-form-item label="备注" prop="remark">
|
||||||
|
<el-input v-model="form.remark" placeholder="请输入备注" />
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
<div slot="footer" class="dialog-footer">
|
||||||
|
<el-button type="primary" @click="submitForm">确 定</el-button>
|
||||||
|
<el-button @click="cancel">取 消</el-button>
|
||||||
|
</div>
|
||||||
|
</el-dialog>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import {
|
import { createEquipmentGroup, updateEquipmentGroup, deleteEquipmentGroup, getEquipmentGroup, getEquipmentGroupPage, exportEquipmentGroupExcel } from "@/api/base/equipmentGroup";
|
||||||
createEquipmentGroup,
|
|
||||||
updateEquipmentGroup,
|
|
||||||
deleteEquipmentGroup,
|
|
||||||
getEquipmentGroup,
|
|
||||||
getEquipmentGroupPage,
|
|
||||||
exportEquipmentGroupExcel,
|
|
||||||
} from '@/api/base/equipmentGroup';
|
|
||||||
import moment from 'moment';
|
|
||||||
import basicPageMixin from '../mixin/basicPageMixin';
|
|
||||||
import { getAccessToken } from '@/utils/auth';
|
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'EquipmentGroup',
|
name: "EquipmentGroup",
|
||||||
mixins: [basicPageMixin],
|
components: {
|
||||||
components: {},
|
},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
searchBarKeys: ['name', 'code'],
|
// 遮罩层
|
||||||
tableBtn: [
|
loading: true,
|
||||||
this.$auth.hasPermi('base:equipment-group:update')
|
// 导出遮罩层
|
||||||
? {
|
exportLoading: false,
|
||||||
type: 'edit',
|
// 显示搜索条件
|
||||||
btnName: '修改',
|
showSearch: true,
|
||||||
}
|
// 总条数
|
||||||
: undefined,
|
total: 0,
|
||||||
this.$auth.hasPermi('base:equipment-group:delete')
|
// 设备分组(用于同类型不同厂家的设备区分)列表
|
||||||
? {
|
list: [],
|
||||||
type: 'delete',
|
// 弹出层标题
|
||||||
btnName: '删除',
|
title: "",
|
||||||
}
|
|
||||||
: undefined,
|
|
||||||
].filter((v) => v),
|
|
||||||
tableProps: [
|
|
||||||
{
|
|
||||||
prop: 'createTime',
|
|
||||||
label: '添加时间',
|
|
||||||
fixed: true,
|
|
||||||
width: 180,
|
|
||||||
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
|
||||||
},
|
|
||||||
{ prop: 'name', label: '设备分组名称', align: 'center' },
|
|
||||||
{ prop: 'code', label: '检测分组编码', align: 'center' },
|
|
||||||
{ prop: 'remark', label: '备注', align: 'center' },
|
|
||||||
{
|
|
||||||
action: 'show-alert',
|
|
||||||
label: '报警',
|
|
||||||
align: 'center',
|
|
||||||
subcomponent: {
|
|
||||||
props: ['injectData'],
|
|
||||||
render: function (h) {
|
|
||||||
const _this = this;
|
|
||||||
return h(
|
|
||||||
'el-button',
|
|
||||||
{
|
|
||||||
props: { type: 'text', size: 'mini' },
|
|
||||||
on: {
|
|
||||||
click: function () {
|
|
||||||
console.log('inejctdata', _this.injectData);
|
|
||||||
_this.$emit('emitData', {
|
|
||||||
action: _this.injectData.action,
|
|
||||||
value: _this.injectData.id,
|
|
||||||
});
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
'查看报警'
|
|
||||||
);
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
],
|
|
||||||
searchBarFormConfig: [
|
|
||||||
{
|
|
||||||
type: 'input',
|
|
||||||
label: '分组名称',
|
|
||||||
placeholder: '请输入设备分组名称',
|
|
||||||
param: 'name',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
type: 'input',
|
|
||||||
label: '分组编码',
|
|
||||||
placeholder: '请输入设备分组编码',
|
|
||||||
param: 'codes',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
type: 'button',
|
|
||||||
btnName: '查询',
|
|
||||||
name: 'search',
|
|
||||||
color: 'primary',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
type: 'separate',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
type: this.$auth.hasPermi('base:equipment-group:create')
|
|
||||||
? 'button'
|
|
||||||
: '',
|
|
||||||
btnName: '新增',
|
|
||||||
name: 'add',
|
|
||||||
plain: true,
|
|
||||||
color: 'success',
|
|
||||||
},
|
|
||||||
// {
|
|
||||||
// type: this.$auth.hasPermi('base:equipment-group:export') ? 'button' : '',
|
|
||||||
// btnName: '导出',
|
|
||||||
// name: 'export',
|
|
||||||
// color: 'warning',
|
|
||||||
// },
|
|
||||||
],
|
|
||||||
rows: [
|
|
||||||
[
|
|
||||||
{
|
|
||||||
input: true,
|
|
||||||
label: '分组名称',
|
|
||||||
prop: 'name',
|
|
||||||
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
|
||||||
// bind: {
|
|
||||||
// disabled: true, // some condition, like detail mode...
|
|
||||||
// }
|
|
||||||
},
|
|
||||||
],
|
|
||||||
[
|
|
||||||
{
|
|
||||||
input: true,
|
|
||||||
label: '分组编码',
|
|
||||||
prop: 'code',
|
|
||||||
url: '/base/equipment-group/getCode',
|
|
||||||
},
|
|
||||||
],
|
|
||||||
[
|
|
||||||
{
|
|
||||||
input: true,
|
|
||||||
label: '备注',
|
|
||||||
prop: 'remark',
|
|
||||||
// rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
|
||||||
bind: {
|
|
||||||
placeholder: '请输入备注',
|
|
||||||
},
|
|
||||||
},
|
|
||||||
],
|
|
||||||
],
|
|
||||||
// 是否显示弹出层
|
// 是否显示弹出层
|
||||||
open: false,
|
open: false,
|
||||||
// 查询参数
|
// 查询参数
|
||||||
@ -197,6 +105,9 @@ export default {
|
|||||||
},
|
},
|
||||||
// 表单参数
|
// 表单参数
|
||||||
form: {},
|
form: {},
|
||||||
|
// 表单校验
|
||||||
|
rules: {
|
||||||
|
}
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
created() {
|
created() {
|
||||||
@ -207,7 +118,7 @@ export default {
|
|||||||
getList() {
|
getList() {
|
||||||
this.loading = true;
|
this.loading = true;
|
||||||
// 执行查询
|
// 执行查询
|
||||||
getEquipmentGroupPage(this.queryParams).then((response) => {
|
getEquipmentGroupPage(this.queryParams).then(response => {
|
||||||
this.list = response.data.list;
|
this.list = response.data.list;
|
||||||
this.total = response.data.total;
|
this.total = response.data.total;
|
||||||
this.loading = false;
|
this.loading = false;
|
||||||
@ -226,7 +137,7 @@ export default {
|
|||||||
name: undefined,
|
name: undefined,
|
||||||
remark: undefined,
|
remark: undefined,
|
||||||
};
|
};
|
||||||
this.resetForm('form');
|
this.resetForm("form");
|
||||||
},
|
},
|
||||||
/** 搜索按钮操作 */
|
/** 搜索按钮操作 */
|
||||||
handleQuery() {
|
handleQuery() {
|
||||||
@ -235,43 +146,43 @@ export default {
|
|||||||
},
|
},
|
||||||
/** 重置按钮操作 */
|
/** 重置按钮操作 */
|
||||||
resetQuery() {
|
resetQuery() {
|
||||||
this.resetForm('queryForm');
|
this.resetForm("queryForm");
|
||||||
this.handleQuery();
|
this.handleQuery();
|
||||||
},
|
},
|
||||||
/** 新增按钮操作 */
|
/** 新增按钮操作 */
|
||||||
handleAdd() {
|
handleAdd() {
|
||||||
this.reset();
|
this.reset();
|
||||||
this.open = true;
|
this.open = true;
|
||||||
this.title = '添加设备分组(用于同类型不同厂家的设备区分)';
|
this.title = "添加设备分组(用于同类型不同厂家的设备区分)";
|
||||||
},
|
},
|
||||||
/** 修改按钮操作 */
|
/** 修改按钮操作 */
|
||||||
handleUpdate(row) {
|
handleUpdate(row) {
|
||||||
this.reset();
|
this.reset();
|
||||||
const id = row.id;
|
const id = row.id;
|
||||||
getEquipmentGroup(id).then((response) => {
|
getEquipmentGroup(id).then(response => {
|
||||||
this.form = response.data;
|
this.form = response.data;
|
||||||
this.open = true;
|
this.open = true;
|
||||||
this.title = '修改设备分组(用于同类型不同厂家的设备区分)';
|
this.title = "修改设备分组(用于同类型不同厂家的设备区分)";
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
/** 提交按钮 */
|
/** 提交按钮 */
|
||||||
submitForm() {
|
submitForm() {
|
||||||
this.$refs['form'].validate((valid) => {
|
this.$refs["form"].validate(valid => {
|
||||||
if (!valid) {
|
if (!valid) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// 修改的提交
|
// 修改的提交
|
||||||
if (this.form.id != null) {
|
if (this.form.id != null) {
|
||||||
updateEquipmentGroup(this.form).then((response) => {
|
updateEquipmentGroup(this.form).then(response => {
|
||||||
this.$modal.msgSuccess('修改成功');
|
this.$modal.msgSuccess("修改成功");
|
||||||
this.open = false;
|
this.open = false;
|
||||||
this.getList();
|
this.getList();
|
||||||
});
|
});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// 添加的提交
|
// 添加的提交
|
||||||
createEquipmentGroup(this.form).then((response) => {
|
createEquipmentGroup(this.form).then(response => {
|
||||||
this.$modal.msgSuccess('新增成功');
|
this.$modal.msgSuccess("新增成功");
|
||||||
this.open = false;
|
this.open = false;
|
||||||
this.getList();
|
this.getList();
|
||||||
});
|
});
|
||||||
@ -280,44 +191,27 @@ export default {
|
|||||||
/** 删除按钮操作 */
|
/** 删除按钮操作 */
|
||||||
handleDelete(row) {
|
handleDelete(row) {
|
||||||
const id = row.id;
|
const id = row.id;
|
||||||
this.$modal
|
this.$modal.confirm('是否确认删除设备分组(用于同类型不同厂家的设备区分)编号为"' + id + '"的数据项?').then(function() {
|
||||||
.confirm(
|
|
||||||
'是否确认删除设备分组(用于同类型不同厂家的设备区分)编号为"' +
|
|
||||||
id +
|
|
||||||
'"的数据项?'
|
|
||||||
)
|
|
||||||
.then(function () {
|
|
||||||
return deleteEquipmentGroup(id);
|
return deleteEquipmentGroup(id);
|
||||||
})
|
}).then(() => {
|
||||||
.then(() => {
|
|
||||||
this.getList();
|
this.getList();
|
||||||
this.$modal.msgSuccess('删除成功');
|
this.$modal.msgSuccess("删除成功");
|
||||||
})
|
}).catch(() => {});
|
||||||
.catch(() => {});
|
|
||||||
},
|
},
|
||||||
/** 导出按钮操作 */
|
/** 导出按钮操作 */
|
||||||
handleExport() {
|
handleExport() {
|
||||||
// 处理查询参数
|
// 处理查询参数
|
||||||
let params = { ...this.queryParams };
|
let params = {...this.queryParams};
|
||||||
params.pageNo = undefined;
|
params.pageNo = undefined;
|
||||||
params.pageSize = undefined;
|
params.pageSize = undefined;
|
||||||
this.$modal
|
this.$modal.confirm('是否确认导出所有设备分组(用于同类型不同厂家的设备区分)数据项?').then(() => {
|
||||||
.confirm(
|
|
||||||
'是否确认导出所有设备分组(用于同类型不同厂家的设备区分)数据项?'
|
|
||||||
)
|
|
||||||
.then(() => {
|
|
||||||
this.exportLoading = true;
|
this.exportLoading = true;
|
||||||
return exportEquipmentGroupExcel(params);
|
return exportEquipmentGroupExcel(params);
|
||||||
})
|
}).then(response => {
|
||||||
.then((response) => {
|
this.$download.excel(response, '设备分组(用于同类型不同厂家的设备区分).xls');
|
||||||
this.$download.excel(
|
|
||||||
response,
|
|
||||||
'设备分组(用于同类型不同厂家的设备区分).xls'
|
|
||||||
);
|
|
||||||
this.exportLoading = false;
|
this.exportLoading = false;
|
||||||
})
|
}).catch(() => {});
|
||||||
.catch(() => {});
|
}
|
||||||
},
|
}
|
||||||
},
|
|
||||||
};
|
};
|
||||||
</script>
|
</script>
|
||||||
|
@ -10,11 +10,8 @@
|
|||||||
<SearchBar
|
<SearchBar
|
||||||
:formConfigs="[{ label: '近24小时检测记录', type: 'title' }]"
|
:formConfigs="[{ label: '近24小时检测记录', type: 'title' }]"
|
||||||
ref="search-bar" />
|
ref="search-bar" />
|
||||||
<!-- <pre><code v-html="jsondemo"></code></pre> -->
|
<pre><code v-html="jsondemo"></code></pre>
|
||||||
|
|
||||||
<el-skeleton v-if="initing" :rows="6" animated />
|
|
||||||
<base-table
|
<base-table
|
||||||
v-else
|
|
||||||
:table-props="tableProps"
|
:table-props="tableProps"
|
||||||
:page="queryParams.pageNo"
|
:page="queryParams.pageNo"
|
||||||
:limit="queryParams.pageSize"
|
:limit="queryParams.pageSize"
|
||||||
@ -24,13 +21,11 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import response from './response.json';
|
import hljs from 'highlight.js/lib/highlight';
|
||||||
import { handleNameData, handleDynamicData } from '@/utils/dynamicProps';
|
import json from 'highlight.js/lib/languages/json';
|
||||||
// import hljs from 'highlight.js/lib/highlight';
|
import 'highlight.js/styles/github-gist.css';
|
||||||
// import json from 'highlight.js/lib/languages/json';
|
|
||||||
// import 'highlight.js/styles/github-gist.css';
|
|
||||||
|
|
||||||
// hljs.registerLanguage('json', json);
|
hljs.registerLanguage('json', json);
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'QualityRecentHours',
|
name: 'QualityRecentHours',
|
||||||
@ -38,19 +33,18 @@ export default {
|
|||||||
props: {},
|
props: {},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
initing: false,
|
|
||||||
queryParams: {
|
queryParams: {
|
||||||
pageNo: 1,
|
pageNo: 1,
|
||||||
pageSize: 10,
|
pageSize: 10,
|
||||||
},
|
},
|
||||||
// jsondemo: '',
|
jsondemo: '',
|
||||||
list: [
|
list: [
|
||||||
// {
|
{
|
||||||
// inspectionContent: '检测内容1',
|
inspectionContent: '检测内容1',
|
||||||
// '2023-03-18T00:00:00-产线1': '产线1-asdf',
|
'2023-03-18T00:00:00-产线1': '产线1-asdf',
|
||||||
// '2023-03-18T01:00:00-产线2': '产线2-kldf',
|
'2023-03-18T01:00:00-产线2': '产线2-kldf',
|
||||||
// '2023-03-18T02:00:00-产线1': '产线1-vasdkj',
|
'2023-03-18T02:00:00-产线1': '产线1-vasdkj',
|
||||||
// },
|
},
|
||||||
],
|
],
|
||||||
tableProps: [
|
tableProps: [
|
||||||
{
|
{
|
||||||
@ -58,6 +52,79 @@ export default {
|
|||||||
label: '检测内容',
|
label: '检测内容',
|
||||||
align: 'center',
|
align: 'center',
|
||||||
},
|
},
|
||||||
|
// 动态插入
|
||||||
|
// mock
|
||||||
|
{
|
||||||
|
prop: '2023-03-18T00:00:00',
|
||||||
|
label: '2023-03-18T00:00:00',
|
||||||
|
align: 'center',
|
||||||
|
children: [
|
||||||
|
{
|
||||||
|
prop: '2023-03-18T00:00:00-产线1',
|
||||||
|
label: '产线1',
|
||||||
|
align: 'center',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
prop: '2023-03-18T00:00:00-产线2',
|
||||||
|
label: '产线2',
|
||||||
|
align: 'center',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
prop: '2023-03-18T00:00:00-产线3',
|
||||||
|
label: '产线3',
|
||||||
|
align: 'center',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
prop: '2023-03-18T00:00:00-产线4',
|
||||||
|
label: '产线4',
|
||||||
|
align: 'center',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
prop: '2023-03-18T00:00:00-产线5',
|
||||||
|
label: '产线5',
|
||||||
|
align: 'center',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
prop: '2023-03-18T01:00:00',
|
||||||
|
label: '2023-03-18T01:00:00',
|
||||||
|
align: 'center',
|
||||||
|
children: [
|
||||||
|
{
|
||||||
|
prop: '2023-03-18T01:00:00-产线1',
|
||||||
|
label: '产线1',
|
||||||
|
align: 'center',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
prop: '2023-03-18T01:00:00-产线2',
|
||||||
|
label: '产线2',
|
||||||
|
align: 'center',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
prop: '2023-03-18T01:00:00-产线3',
|
||||||
|
label: '产线3',
|
||||||
|
align: 'center',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
prop: '2023-03-18T02:00:00',
|
||||||
|
label: '2023-03-18T02:00:00',
|
||||||
|
align: 'center',
|
||||||
|
children: [
|
||||||
|
{
|
||||||
|
prop: '2023-03-18T02:00:00-产线1',
|
||||||
|
label: '产线1',
|
||||||
|
align: 'center',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
prop: '2023-03-18T02:00:00-产线2',
|
||||||
|
label: '产线2',
|
||||||
|
align: 'center',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
],
|
],
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
@ -67,36 +134,47 @@ export default {
|
|||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
async getList() {
|
async getList() {
|
||||||
// const response = await this.$axios({
|
const response = await this.$axios({
|
||||||
// url: '/monitoring/record-in-one-day/get',
|
url: '/monitoring/record-in-one-day/get',
|
||||||
// method: 'get',
|
method: 'get',
|
||||||
// });
|
});
|
||||||
console.log(response);
|
console.log(response);
|
||||||
// const {
|
|
||||||
// // data: { nameData },
|
|
||||||
// code,
|
|
||||||
// } = response;
|
|
||||||
// this.jsondemo = hljs.highlight(
|
|
||||||
// 'json',
|
|
||||||
// JSON.stringify(response, null, 2),
|
|
||||||
// true
|
|
||||||
// ).value;
|
|
||||||
const {
|
const {
|
||||||
data: { data: dyanmicData, nameData },
|
// data: { nameData },
|
||||||
|
code,
|
||||||
} = response;
|
} = response;
|
||||||
|
this.jsondemo = hljs.highlight(
|
||||||
this.initing = true;
|
'json',
|
||||||
const dynamicProps = handleNameData(nameData);
|
JSON.stringify(response, null, 2),
|
||||||
this.tableProps.push(...dynamicProps);
|
true
|
||||||
const dataList = handleDynamicData(dyanmicData);
|
).value;
|
||||||
this.list = dataList;
|
},
|
||||||
this.queryParams.pageSize = dataList.length;
|
filterNameData(nameData) {
|
||||||
|
const ndSet = new Set();
|
||||||
setTimeout(() => {
|
nameData.forEach((nd) => {
|
||||||
this.initing = false;
|
ndSet.add(nd.name);
|
||||||
}, 1000);
|
});
|
||||||
|
return Array.from(ndSet.values())
|
||||||
|
.sort()
|
||||||
|
.map((name) => ({
|
||||||
|
prop: name,
|
||||||
|
label: name,
|
||||||
|
}));
|
||||||
|
},
|
||||||
|
filterData(data) {
|
||||||
|
return data.map((item) => {
|
||||||
|
const { data: innerData } = item;
|
||||||
|
const keyValuePairs = {};
|
||||||
|
innerData.map((d) => {
|
||||||
|
keyValuePairs[d.dynamicName] = d.dynamicValue;
|
||||||
|
});
|
||||||
|
return {
|
||||||
|
inspectionContent: item.inspectionContent,
|
||||||
|
...keyValuePairs,
|
||||||
|
sumInput: item.sumInput,
|
||||||
|
};
|
||||||
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
handleEmitFun(payload) {
|
handleEmitFun(payload) {
|
||||||
console.log('payload', payload);
|
console.log('payload', payload);
|
||||||
},
|
},
|
||||||
|
@ -1,80 +0,0 @@
|
|||||||
{
|
|
||||||
"tableProps": [
|
|
||||||
{
|
|
||||||
"prop": "inspectionContent",
|
|
||||||
"label": "检测内容",
|
|
||||||
"align": "center"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"prop": "2023-03-18T00:00:00",
|
|
||||||
"label": "2023-03-18T00:00:00",
|
|
||||||
"align": "center",
|
|
||||||
"children": [
|
|
||||||
{
|
|
||||||
"prop": "2023-03-18T00:00:00-产线1",
|
|
||||||
"label": "产线1",
|
|
||||||
"align": "center"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"prop": "2023-03-18T00:00:00-产线2",
|
|
||||||
"label": "产线2",
|
|
||||||
"align": "center"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"prop": "2023-03-18T00:00:00-产线3",
|
|
||||||
"label": "产线3",
|
|
||||||
"align": "center"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"prop": "2023-03-18T00:00:00-产线4",
|
|
||||||
"label": "产线4",
|
|
||||||
"align": "center"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"prop": "2023-03-18T00:00:00-产线5",
|
|
||||||
"label": "产线5",
|
|
||||||
"align": "center"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"prop": "2023-03-18T01:00:00",
|
|
||||||
"label": "2023-03-18T01:00:00",
|
|
||||||
"align": "center",
|
|
||||||
"children": [
|
|
||||||
{
|
|
||||||
"prop": "2023-03-18T01:00:00-产线1",
|
|
||||||
"label": "产线1",
|
|
||||||
"align": "center"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"prop": "2023-03-18T01:00:00-产线2",
|
|
||||||
"label": "产线2",
|
|
||||||
"align": "center"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"prop": "2023-03-18T01:00:00-产线3",
|
|
||||||
"label": "产线3",
|
|
||||||
"align": "center"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"prop": "2023-03-18T02:00:00",
|
|
||||||
"label": "2023-03-18T02:00:00",
|
|
||||||
"align": "center",
|
|
||||||
"children": [
|
|
||||||
{
|
|
||||||
"prop": "2023-03-18T02:00:00-产线1",
|
|
||||||
"label": "产线1",
|
|
||||||
"align": "center"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"prop": "2023-03-18T02:00:00-产线2",
|
|
||||||
"label": "产线2",
|
|
||||||
"align": "center"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user