Compare commits
No commits in common. "42550264c8fc08069a1fe68c39a5fa8fa61fb7a0" and "727f7d57c37a133d7d4ac3cc5eb2869c95933e4d" have entirely different histories.
42550264c8
...
727f7d57c3
Binary file not shown.
Before Width: | Height: | Size: 710 B |
Binary file not shown.
Before Width: | Height: | Size: 205 KiB |
Binary file not shown.
Before Width: | Height: | Size: 2.0 KiB |
Binary file not shown.
Before Width: | Height: | Size: 3.2 KiB |
@ -10,8 +10,7 @@ body {
|
|||||||
-moz-osx-font-smoothing: grayscale;
|
-moz-osx-font-smoothing: grayscale;
|
||||||
-webkit-font-smoothing: antialiased;
|
-webkit-font-smoothing: antialiased;
|
||||||
text-rendering: optimizeLegibility;
|
text-rendering: optimizeLegibility;
|
||||||
font-family: Helvetica Neue, Helvetica, PingFang SC, Hiragino Sans GB,
|
font-family: Helvetica Neue, Helvetica, PingFang SC, Hiragino Sans GB, Microsoft YaHei, Arial, sans-serif;
|
||||||
Microsoft YaHei, Arial, sans-serif;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// label {
|
// label {
|
||||||
@ -100,7 +99,7 @@ div:focus {
|
|||||||
visibility: hidden;
|
visibility: hidden;
|
||||||
display: block;
|
display: block;
|
||||||
font-size: 0;
|
font-size: 0;
|
||||||
content: ' ';
|
content: " ";
|
||||||
clear: both;
|
clear: both;
|
||||||
height: 0;
|
height: 0;
|
||||||
}
|
}
|
||||||
@ -114,8 +113,7 @@ aside {
|
|||||||
display: block;
|
display: block;
|
||||||
line-height: 32px;
|
line-height: 32px;
|
||||||
font-size: 16px;
|
font-size: 16px;
|
||||||
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen,
|
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;
|
||||||
Ubuntu, Cantarell, 'Fira Sans', 'Droid Sans', 'Helvetica Neue', sans-serif;
|
|
||||||
color: #2c3e50;
|
color: #2c3e50;
|
||||||
-webkit-font-smoothing: antialiased;
|
-webkit-font-smoothing: antialiased;
|
||||||
-moz-osx-font-smoothing: grayscale;
|
-moz-osx-font-smoothing: grayscale;
|
||||||
@ -141,7 +139,7 @@ aside {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.text-center {
|
.text-center {
|
||||||
text-align: center;
|
text-align: center
|
||||||
}
|
}
|
||||||
|
|
||||||
.sub-navbar {
|
.sub-navbar {
|
||||||
@ -152,13 +150,7 @@ aside {
|
|||||||
text-align: right;
|
text-align: right;
|
||||||
padding-right: 20px;
|
padding-right: 20px;
|
||||||
transition: 600ms ease position;
|
transition: 600ms ease position;
|
||||||
background: linear-gradient(
|
background: linear-gradient(90deg, rgba(32, 182, 249, 1) 0%, rgba(32, 182, 249, 1) 0%, rgba(33, 120, 241, 1) 100%, rgba(33, 120, 241, 1) 100%);
|
||||||
90deg,
|
|
||||||
rgba(32, 182, 249, 1) 0%,
|
|
||||||
rgba(32, 182, 249, 1) 0%,
|
|
||||||
rgba(33, 120, 241, 1) 100%,
|
|
||||||
rgba(33, 120, 241, 1) 100%
|
|
||||||
);
|
|
||||||
|
|
||||||
.subtitle {
|
.subtitle {
|
||||||
font-size: 20px;
|
font-size: 20px;
|
||||||
@ -202,21 +194,3 @@ aside {
|
|||||||
.multiselect--active {
|
.multiselect--active {
|
||||||
z-index: 1000 !important;
|
z-index: 1000 !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
.no-data-bg {
|
|
||||||
height: 240px;
|
|
||||||
background: url(../images/no-data-bg.png) 50% 100% / contain
|
|
||||||
no-repeat;
|
|
||||||
position: relative;
|
|
||||||
|
|
||||||
&::after {
|
|
||||||
content: '暂无数据';
|
|
||||||
position: absolute;
|
|
||||||
bottom: 12px;
|
|
||||||
left: 50%;
|
|
||||||
transform: translateX(-50%);
|
|
||||||
color: #ccc;
|
|
||||||
font-size: 18px;
|
|
||||||
letter-spacing: 1px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
@ -53,31 +53,19 @@
|
|||||||
margin-left: 20px;
|
margin-left: 20px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.h1,
|
.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {
|
||||||
.h2,
|
|
||||||
.h3,
|
|
||||||
.h4,
|
|
||||||
.h5,
|
|
||||||
.h6,
|
|
||||||
h1,
|
|
||||||
h2,
|
|
||||||
h3,
|
|
||||||
h4,
|
|
||||||
h5,
|
|
||||||
h6 {
|
|
||||||
font-family: inherit;
|
font-family: inherit;
|
||||||
font-weight: 500;
|
font-weight: 500;
|
||||||
line-height: 1.1;
|
line-height: 1.1;
|
||||||
color: inherit;
|
color: inherit;
|
||||||
}
|
}
|
||||||
|
|
||||||
.el-message-box__status + .el-message-box__message {
|
.el-message-box__status + .el-message-box__message{
|
||||||
word-break: break-word;
|
word-break: break-word;
|
||||||
}
|
}
|
||||||
|
|
||||||
.el-dialog:not(.is-fullscreen) {
|
.el-dialog:not(.is-fullscreen) {
|
||||||
// margin-top: 6vh !important;
|
margin-top: 6vh !important;
|
||||||
margin-top: 12vh !important;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.el-dialog__wrapper.scrollbar .el-dialog .el-dialog__body {
|
.el-dialog__wrapper.scrollbar .el-dialog .el-dialog__body {
|
||||||
@ -87,7 +75,7 @@ h6 {
|
|||||||
padding: 10px 20px 0;
|
padding: 10px 20px 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.el-dialog {
|
.el-dialog{
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
max-width: calc(100% - 30px);
|
max-width: calc(100% - 30px);
|
||||||
@ -98,8 +86,7 @@ h6 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.el-table {
|
.el-table {
|
||||||
.el-table__header-wrapper,
|
.el-table__header-wrapper, .el-table__fixed-header-wrapper {
|
||||||
.el-table__fixed-header-wrapper {
|
|
||||||
th {
|
th {
|
||||||
word-break: break-word;
|
word-break: break-word;
|
||||||
background-color: #f8f8f9;
|
background-color: #f8f8f9;
|
||||||
@ -109,7 +96,7 @@ h6 {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
.el-table__body-wrapper {
|
.el-table__body-wrapper {
|
||||||
.el-button [class*='el-icon-'] + span {
|
.el-button [class*="el-icon-"] + span {
|
||||||
margin-left: 1px;
|
margin-left: 1px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -117,11 +104,11 @@ h6 {
|
|||||||
|
|
||||||
/** 表单布局 **/
|
/** 表单布局 **/
|
||||||
.form-header {
|
.form-header {
|
||||||
font-size: 15px;
|
font-size:15px;
|
||||||
color: #6379bb;
|
color:#6379bb;
|
||||||
border-bottom: 1px solid #ddd;
|
border-bottom:1px solid #ddd;
|
||||||
margin: 8px 10px 25px 10px;
|
margin:8px 10px 25px 10px;
|
||||||
padding-bottom: 5px;
|
padding-bottom:5px
|
||||||
}
|
}
|
||||||
|
|
||||||
/** 表格布局 **/
|
/** 表格布局 **/
|
||||||
@ -137,8 +124,8 @@ h6 {
|
|||||||
.tree-border {
|
.tree-border {
|
||||||
margin-top: 5px;
|
margin-top: 5px;
|
||||||
border: 1px solid #e5e6e7;
|
border: 1px solid #e5e6e7;
|
||||||
background: #ffffff none;
|
background: #FFFFFF none;
|
||||||
border-radius: 4px;
|
border-radius:4px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.pagination-container .el-pagination {
|
.pagination-container .el-pagination {
|
||||||
@ -146,7 +133,7 @@ h6 {
|
|||||||
position: absolute;
|
position: absolute;
|
||||||
}
|
}
|
||||||
|
|
||||||
@media (max-width: 768px) {
|
@media ( max-width : 768px) {
|
||||||
.pagination-container .el-pagination > .el-pagination__jump {
|
.pagination-container .el-pagination > .el-pagination__jump {
|
||||||
display: none !important;
|
display: none !important;
|
||||||
}
|
}
|
||||||
@ -162,14 +149,12 @@ h6 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** 表格更多操作下拉样式 */
|
/** 表格更多操作下拉样式 */
|
||||||
.el-table .el-dropdown-link,
|
.el-table .el-dropdown-link,.el-table .el-dropdown-selfdefine {
|
||||||
.el-table .el-dropdown-selfdefine {
|
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
margin-left: 5px;
|
margin-left: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.el-table .el-dropdown,
|
.el-table .el-dropdown, .el-icon-arrow-down {
|
||||||
.el-icon-arrow-down {
|
|
||||||
font-size: 12px;
|
font-size: 12px;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -224,22 +209,22 @@ h6 {
|
|||||||
/* button color */
|
/* button color */
|
||||||
.el-button--cyan.is-active,
|
.el-button--cyan.is-active,
|
||||||
.el-button--cyan:active {
|
.el-button--cyan:active {
|
||||||
background: #20b2aa;
|
background: #20B2AA;
|
||||||
border-color: #20b2aa;
|
border-color: #20B2AA;
|
||||||
color: #ffffff;
|
color: #FFFFFF;
|
||||||
}
|
}
|
||||||
|
|
||||||
.el-button--cyan:focus,
|
.el-button--cyan:focus,
|
||||||
.el-button--cyan:hover {
|
.el-button--cyan:hover {
|
||||||
background: #48d1cc;
|
background: #48D1CC;
|
||||||
border-color: #48d1cc;
|
border-color: #48D1CC;
|
||||||
color: #ffffff;
|
color: #FFFFFF;
|
||||||
}
|
}
|
||||||
|
|
||||||
.el-button--cyan {
|
.el-button--cyan {
|
||||||
background-color: #20b2aa;
|
background-color: #20B2AA;
|
||||||
border-color: #20b2aa;
|
border-color: #20B2AA;
|
||||||
color: #ffffff;
|
color: #FFFFFF;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* text color */
|
/* text color */
|
||||||
@ -293,10 +278,10 @@ h6 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* 拖拽列样式 */
|
/* 拖拽列样式 */
|
||||||
.sortable-ghost {
|
.sortable-ghost{
|
||||||
opacity: 0.8;
|
opacity: .8;
|
||||||
color: #fff !important;
|
color: #fff!important;
|
||||||
background: #42b983 !important;
|
background: #42b983!important;
|
||||||
}
|
}
|
||||||
|
|
||||||
.top-right-btn {
|
.top-right-btn {
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
import moment from 'moment';
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 用于动态表结构的 tableProps 生成
|
* 用于动态表结构的 tableProps 生成
|
||||||
* @param {*} nameData
|
* @param {*} nameData
|
||||||
@ -18,9 +16,10 @@ export function handleNameData(nameData) {
|
|||||||
function step1(tree1) {
|
function step1(tree1) {
|
||||||
return Array.from(new Set(tree1.map((item) => item.name)))
|
return Array.from(new Set(tree1.map((item) => item.name)))
|
||||||
.sort()
|
.sort()
|
||||||
.map((time) => ({
|
.map((item) => ({
|
||||||
prop: time,
|
prop: item,
|
||||||
label: moment(time).format('YYYY-MM-DD HH:mm:ss'),
|
label: item,
|
||||||
|
align: 'center',
|
||||||
children: [],
|
children: [],
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
@ -34,6 +33,7 @@ function step2(firstTierProps, tree2) {
|
|||||||
parent.children.push({
|
parent.children.push({
|
||||||
label: nd.name,
|
label: nd.name,
|
||||||
prop: `${parent.prop}-${nd.name}`,
|
prop: `${parent.prop}-${nd.name}`,
|
||||||
|
align: 'center',
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -17,7 +17,6 @@
|
|||||||
v-if="tableBtn.length"
|
v-if="tableBtn.length"
|
||||||
slot="handleBtn"
|
slot="handleBtn"
|
||||||
label="操作"
|
label="操作"
|
||||||
:width="120"
|
|
||||||
:method-list="tableBtn"
|
:method-list="tableBtn"
|
||||||
@clickBtn="handleTableBtnClick" />
|
@clickBtn="handleTableBtnClick" />
|
||||||
</base-table>
|
</base-table>
|
||||||
@ -86,11 +85,12 @@ export default {
|
|||||||
width: 180,
|
width: 180,
|
||||||
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
||||||
},
|
},
|
||||||
{ prop: 'equipmentName', label: '设备' },
|
{ prop: 'equipmentName', label: '设备', align: 'center' },
|
||||||
{ prop: 'groupName', label: '分组' },
|
{ prop: 'groupName', label: '分组', align: 'center' },
|
||||||
{
|
{
|
||||||
_action: 'equipment-bind-group-show-alert',
|
_action: 'equipment-bind-group-show-alert',
|
||||||
label: '分组报警',
|
label: '分组报警',
|
||||||
|
align: 'center',
|
||||||
subcomponent: {
|
subcomponent: {
|
||||||
props: ['injectData'],
|
props: ['injectData'],
|
||||||
render: function (h) {
|
render: function (h) {
|
||||||
@ -98,7 +98,7 @@ export default {
|
|||||||
return h(
|
return h(
|
||||||
'el-button',
|
'el-button',
|
||||||
{
|
{
|
||||||
props: { type: 'text' },
|
props: { type: 'text', size: 'mini' },
|
||||||
on: {
|
on: {
|
||||||
click: function () {
|
click: function () {
|
||||||
console.log('inejctdata', _this.injectData);
|
console.log('inejctdata', _this.injectData);
|
||||||
@ -162,9 +162,6 @@ export default {
|
|||||||
label: '设备',
|
label: '设备',
|
||||||
url: '/base/equipment/page?pageNo=1&pageSize=100',
|
url: '/base/equipment/page?pageNo=1&pageSize=100',
|
||||||
prop: 'equipmentId',
|
prop: 'equipmentId',
|
||||||
bind: {
|
|
||||||
filterable: true,
|
|
||||||
},
|
|
||||||
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
@ -176,9 +173,6 @@ export default {
|
|||||||
// depends: '__product_line', // 依赖产线获取数据
|
// depends: '__product_line', // 依赖产线获取数据
|
||||||
// depends: 'productionLineId',
|
// depends: 'productionLineId',
|
||||||
prop: 'groupId',
|
prop: 'groupId',
|
||||||
bind: {
|
|
||||||
filterable: true,
|
|
||||||
},
|
|
||||||
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
@ -229,7 +223,7 @@ export default {
|
|||||||
/** 查询列表 */
|
/** 查询列表 */
|
||||||
getList() {
|
getList() {
|
||||||
this.loading = true;
|
this.loading = true;
|
||||||
_; // 执行查询
|
_// 执行查询
|
||||||
getEquipmentBindGroupPage(this.queryParams).then((response) => {
|
getEquipmentBindGroupPage(this.queryParams).then((response) => {
|
||||||
this.list = response.data.list;
|
this.list = response.data.list;
|
||||||
this.total = response.data.total;
|
this.total = response.data.total;
|
||||||
|
@ -17,7 +17,6 @@
|
|||||||
v-if="tableBtn.length"
|
v-if="tableBtn.length"
|
||||||
slot="handleBtn"
|
slot="handleBtn"
|
||||||
label="操作"
|
label="操作"
|
||||||
:width="120"
|
|
||||||
:method-list="tableBtn"
|
:method-list="tableBtn"
|
||||||
@clickBtn="handleTableBtnClick" />
|
@clickBtn="handleTableBtnClick" />
|
||||||
</base-table>
|
</base-table>
|
||||||
@ -84,26 +83,28 @@ export default {
|
|||||||
width: 180,
|
width: 180,
|
||||||
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
||||||
},
|
},
|
||||||
{ prop: 'productionLine', label: '产线名称' },
|
{ prop: 'productionLine', label: '产线名称', align: 'center' },
|
||||||
{ prop: 'workshopSection', label: '工段名称' },
|
{ prop: 'workshopSection', label: '工段名称', align: 'center' },
|
||||||
{ prop: 'equipment', label: '设备名称' },
|
{ prop: 'equipment', label: '设备名称', align: 'center' },
|
||||||
{ prop: 'sort', label: '工段中排序' },
|
{ prop: 'sort', label: '工段中排序', align: 'center' },
|
||||||
{
|
{
|
||||||
prop: 'lineDataType',
|
prop: 'lineDataType',
|
||||||
label: '产线数据类型',
|
label: '产线数据类型',
|
||||||
|
align: 'center',
|
||||||
filter: (val) =>
|
filter: (val) =>
|
||||||
val != null ? ['无类型', '进口计数', '出口计数'][val] : '-',
|
val != null ? ['无类型', '进口计数', '出口计数'][val] : '-',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
prop: 'sectionDataType',
|
prop: 'sectionDataType',
|
||||||
label: '工段数据类型',
|
label: '工段数据类型',
|
||||||
|
align: 'center',
|
||||||
filter: (val) =>
|
filter: (val) =>
|
||||||
val != null ? ['无类型', '进口计数', '出口计数'][val] : '-',
|
val != null ? ['无类型', '进口计数', '出口计数'][val] : '-',
|
||||||
},
|
},
|
||||||
// {
|
// {
|
||||||
// action: 'show-alert',
|
// action: 'show-alert',
|
||||||
// label: '报警',
|
// label: '报警',
|
||||||
// ,
|
// align: 'center',
|
||||||
// subcomponent: {
|
// subcomponent: {
|
||||||
// props: ['injectData'],
|
// props: ['injectData'],
|
||||||
// render: function (h) {
|
// render: function (h) {
|
||||||
|
@ -17,7 +17,6 @@
|
|||||||
v-if="tableBtn.length"
|
v-if="tableBtn.length"
|
||||||
slot="handleBtn"
|
slot="handleBtn"
|
||||||
label="操作"
|
label="操作"
|
||||||
:width="120"
|
|
||||||
:method-list="tableBtn"
|
:method-list="tableBtn"
|
||||||
@clickBtn="handleTableBtnClick" />
|
@clickBtn="handleTableBtnClick" />
|
||||||
</base-table>
|
</base-table>
|
||||||
@ -85,12 +84,13 @@ export default {
|
|||||||
width: 180,
|
width: 180,
|
||||||
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
||||||
},
|
},
|
||||||
{ prop: 'name', label: '设备分组名称' },
|
{ prop: 'name', label: '设备分组名称', align: 'center' },
|
||||||
{ prop: 'code', label: '设备分组编码' },
|
{ prop: 'code', label: '检测分组编码', align: 'center' },
|
||||||
{ prop: 'remark', label: '备注' },
|
{ prop: 'remark', label: '备注', align: 'center' },
|
||||||
{
|
{
|
||||||
_action: 'equipment-group-show-alert',
|
_action: 'equipment-group-show-alert',
|
||||||
label: '报警',
|
label: '报警',
|
||||||
|
align: 'center',
|
||||||
subcomponent: {
|
subcomponent: {
|
||||||
props: ['injectData'],
|
props: ['injectData'],
|
||||||
render: function (h) {
|
render: function (h) {
|
||||||
@ -98,7 +98,7 @@ export default {
|
|||||||
return h(
|
return h(
|
||||||
'el-button',
|
'el-button',
|
||||||
{
|
{
|
||||||
props: { type: 'text' },
|
props: { type: 'text', size: 'mini' },
|
||||||
on: {
|
on: {
|
||||||
click: function () {
|
click: function () {
|
||||||
console.log('inejctdata', _this.injectData);
|
console.log('inejctdata', _this.injectData);
|
||||||
@ -127,7 +127,7 @@ export default {
|
|||||||
type: 'input',
|
type: 'input',
|
||||||
label: '分组编码',
|
label: '分组编码',
|
||||||
placeholder: '请输入设备分组编码',
|
placeholder: '请输入设备分组编码',
|
||||||
param: 'code',
|
param: 'codes',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
type: 'button',
|
type: 'button',
|
||||||
@ -172,7 +172,6 @@ export default {
|
|||||||
label: '分组编码',
|
label: '分组编码',
|
||||||
prop: 'code',
|
prop: 'code',
|
||||||
url: '/base/equipment-group/getCode',
|
url: '/base/equipment-group/getCode',
|
||||||
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
@ -303,7 +302,11 @@ export default {
|
|||||||
handleDelete(row) {
|
handleDelete(row) {
|
||||||
const id = row.id;
|
const id = row.id;
|
||||||
this.$modal
|
this.$modal
|
||||||
.confirm('是否确认删除设备分组 "' + row.name + '"?')
|
.confirm(
|
||||||
|
'是否确认删除设备分组(用于同类型不同厂家的设备区分)编号为"' +
|
||||||
|
id +
|
||||||
|
'"的数据项?'
|
||||||
|
)
|
||||||
.then(function () {
|
.then(function () {
|
||||||
return deleteEquipmentGroup(id);
|
return deleteEquipmentGroup(id);
|
||||||
})
|
})
|
||||||
|
@ -1,177 +0,0 @@
|
|||||||
<!--
|
|
||||||
filename: dialogForm.vue
|
|
||||||
author: liubin
|
|
||||||
date: 2023-09-11 15:55:13
|
|
||||||
description: DialogForm for equipmentBindSection only
|
|
||||||
-->
|
|
||||||
|
|
||||||
<template>
|
|
||||||
<el-form
|
|
||||||
ref="form"
|
|
||||||
:model="dataForm"
|
|
||||||
label-width="100px"
|
|
||||||
v-loading="formLoading">
|
|
||||||
<el-row :gutter="20">
|
|
||||||
<el-col :span="12">
|
|
||||||
<el-form-item
|
|
||||||
label="报警编码"
|
|
||||||
prop="code"
|
|
||||||
:rules="[{ required: true, message: '不能为空', trigger: 'blur' }]">
|
|
||||||
<el-input
|
|
||||||
v-model="dataForm.code"
|
|
||||||
@change="$emit('update', dataForm)"
|
|
||||||
placeholder="请输入工段排序" />
|
|
||||||
</el-form-item>
|
|
||||||
<!--
|
|
||||||
<el-form-item
|
|
||||||
label="报警编码"
|
|
||||||
prop="code"
|
|
||||||
:rules="[{ required: true, message: '不能为空', trigger: 'blur' }]">
|
|
||||||
<el-select
|
|
||||||
v-model="dataForm.code"
|
|
||||||
placeholder="请选择产线"
|
|
||||||
@change="handleProductlineChange">
|
|
||||||
<el-option
|
|
||||||
v-for="opt in productionLineList"
|
|
||||||
:key="opt.value"
|
|
||||||
:label="opt.label"
|
|
||||||
:value="opt.value" />
|
|
||||||
</el-select>
|
|
||||||
</el-form-item> -->
|
|
||||||
</el-col>
|
|
||||||
|
|
||||||
<el-col :span="12">
|
|
||||||
<el-form-item
|
|
||||||
label="报警类型"
|
|
||||||
prop="type"
|
|
||||||
:rules="[{ required: true, message: '不能为空', trigger: 'blur' }]">
|
|
||||||
<el-select
|
|
||||||
v-model="dataForm.type"
|
|
||||||
placeholder="请选择报警类型"
|
|
||||||
@change="$emit('update', dataForm)">
|
|
||||||
<el-option
|
|
||||||
v-for="opt in [
|
|
||||||
{ label: '布尔型', value: 2 },
|
|
||||||
{ label: '字符型', value: 1 },
|
|
||||||
]"
|
|
||||||
:key="opt.value"
|
|
||||||
:label="opt.label"
|
|
||||||
:value="opt.value" />
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
</el-col>
|
|
||||||
</el-row>
|
|
||||||
<el-row :gutter="20">
|
|
||||||
<el-col :span="12">
|
|
||||||
<el-form-item
|
|
||||||
label="报警级别"
|
|
||||||
prop="grade"
|
|
||||||
:rules="[{ required: true, message: '不能为空', trigger: 'blur' }]">
|
|
||||||
<el-select
|
|
||||||
v-model="dataForm.grade"
|
|
||||||
placeholder="请选择报警级别"
|
|
||||||
@change="$emit('update', dataForm)">
|
|
||||||
<el-option
|
|
||||||
v-for="opt in getDictDatas(DICT_TYPE.EQU_ALARM_LEVEL)"
|
|
||||||
:key="opt.value"
|
|
||||||
:label="opt.label"
|
|
||||||
:value="opt.value" />
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
</el-col>
|
|
||||||
|
|
||||||
<el-col :span="12">
|
|
||||||
<el-form-item
|
|
||||||
v-if="+dataForm.type == 1"
|
|
||||||
label="设备报警编码"
|
|
||||||
prop="alarmCode">
|
|
||||||
<el-input
|
|
||||||
v-model="dataForm.alarmCode"
|
|
||||||
@change="$emit('update', dataForm)"
|
|
||||||
placeholder="请输入设备报警编码" />
|
|
||||||
</el-form-item>
|
|
||||||
</el-col>
|
|
||||||
</el-row>
|
|
||||||
<el-row :gutter="20">
|
|
||||||
<el-col :span="12">
|
|
||||||
<el-form-item
|
|
||||||
label="参数列名"
|
|
||||||
prop="plcParamName"
|
|
||||||
:rules="[{ required: true, message: '不能为空', trigger: 'blur' }]">
|
|
||||||
<el-input
|
|
||||||
v-model="dataForm.plcParamName"
|
|
||||||
placeholder="请输入参数列名"
|
|
||||||
@change="$emit('update', dataForm)"></el-input>
|
|
||||||
</el-form-item>
|
|
||||||
</el-col>
|
|
||||||
<el-col :span="12">
|
|
||||||
<el-form-item
|
|
||||||
label="报警内容"
|
|
||||||
prop="alarmContent"
|
|
||||||
:rules="[{ required: true, message: '不能为空', trigger: 'blur' }]">
|
|
||||||
<el-input
|
|
||||||
v-model="dataForm.alarmContent"
|
|
||||||
placeholder="请输入报警内容"
|
|
||||||
@change="$emit('update', dataForm)"></el-input>
|
|
||||||
</el-form-item>
|
|
||||||
</el-col>
|
|
||||||
</el-row>
|
|
||||||
</el-form>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script>
|
|
||||||
export default {
|
|
||||||
name: 'DialogForm',
|
|
||||||
model: {
|
|
||||||
prop: 'dataForm',
|
|
||||||
event: 'update',
|
|
||||||
},
|
|
||||||
emits: ['update'],
|
|
||||||
components: {},
|
|
||||||
props: {
|
|
||||||
dataForm: {
|
|
||||||
type: Object,
|
|
||||||
default: () => ({}),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
data() {
|
|
||||||
return {
|
|
||||||
formLoading: true,
|
|
||||||
};
|
|
||||||
},
|
|
||||||
mounted() {
|
|
||||||
this.getCode('/base/equipment-group-alarm/getCode').then((code) => {
|
|
||||||
this.formLoading = false;
|
|
||||||
this.$emit('update', {
|
|
||||||
...this.dataForm,
|
|
||||||
code,
|
|
||||||
});
|
|
||||||
});
|
|
||||||
},
|
|
||||||
methods: {
|
|
||||||
/** 模拟透传 ref */
|
|
||||||
validate(cb) {
|
|
||||||
return this.$refs.form.validate(cb);
|
|
||||||
},
|
|
||||||
resetFields(args) {
|
|
||||||
return this.$refs.form.resetFields(args);
|
|
||||||
},
|
|
||||||
async handleProductlineChange(id) {
|
|
||||||
await this.getWorksectionList(id);
|
|
||||||
this.dataForm.workshopSectionId = null;
|
|
||||||
this.$emit('update', this.dataForm);
|
|
||||||
},
|
|
||||||
async getCode(url) {
|
|
||||||
const response = await this.$axios(url);
|
|
||||||
return response.data;
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style scoped lang="scss">
|
|
||||||
.el-date-editor,
|
|
||||||
.el-select {
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
</style>
|
|
@ -17,7 +17,6 @@
|
|||||||
v-if="tableBtn.length"
|
v-if="tableBtn.length"
|
||||||
slot="handleBtn"
|
slot="handleBtn"
|
||||||
label="操作"
|
label="操作"
|
||||||
:width="120"
|
|
||||||
:method-list="tableBtn"
|
:method-list="tableBtn"
|
||||||
@clickBtn="handleTableBtnClick" />
|
@clickBtn="handleTableBtnClick" />
|
||||||
</base-table>
|
</base-table>
|
||||||
@ -38,7 +37,7 @@
|
|||||||
@close="cancel"
|
@close="cancel"
|
||||||
@cancel="cancel"
|
@cancel="cancel"
|
||||||
@confirm="submitForm">
|
@confirm="submitForm">
|
||||||
<DialogForm v-if="open" ref="form" v-model="form" :rows="rows" />
|
<DialogForm v-if="open" ref="form" :dataForm="form" :rows="rows" />
|
||||||
</base-dialog>
|
</base-dialog>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
@ -55,11 +54,10 @@ import {
|
|||||||
import basicPageMixin from '@/mixins/lb/basicPageMixin';
|
import basicPageMixin from '@/mixins/lb/basicPageMixin';
|
||||||
import moment from 'moment';
|
import moment from 'moment';
|
||||||
import { publicFormatter } from '@/utils/dict';
|
import { publicFormatter } from '@/utils/dict';
|
||||||
import DialogForm from './dialogForm.vue';
|
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'EquipmentGroupAlarm',
|
name: 'EquipmentGroupAlarm',
|
||||||
components: { DialogForm },
|
components: {},
|
||||||
mixins: [basicPageMixin],
|
mixins: [basicPageMixin],
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
@ -86,27 +84,22 @@ export default {
|
|||||||
width: 180,
|
width: 180,
|
||||||
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
||||||
},
|
},
|
||||||
{ width: 240, prop: 'code', label: '报警编码' },
|
{ prop: 'code', label: '报警编码', align: 'center' },
|
||||||
{
|
{ prop: 'type', label: '报警类型', align: 'center' },
|
||||||
prop: 'type',
|
|
||||||
label: '报警类型',
|
|
||||||
filter: (val) =>
|
|
||||||
val != null ? ['-', '字符型', '布尔型', '-'][val] : '-',
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
prop: 'grade',
|
prop: 'grade',
|
||||||
label: '报警级别',
|
label: '报警级别',
|
||||||
|
align: 'center',
|
||||||
filter: publicFormatter(this.DICT_TYPE.EQU_ALARM_LEVEL),
|
filter: publicFormatter(this.DICT_TYPE.EQU_ALARM_LEVEL),
|
||||||
},
|
},
|
||||||
{ prop: 'alarmCode', label: '设备报警编码' },
|
{ prop: 'alarmCode', label: '设备报警编码', align: 'center' },
|
||||||
{ prop: 'plcParamName', label: '参数列名' },
|
{ prop: 'plcParamName', label: '参数列名', align: 'center' },
|
||||||
{ prop: 'alarmContent', label: '报警内容' },
|
{ prop: 'alarmContent', label: '报警内容', align: 'center' },
|
||||||
],
|
],
|
||||||
searchBarFormConfig: [
|
searchBarFormConfig: [
|
||||||
{
|
{
|
||||||
type: 'input',
|
type: 'input',
|
||||||
label: '设备分组编码',
|
label: '设备分组编码',
|
||||||
width: '220',
|
|
||||||
placeholder: '/',
|
placeholder: '/',
|
||||||
param: 'equipmentGroupCode',
|
param: 'equipmentGroupCode',
|
||||||
defaultSelect: null,
|
defaultSelect: null,
|
||||||
@ -188,14 +181,14 @@ export default {
|
|||||||
},
|
},
|
||||||
// 表单参数
|
// 表单参数
|
||||||
form: {
|
form: {
|
||||||
id: null,
|
id: undefined,
|
||||||
equipmentGroupId: null,
|
equipmentGroupId: undefined,
|
||||||
code: null,
|
code: undefined,
|
||||||
type: null,
|
type: undefined,
|
||||||
grade: null,
|
grade: undefined,
|
||||||
alarmCode: null,
|
alarmCode: undefined,
|
||||||
alarmContent: null,
|
alarmContent: undefined,
|
||||||
plcParamName: null,
|
plcParamName: undefined,
|
||||||
},
|
},
|
||||||
// // 表单校验
|
// // 表单校验
|
||||||
// rules: {
|
// rules: {
|
||||||
@ -256,14 +249,14 @@ export default {
|
|||||||
/** 表单重置 */
|
/** 表单重置 */
|
||||||
reset() {
|
reset() {
|
||||||
this.form = {
|
this.form = {
|
||||||
id: null,
|
id: undefined,
|
||||||
equipmentGroupId: null,
|
equipmentGroupId: undefined,
|
||||||
code: null,
|
code: undefined,
|
||||||
type: null,
|
type: undefined,
|
||||||
grade: null,
|
grade: undefined,
|
||||||
alarmCode: null,
|
alarmCode: undefined,
|
||||||
alarmContent: null,
|
alarmContent: undefined,
|
||||||
plcParamName: null,
|
plcParamName: undefined,
|
||||||
};
|
};
|
||||||
this.resetForm('form');
|
this.resetForm('form');
|
||||||
},
|
},
|
||||||
@ -328,7 +321,7 @@ export default {
|
|||||||
handleDelete(row) {
|
handleDelete(row) {
|
||||||
const id = row.id;
|
const id = row.id;
|
||||||
this.$modal
|
this.$modal
|
||||||
.confirm('是否确认删除该报警?')
|
.confirm('是否确认删除设备分组报警明细编号为"' + id + '"的数据项?')
|
||||||
.then(function () {
|
.then(function () {
|
||||||
return deleteEquipmentGroupAlarm(id);
|
return deleteEquipmentGroupAlarm(id);
|
||||||
})
|
})
|
||||||
|
@ -12,7 +12,6 @@
|
|||||||
:page="queryParams.pageNo"
|
:page="queryParams.pageNo"
|
||||||
:limit="queryParams.pageSize"
|
:limit="queryParams.pageSize"
|
||||||
:table-data="list"
|
:table-data="list"
|
||||||
ref="pageTable"
|
|
||||||
@emitFun="handleEmitFun">
|
@emitFun="handleEmitFun">
|
||||||
<method-btn
|
<method-btn
|
||||||
v-if="tableBtn.length"
|
v-if="tableBtn.length"
|
||||||
@ -59,12 +58,9 @@ const switchBtn = {
|
|||||||
name: 'SwitchBtn',
|
name: 'SwitchBtn',
|
||||||
props: ['injectData'],
|
props: ['injectData'],
|
||||||
data() {
|
data() {
|
||||||
return {};
|
return {
|
||||||
},
|
active: +this.injectData[this.injectData.prop] == 1 ? true : false,
|
||||||
computed: {
|
};
|
||||||
active() {
|
|
||||||
return +this.injectData[this.injectData.prop] == 1 ? true : false;
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
methods: {},
|
methods: {},
|
||||||
render: function (h) {
|
render: function (h) {
|
||||||
@ -76,6 +72,8 @@ const switchBtn = {
|
|||||||
},
|
},
|
||||||
on: {
|
on: {
|
||||||
change: (newVal) => {
|
change: (newVal) => {
|
||||||
|
this.active = !this.active;
|
||||||
|
console.log('changed emit', newVal);
|
||||||
this.$emit('emitData', {
|
this.$emit('emitData', {
|
||||||
action: 'update-collect',
|
action: 'update-collect',
|
||||||
payload: {
|
payload: {
|
||||||
@ -97,7 +95,6 @@ export default {
|
|||||||
components: {},
|
components: {},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
tableKey: Math.random(),
|
|
||||||
searchBarKeys: ['name', 'plcTableName'],
|
searchBarKeys: ['name', 'plcTableName'],
|
||||||
tableBtn: [
|
tableBtn: [
|
||||||
this.$auth.hasPermi('base:equipment-plc:update')
|
this.$auth.hasPermi('base:equipment-plc:update')
|
||||||
@ -121,16 +118,17 @@ export default {
|
|||||||
// width: 180,
|
// width: 180,
|
||||||
// filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
// filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
||||||
// },
|
// },
|
||||||
{ prop: 'code', label: '编码' },
|
{ prop: 'code', label: '编码', align: 'center' },
|
||||||
{ prop: 'plcTableName', label: '关联表名' },
|
{ prop: 'plcTableName', label: '关联表名', align: 'center' },
|
||||||
{ prop: 'name', label: '标识名称' },
|
{ prop: 'name', label: '标识名称', align: 'center' },
|
||||||
{ prop: 'enName', label: '英文名称' },
|
{ prop: 'enName', label: '英文名称', align: 'center' },
|
||||||
{
|
{
|
||||||
prop: 'collection',
|
prop: 'collection',
|
||||||
label: '是否采集',
|
label: '是否采集',
|
||||||
|
align: 'center',
|
||||||
subcomponent: switchBtn,
|
subcomponent: switchBtn,
|
||||||
},
|
},
|
||||||
{ prop: 'description', label: '描述' },
|
{ prop: 'description', label: '描述', align: 'center' },
|
||||||
],
|
],
|
||||||
searchBarFormConfig: [
|
searchBarFormConfig: [
|
||||||
{
|
{
|
||||||
@ -187,7 +185,6 @@ export default {
|
|||||||
label: '编码',
|
label: '编码',
|
||||||
prop: 'code',
|
prop: 'code',
|
||||||
url: '/base/equipment-group/getCode',
|
url: '/base/equipment-group/getCode',
|
||||||
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
@ -195,7 +192,7 @@ export default {
|
|||||||
input: true,
|
input: true,
|
||||||
label: '标识',
|
label: '标识',
|
||||||
prop: 'name',
|
prop: 'name',
|
||||||
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
// rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
||||||
// bind: {
|
// bind: {
|
||||||
// disabled: true, // some condition, like detail mode...
|
// disabled: true, // some condition, like detail mode...
|
||||||
// }
|
// }
|
||||||
@ -270,7 +267,6 @@ export default {
|
|||||||
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;
|
||||||
// this.tableKey = Math.random(); // method 1
|
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
/** 取消按钮 */
|
/** 取消按钮 */
|
||||||
|
@ -17,7 +17,6 @@
|
|||||||
v-if="tableBtn.length"
|
v-if="tableBtn.length"
|
||||||
slot="handleBtn"
|
slot="handleBtn"
|
||||||
label="操作"
|
label="操作"
|
||||||
:width="120"
|
|
||||||
:method-list="tableBtn"
|
:method-list="tableBtn"
|
||||||
@clickBtn="handleTableBtnClick" />
|
@clickBtn="handleTableBtnClick" />
|
||||||
</base-table>
|
</base-table>
|
||||||
@ -62,7 +61,7 @@ export default {
|
|||||||
components: {},
|
components: {},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
searchBarKeys: ['equipmentId', 'plcId'],
|
searchBarKeys: ['name', 'plcTableName'],
|
||||||
// tableBtn: [
|
// tableBtn: [
|
||||||
// this.$auth.hasPermi('base:equipment-plc:update')
|
// this.$auth.hasPermi('base:equipment-plc:update')
|
||||||
// ? {
|
// ? {
|
||||||
@ -99,17 +98,18 @@ export default {
|
|||||||
// width: 180,
|
// width: 180,
|
||||||
// filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
// filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
||||||
// },
|
// },
|
||||||
{ prop: 'productionLine', label: '产线' },
|
{ prop: 'productionLine', label: '产线', align: 'center' },
|
||||||
{ prop: 'workshopSection', label: '工段' },
|
{ prop: 'workshopSection', label: '工段', align: 'center' },
|
||||||
{ prop: 'equipmentName', label: '设备名' },
|
{ prop: 'equipmentName', label: '设备名', align: 'center' },
|
||||||
{ prop: 'equipmentCode', label: '设备编码' },
|
{ prop: 'equipmentCode', label: '设备编码', align: 'center' },
|
||||||
{ prop: 'plcCode', label: '关联表编码' },
|
{ prop: 'plcCode', label: '关联表编码', align: 'center' },
|
||||||
{ prop: 'plcTableName', label: '关联表名' },
|
{ prop: 'plcTableName', label: '关联表名', align: 'center' },
|
||||||
{ prop: 'plcName', label: '标识名称' },
|
{ prop: 'plcName', label: '标识名称', align: 'center' },
|
||||||
{ prop: 'bindingParameters', label: '绑定参数数量' },
|
{ prop: 'bindingParameters', label: '绑定参数数量', align: 'center' },
|
||||||
{
|
{
|
||||||
_action: 'params-bind',
|
_action: 'params-bind',
|
||||||
label: '查看绑定',
|
label: '查看绑定',
|
||||||
|
align: 'center',
|
||||||
subcomponent: {
|
subcomponent: {
|
||||||
props: ['injectData'],
|
props: ['injectData'],
|
||||||
render: function (h) {
|
render: function (h) {
|
||||||
@ -136,18 +136,16 @@ export default {
|
|||||||
],
|
],
|
||||||
searchBarFormConfig: [
|
searchBarFormConfig: [
|
||||||
{
|
{
|
||||||
type: 'select',
|
type: 'input',
|
||||||
label: '设备名',
|
label: '设备名',
|
||||||
placeholder: '请选择设备',
|
placeholder: '请输入设备名',
|
||||||
param: 'equipmentId',
|
param: 'equipmentId',
|
||||||
selectOptions: [],
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
type: 'select',
|
type: 'input',
|
||||||
label: 'PLC编码',
|
label: '编码',
|
||||||
placeholder: '请选择编码',
|
placeholder: '请输入编码',
|
||||||
param: 'plcId',
|
param: 'plcId',
|
||||||
selectOptions: [],
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
type: 'button',
|
type: 'button',
|
||||||
@ -181,7 +179,6 @@ export default {
|
|||||||
select: true,
|
select: true,
|
||||||
label: '关联表名',
|
label: '关联表名',
|
||||||
prop: 'plcId',
|
prop: 'plcId',
|
||||||
labelKey: `plcTableName`,
|
|
||||||
url: '/base/equipment-plc/listAll',
|
url: '/base/equipment-plc/listAll',
|
||||||
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
||||||
},
|
},
|
||||||
@ -210,44 +207,8 @@ export default {
|
|||||||
},
|
},
|
||||||
created() {
|
created() {
|
||||||
this.getList();
|
this.getList();
|
||||||
this.initSearchOptions();
|
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
async getEquipmentOptions() {
|
|
||||||
const res = await this.$axios({
|
|
||||||
url: '/base/equipment/listAll',
|
|
||||||
method: 'get',
|
|
||||||
});
|
|
||||||
return res.data;
|
|
||||||
},
|
|
||||||
|
|
||||||
async getPlcOptions() {
|
|
||||||
const res = await this.$axios({
|
|
||||||
url: '/base/equipment-plc/listAll',
|
|
||||||
method: 'get',
|
|
||||||
});
|
|
||||||
return res.data;
|
|
||||||
},
|
|
||||||
|
|
||||||
/** 初始化查询条件 */
|
|
||||||
async initSearchOptions() {
|
|
||||||
Promise.all([this.getEquipmentOptions(), this.getPlcOptions()]).then(
|
|
||||||
([eqList, plcList]) => {
|
|
||||||
this.searchBarFormConfig[0].selectOptions = eqList.map((item) => {
|
|
||||||
return {
|
|
||||||
name: item.name,
|
|
||||||
id: item.id,
|
|
||||||
};
|
|
||||||
});
|
|
||||||
this.searchBarFormConfig[1].selectOptions = plcList.map((item) => {
|
|
||||||
return {
|
|
||||||
name: item.name,
|
|
||||||
id: item.id,
|
|
||||||
};
|
|
||||||
});
|
|
||||||
}
|
|
||||||
);
|
|
||||||
},
|
|
||||||
/** 覆盖 handleEmitFun 的默认实现 */
|
/** 覆盖 handleEmitFun 的默认实现 */
|
||||||
handleEmitFun({ action, payload }) {
|
handleEmitFun({ action, payload }) {
|
||||||
switch (action) {
|
switch (action) {
|
||||||
|
@ -17,7 +17,6 @@
|
|||||||
v-if="tableBtn.length"
|
v-if="tableBtn.length"
|
||||||
slot="handleBtn"
|
slot="handleBtn"
|
||||||
label="操作"
|
label="操作"
|
||||||
:width="120"
|
|
||||||
:method-list="tableBtn"
|
:method-list="tableBtn"
|
||||||
@clickBtn="handleTableBtnClick" />
|
@clickBtn="handleTableBtnClick" />
|
||||||
</base-table>
|
</base-table>
|
||||||
@ -69,27 +68,29 @@ export default {
|
|||||||
// width: 180,
|
// width: 180,
|
||||||
// filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
// filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
||||||
// },
|
// },
|
||||||
{ prop: 'plcParamName', label: '参数列名' },
|
{ prop: 'plcParamName', label: '参数列名', align: 'center' },
|
||||||
{ prop: 'name', label: '参数名称' },
|
{ prop: 'name', label: '参数名称', align: 'center' },
|
||||||
{
|
{
|
||||||
prop: 'unit',
|
prop: 'unit',
|
||||||
label: '单位',
|
label: '单位',
|
||||||
|
align: 'center',
|
||||||
filter: publicFormatter('unit_dict'),
|
filter: publicFormatter('unit_dict'),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
prop: 'collection',
|
prop: 'collection',
|
||||||
label: '是否采集',
|
label: '是否采集',
|
||||||
|
align: 'center',
|
||||||
filter: (val) => (val != null ? ['否', '是'][val] : '-'),
|
filter: (val) => (val != null ? ['否', '是'][val] : '-'),
|
||||||
},
|
},
|
||||||
{ prop: 'minValue', label: '最小值' },
|
{ prop: 'minValue', label: '最小值', align: 'center' },
|
||||||
{ prop: 'maxValue', label: '最大值' },
|
{ prop: 'maxValue', label: '最大值', align: 'center' },
|
||||||
{ prop: 'defaultValue', label: '标准值' },
|
{ prop: 'defaultValue', label: '标准值', align: 'center' },
|
||||||
{ prop: 'description', label: '描述' },
|
{ prop: 'description', label: '描述', align: 'center' },
|
||||||
{ prop: 'remark', label: '备注' },
|
{ prop: 'remark', label: '备注', align: 'center' },
|
||||||
// {
|
// {
|
||||||
// _action: 'params-bind',
|
// _action: 'params-bind',
|
||||||
// label: '查看绑定',
|
// label: '查看绑定',
|
||||||
// ,
|
// align: 'center',
|
||||||
// subcomponent: {
|
// subcomponent: {
|
||||||
// props: ['injectData'],
|
// props: ['injectData'],
|
||||||
// render: function (h) {
|
// render: function (h) {
|
||||||
@ -156,7 +157,7 @@ export default {
|
|||||||
{
|
{
|
||||||
type: 'number',
|
type: 'number',
|
||||||
message: '请输入正确的数字',
|
message: '请输入正确的数字',
|
||||||
trigger: 'change',
|
trigger: 'blur',
|
||||||
transform: (val) => Number(val),
|
transform: (val) => Number(val),
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
@ -166,13 +167,10 @@ export default {
|
|||||||
label: '最大值',
|
label: '最大值',
|
||||||
prop: 'maxValue',
|
prop: 'maxValue',
|
||||||
rules: [
|
rules: [
|
||||||
{
|
|
||||||
required: false,
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
type: 'number',
|
type: 'number',
|
||||||
message: '请输入正确的数字',
|
message: '请输入正确的数字',
|
||||||
trigger: 'change',
|
trigger: 'blur',
|
||||||
transform: (val) => Number(val),
|
transform: (val) => Number(val),
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
@ -351,8 +349,8 @@ export default {
|
|||||||
plcParamName: undefined,
|
plcParamName: undefined,
|
||||||
name: undefined,
|
name: undefined,
|
||||||
unit: undefined,
|
unit: undefined,
|
||||||
minValue: null,
|
minValue: undefined,
|
||||||
maxValue: null,
|
maxValue: undefined,
|
||||||
defaultValue: undefined,
|
defaultValue: undefined,
|
||||||
collection: undefined,
|
collection: undefined,
|
||||||
description: undefined,
|
description: undefined,
|
||||||
|
@ -16,7 +16,6 @@
|
|||||||
<method-btn
|
<method-btn
|
||||||
v-if="tableBtn.length"
|
v-if="tableBtn.length"
|
||||||
slot="handleBtn"
|
slot="handleBtn"
|
||||||
:width="120"
|
|
||||||
label="操作"
|
label="操作"
|
||||||
:method-list="tableBtn"
|
:method-list="tableBtn"
|
||||||
@clickBtn="handleTableBtnClick" />
|
@clickBtn="handleTableBtnClick" />
|
||||||
@ -148,14 +147,15 @@ export default {
|
|||||||
width: 180,
|
width: 180,
|
||||||
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
||||||
},
|
},
|
||||||
{ prop: 'name', label: '设备名称' },
|
{ prop: 'name', label: '设备名称', align: 'center' },
|
||||||
{ width: 256, prop: 'code', label: '检测编码' },
|
{ prop: 'code', label: '检测编码', align: 'center' },
|
||||||
{ prop: 'equipmentType', label: '设备类型' },
|
{ prop: 'equipmentType', label: '设备类型', align: 'center' },
|
||||||
{ prop: 'enName', label: '英文名称' },
|
{ prop: 'enName', label: '英文名称', align: 'center' },
|
||||||
{ prop: 'abbr', label: '缩写' },
|
{ prop: 'abbr', label: '缩写', align: 'center' },
|
||||||
{
|
{
|
||||||
action: 'show-detail',
|
action: 'show-detail',
|
||||||
label: '详情',
|
label: '详情',
|
||||||
|
align: 'center',
|
||||||
subcomponent: {
|
subcomponent: {
|
||||||
props: ['injectData'],
|
props: ['injectData'],
|
||||||
render: function (h) {
|
render: function (h) {
|
||||||
@ -377,8 +377,8 @@ export default {
|
|||||||
width: 180,
|
width: 180,
|
||||||
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
||||||
},
|
},
|
||||||
{ prop: 'name', label: '属性名称' },
|
{ prop: 'name', label: '属性名称', align: 'center' },
|
||||||
{ prop: 'value', label: '属性值' },
|
{ prop: 'value', label: '属性值', align: 'center' },
|
||||||
],
|
],
|
||||||
// 是否显示弹出层
|
// 是否显示弹出层
|
||||||
open: false,
|
open: false,
|
||||||
|
@ -17,7 +17,6 @@
|
|||||||
v-if="tableBtn.length"
|
v-if="tableBtn.length"
|
||||||
slot="handleBtn"
|
slot="handleBtn"
|
||||||
label="操作"
|
label="操作"
|
||||||
:width="120"
|
|
||||||
:method-list="tableBtn"
|
:method-list="tableBtn"
|
||||||
@clickBtn="handleTableBtnClick" />
|
@clickBtn="handleTableBtnClick" />
|
||||||
</base-table>
|
</base-table>
|
||||||
@ -86,9 +85,9 @@ export default {
|
|||||||
width: 180,
|
width: 180,
|
||||||
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
||||||
},
|
},
|
||||||
{ prop: 'name', label: '设备类型名称', },
|
{ prop: 'name', label: '设备类型名称', align: 'center' },
|
||||||
{ prop: 'code', label: '检测类型编码', },
|
{ prop: 'code', label: '检测类型编码', align: 'center' },
|
||||||
{ prop: 'remark', label: '备注', },
|
{ prop: 'remark', label: '备注', align: 'center' },
|
||||||
],
|
],
|
||||||
searchBarFormConfig: [
|
searchBarFormConfig: [
|
||||||
{
|
{
|
||||||
|
@ -6,34 +6,7 @@
|
|||||||
-->
|
-->
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div class="chart-grid-item" style="">
|
<div class="pie-chart" :data-eqname="value.equipmentName || 'Default'"></div>
|
||||||
<div
|
|
||||||
class="pie-chart"
|
|
||||||
ref="pieChart"
|
|
||||||
:data-eqname="value.equipmentName || 'Default'"></div>
|
|
||||||
<div class="data-view">
|
|
||||||
<div class="data-view__item">
|
|
||||||
<!-- <div class="data-view__item__value">111</div> -->
|
|
||||||
<div class="data-view__item__value">{{ textData.workTime }}</div>
|
|
||||||
<div class="data-view__item__title blue">工作时长</div>
|
|
||||||
</div>
|
|
||||||
<div class="data-view__item">
|
|
||||||
<!-- <div class="data-view__item__value">22</div> -->
|
|
||||||
<div class="data-view__item__value">{{ textData.stopTime }}</div>
|
|
||||||
<div class="data-view__item__title green">停机时长</div>
|
|
||||||
</div>
|
|
||||||
<div class="data-view__item">
|
|
||||||
<!-- <div class="data-view__item__value">10</div> -->
|
|
||||||
<div class="data-view__item__value">{{ textData.downTime }}</div>
|
|
||||||
<div class="data-view__item__title purple">故障时长</div>
|
|
||||||
</div>
|
|
||||||
<div class="data-view__item">
|
|
||||||
<!-- <div class="data-view__item__value">100%</div> -->
|
|
||||||
<div class="data-view__item__value">{{ textData.peEfficiency }}</div>
|
|
||||||
<div class="data-view__item__title yellow">速度开动率</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
@ -46,27 +19,7 @@ export default {
|
|||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
chart: null,
|
chart: null,
|
||||||
textData: {
|
|
||||||
workTime: '',
|
|
||||||
downTime: '',
|
|
||||||
stopTime: '',
|
|
||||||
peEfficiency: '',
|
|
||||||
},
|
|
||||||
config: {
|
config: {
|
||||||
title: {
|
|
||||||
text: '产线1', //<=========
|
|
||||||
top: '35%',
|
|
||||||
left: '49%',
|
|
||||||
textAlign: 'center',
|
|
||||||
textStyle: {
|
|
||||||
fontSize: 18,
|
|
||||||
},
|
|
||||||
subtext: '设备', //<=========
|
|
||||||
subtextStyle: {
|
|
||||||
fontSize: 14,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
color: ['#3da8fd', '#8ef0ab', '#6b5cfd', '#FFC72A', 'transparent'],
|
|
||||||
grid: {
|
grid: {
|
||||||
top: 0,
|
top: 0,
|
||||||
left: 0,
|
left: 0,
|
||||||
@ -77,7 +30,6 @@ export default {
|
|||||||
trigger: 'item',
|
trigger: 'item',
|
||||||
},
|
},
|
||||||
legend: {
|
legend: {
|
||||||
show: false,
|
|
||||||
top: '0%',
|
top: '0%',
|
||||||
left: 'center',
|
left: 'center',
|
||||||
textStyle: {
|
textStyle: {
|
||||||
@ -87,70 +39,34 @@ export default {
|
|||||||
itemHeight: 10,
|
itemHeight: 10,
|
||||||
},
|
},
|
||||||
series: [
|
series: [
|
||||||
// 嵌套环形图
|
|
||||||
{
|
{
|
||||||
// 外环
|
name: this.value.equipmentName || 'Default',
|
||||||
name: '',
|
|
||||||
type: 'pie',
|
type: 'pie',
|
||||||
radius: ['75%', '90%'],
|
radius: ['40%', '75%'],
|
||||||
center: ['50%', '45%'],
|
avoidLabelOverlap: false,
|
||||||
label: {
|
label: {
|
||||||
show: false,
|
show: false,
|
||||||
|
position: 'center',
|
||||||
},
|
},
|
||||||
data: [
|
data: ['workTime', 'stopTime', 'downTime'].map((v, index) => ({
|
||||||
//<=========
|
name: ['工作时长', '停机时长', '故障时长'][index],
|
||||||
{ name: '工作时长', value: 1048 },
|
value: this.value[v],
|
||||||
{ name: '停机时长', value: 735 },
|
})),
|
||||||
{ name: '故障时长', value: 580 },
|
// data: [
|
||||||
],
|
// { value: 1048, name: 'Search Engine' },
|
||||||
|
// { value: 735, name: 'Direct' },
|
||||||
|
// { value: 580, name: 'Email' },
|
||||||
|
// { value: 484, name: 'Union Ads' },
|
||||||
|
// { value: 300, name: 'Video Ads' },
|
||||||
|
// ],
|
||||||
},
|
},
|
||||||
{
|
|
||||||
// 内环
|
|
||||||
name: '',
|
|
||||||
type: 'pie',
|
|
||||||
center: ['50%', '45%'],
|
|
||||||
radius: ['60%', '75%'],
|
|
||||||
itemStyle: {
|
|
||||||
borderRadius: 10,
|
|
||||||
},
|
|
||||||
label: {
|
|
||||||
show: false,
|
|
||||||
},
|
|
||||||
data: [
|
|
||||||
//<=========
|
|
||||||
{ name: '总', value: 3000 },
|
|
||||||
{ name: '', value: 1400 },
|
|
||||||
],
|
|
||||||
},
|
|
||||||
// {
|
|
||||||
// name: this.value.equipmentName || 'Default',
|
|
||||||
// type: 'pie',
|
|
||||||
// radius: ['40%', '75%'],
|
|
||||||
// avoidLabelOverlap: false,
|
|
||||||
// label: {
|
|
||||||
// show: false,
|
|
||||||
// position: 'center',
|
|
||||||
// },
|
|
||||||
// data: ['workTime', 'stopTime', 'downTime'].map((v, index) => ({
|
|
||||||
// name: ['工作时长', '停机时长', '故障时长'][index],
|
|
||||||
// value: this.value[v],
|
|
||||||
// })),
|
|
||||||
// // data: [
|
|
||||||
// // { value: 1048, name: 'Search Engine' },
|
|
||||||
// // { value: 735, name: 'Direct' },
|
|
||||||
// // { value: 580, name: 'Email' },
|
|
||||||
// // { value: 484, name: 'Union Ads' },
|
|
||||||
// // { value: 300, name: 'Video Ads' },
|
|
||||||
// // ],
|
|
||||||
// },
|
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
mounted() {
|
mounted() {
|
||||||
console.log('value', this.value);
|
|
||||||
if (!this.chart) {
|
if (!this.chart) {
|
||||||
this.chart = echarts.init(this.$refs.pieChart);
|
this.chart = echarts.init(this.$el);
|
||||||
this.$nextTick(() => {
|
this.$nextTick(() => {
|
||||||
this.chart.setOption(this.config);
|
this.chart.setOption(this.config);
|
||||||
});
|
});
|
||||||
@ -159,120 +75,24 @@ export default {
|
|||||||
beforeDestroy() {
|
beforeDestroy() {
|
||||||
if (this.chart) this.chart.dispose();
|
if (this.chart) this.chart.dispose();
|
||||||
},
|
},
|
||||||
watch: {
|
methods: {},
|
||||||
value: {
|
|
||||||
handler(val) {
|
|
||||||
this.updateConfig(val);
|
|
||||||
if (this.chart) this.chart.setOption(this.config);
|
|
||||||
},
|
|
||||||
deep: true,
|
|
||||||
immediate: true,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
methods: {
|
|
||||||
updateConfig(item) {
|
|
||||||
const {
|
|
||||||
lineName, // 产线
|
|
||||||
equipmentName, // 设备
|
|
||||||
downTime, // 故障时长(h)
|
|
||||||
stopTime, // 停机时长(h)
|
|
||||||
workTime, // 工作时长(h)
|
|
||||||
peEfficiency, // 速度开动率
|
|
||||||
timeEfficiency, // 时间开动率
|
|
||||||
//===============//
|
|
||||||
sectionName,
|
|
||||||
workRate,
|
|
||||||
stopRate,
|
|
||||||
downRate,
|
|
||||||
realProcSpeed,
|
|
||||||
designProcSpeed,
|
|
||||||
oee,
|
|
||||||
teep,
|
|
||||||
downCount,
|
|
||||||
mtbf,
|
|
||||||
mttr,
|
|
||||||
} = item;
|
|
||||||
this.config.title.text = lineName;
|
|
||||||
this.config.title.subtext = equipmentName;
|
|
||||||
this.config.series[0].data = [
|
|
||||||
{ name: '工作时长', value: workTime },
|
|
||||||
{ name: '停机时长', value: stopTime },
|
|
||||||
{ name: '故障时长', value: downTime },
|
|
||||||
];
|
|
||||||
this.config.series[1].data = [
|
|
||||||
{ name: '速度开动率', value: peEfficiency },
|
|
||||||
{ name: '', value: Math.ceil(peEfficiency) - peEfficiency },
|
|
||||||
];
|
|
||||||
//
|
|
||||||
this.textData = {
|
|
||||||
workTime: +workTime.toFixed(2),
|
|
||||||
stopTime: +stopTime.toFixed(2),
|
|
||||||
downTime: +downTime.toFixed(2),
|
|
||||||
peEfficiency: +peEfficiency.toFixed(2),
|
|
||||||
};
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
};
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style scoped lang="scss">
|
<style scoped lang="scss">
|
||||||
.chart-grid-item {
|
|
||||||
padding: 12px;
|
|
||||||
height: 100%;
|
|
||||||
display: flex;
|
|
||||||
flex-direction: column;
|
|
||||||
align-items: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.pie-chart {
|
.pie-chart {
|
||||||
height: 1px;
|
|
||||||
width: 100%;
|
|
||||||
flex: 1;
|
|
||||||
padding: 12px;
|
padding: 12px;
|
||||||
|
min-height: 320px;
|
||||||
|
background: #f1f1f1;
|
||||||
position: relative;
|
position: relative;
|
||||||
}
|
}
|
||||||
|
|
||||||
.data-view {
|
.pie-chart::before {
|
||||||
display: flex;
|
content: attr(data-eqname);
|
||||||
justify-content: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.data-view__item {
|
|
||||||
display: flex;
|
|
||||||
flex-direction: column;
|
|
||||||
text-align: center;
|
|
||||||
align-items: center;
|
|
||||||
user-select: none;
|
|
||||||
padding: 0 6px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.data-view__item:not(:last-child) {
|
|
||||||
border-right: 1px solid #f1f1f1;
|
|
||||||
}
|
|
||||||
|
|
||||||
.data-view__item__value {
|
|
||||||
font-size: 16px;
|
font-size: 16px;
|
||||||
line-height: 24px;
|
line-height: 1;
|
||||||
}
|
position: absolute;
|
||||||
|
top: -16px;
|
||||||
.data-view__item__title {
|
left: 0;
|
||||||
font-size: 8px;
|
|
||||||
line-height: 14px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.blue {
|
|
||||||
color: #3da8fd;
|
|
||||||
}
|
|
||||||
|
|
||||||
.green {
|
|
||||||
color: #8ef0ab;
|
|
||||||
}
|
|
||||||
|
|
||||||
.purple {
|
|
||||||
color: #6b5cfd;
|
|
||||||
}
|
|
||||||
|
|
||||||
.yellow {
|
|
||||||
color: #ffc72a;
|
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
@ -13,64 +13,46 @@
|
|||||||
ref="search-bar"
|
ref="search-bar"
|
||||||
@headBtnClick="handleSearchBarBtnClick" />
|
@headBtnClick="handleSearchBarBtnClick" />
|
||||||
|
|
||||||
<el-row>
|
|
||||||
<el-col class="custom-tabs">
|
|
||||||
<el-tabs
|
|
||||||
v-model="activeName"
|
|
||||||
:stretch="true"
|
|
||||||
@tab-click="handleTabClick">
|
|
||||||
<el-tab-pane :label="'\u2002数据列表\u2002'" name="table">
|
|
||||||
<!-- 列表 -->
|
<!-- 列表 -->
|
||||||
<base-table
|
<base-table
|
||||||
class="base-table__margin"
|
class="base-table__margin"
|
||||||
:table-props="tableProps"
|
:table-props="tableProps"
|
||||||
:page="1"
|
|
||||||
:limit="10"
|
|
||||||
:table-data="list"
|
:table-data="list"
|
||||||
@emitFun="handleEmitFun"></base-table>
|
@emitFun="handleEmitFun">
|
||||||
</el-tab-pane>
|
<!-- :page="queryParams.pageNo"
|
||||||
<el-tab-pane :label="'\u3000可视化\u3000'" name="graph">
|
:limit="queryParams.pageSize" -->
|
||||||
<div
|
<!-- <method-btn
|
||||||
v-if="activeName == 'graph'"
|
v-if="tableBtn.length"
|
||||||
class="graph"
|
slot="handleBtn"
|
||||||
style="display: flex; flex-direction: column; position: relative">
|
label="操作"
|
||||||
<div class="blue-title">各设备加工数量</div>
|
:method-list="tableBtn"
|
||||||
<div class="legend">
|
@clickBtn="handleTableBtnClick" /> -->
|
||||||
<div class="legend-item">
|
</base-table>
|
||||||
<span class="icon blue"></span>
|
|
||||||
<span class="text">工作时长</span>
|
|
||||||
</div>
|
|
||||||
<div class="legend-item">
|
|
||||||
<span class="icon green"></span>
|
|
||||||
<span class="text">停机时长</span>
|
|
||||||
</div>
|
|
||||||
<div class="legend-item">
|
|
||||||
<span class="icon purple"></span>
|
|
||||||
<span class="text">故障时长</span>
|
|
||||||
</div>
|
|
||||||
<div class="legend-item">
|
|
||||||
<span class="icon yellow"></span>
|
|
||||||
<span class="text">速度开动率</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="graph-grid">
|
|
||||||
<div class="bg-grid grid-line">
|
|
||||||
<div class="grid-item" v-for="item in list.length" :key="item"></div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="bg-grid grid-charts">
|
<!-- 分页组件 -->
|
||||||
<pie-chart
|
<!-- <pagination
|
||||||
v-for="item in list"
|
v-show="total > 0"
|
||||||
:key="item.id"
|
:total="total"
|
||||||
:value="item" />
|
:page.sync="queryParams.pageNo"
|
||||||
<!-- <pie-chart v-for="item in 5" :key="item" :value="item" /> -->
|
:limit.sync="queryParams.pageSize"
|
||||||
|
@pagination="getList" /> -->
|
||||||
|
|
||||||
|
<!-- 对话框(添加 / 修改) -->
|
||||||
|
<base-dialog
|
||||||
|
:dialogTitle="visualizationOpen ? '设备可视化' : '查看趋势'"
|
||||||
|
:dialogVisible="open"
|
||||||
|
:width="visualizationOpen ? '80%' : '700px'"
|
||||||
|
@closed="closed"
|
||||||
|
@close="cancel"
|
||||||
|
@cancel="cancel"
|
||||||
|
@confirm="submitForm">
|
||||||
|
<div class="visualization" v-if="visualizationOpen">
|
||||||
|
<pie-chart v-for="item in list" :key="item.id" :value="item" />
|
||||||
</div>
|
</div>
|
||||||
|
<div v-if="trendOpen">
|
||||||
|
<h1>查看趋势</h1>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</base-dialog>
|
||||||
</el-tab-pane>
|
|
||||||
</el-tabs>
|
|
||||||
</el-col>
|
|
||||||
</el-row>
|
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
@ -86,7 +68,6 @@ export default {
|
|||||||
props: {},
|
props: {},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
activeName: 'table',
|
|
||||||
open: false,
|
open: false,
|
||||||
visualizationOpen: false,
|
visualizationOpen: false,
|
||||||
trendOpen: false,
|
trendOpen: false,
|
||||||
@ -105,72 +86,84 @@ export default {
|
|||||||
// : undefined,
|
// : undefined,
|
||||||
// ].filter((v) => v),
|
// ].filter((v) => v),
|
||||||
tableProps: [
|
tableProps: [
|
||||||
{ prop: 'factoryName', label: '工厂' },
|
{ prop: 'factoryName', label: '工厂', align: 'center' },
|
||||||
{ prop: 'lineName', label: '产线' },
|
{ prop: 'lineName', label: '产线', align: 'center' },
|
||||||
{ prop: 'sectionName', label: '工段' },
|
{ prop: 'sectionName', label: '工段', align: 'center' },
|
||||||
{ prop: 'equipmentName', label: '设备' },
|
{ prop: 'equipmentName', label: '设备', align: 'center' },
|
||||||
{
|
{
|
||||||
label: '有效时间',
|
label: '有效时间',
|
||||||
|
align: 'center',
|
||||||
children: [
|
children: [
|
||||||
{
|
{
|
||||||
width: 128,
|
width: 128,
|
||||||
prop: 'workTime',
|
prop: 'workTime',
|
||||||
label: '工作时长',
|
label: '工作时长',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
width: 128,
|
width: 128,
|
||||||
prop: 'workRate',
|
prop: 'workRate',
|
||||||
label: '百分比',
|
label: '百分比',
|
||||||
|
align: 'center',
|
||||||
filter: (val) => (val != null ? +val.toFixed(3) : '-'),
|
filter: (val) => (val != null ? +val.toFixed(3) : '-'),
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: '关机时间',
|
label: '关机时间',
|
||||||
|
align: 'center',
|
||||||
children: [
|
children: [
|
||||||
{
|
{
|
||||||
width: 128,
|
width: 128,
|
||||||
prop: 'stopTime',
|
prop: 'stopTime',
|
||||||
label: '停机时长',
|
label: '停机时长',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{ width: 128, prop: 'stopRate', label: '百分比' },
|
{ width: 128, prop: 'stopRate', label: '百分比', align: 'center' },
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: '中断损失',
|
label: '中断损失',
|
||||||
|
align: 'center',
|
||||||
children: [
|
children: [
|
||||||
{
|
{
|
||||||
width: 128,
|
width: 128,
|
||||||
prop: 'downTime',
|
prop: 'downTime',
|
||||||
label: '故障时长',
|
label: '故障时长',
|
||||||
|
align: 'center',
|
||||||
filter: (val) => (val != null ? +val.toFixed(3) : '-'),
|
filter: (val) => (val != null ? +val.toFixed(3) : '-'),
|
||||||
},
|
},
|
||||||
{ width: 128, prop: 'downRate', label: '百分比' },
|
{ width: 128, prop: 'downRate', label: '百分比', align: 'center' },
|
||||||
{
|
{
|
||||||
width: 128,
|
width: 128,
|
||||||
prop: 'timeEfficiency',
|
prop: 'timeEfficiency',
|
||||||
label: '时间开动率',
|
label: '时间开动率',
|
||||||
|
align: 'center',
|
||||||
filter: (val) => (val != null ? +val.toFixed(3) : '-'),
|
filter: (val) => (val != null ? +val.toFixed(3) : '-'),
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: '速度损失',
|
label: '速度损失',
|
||||||
|
align: 'center',
|
||||||
children: [
|
children: [
|
||||||
{
|
{
|
||||||
width: 128,
|
width: 128,
|
||||||
prop: 'realProcSpeed',
|
prop: 'realProcSpeed',
|
||||||
label: '实际加工速度',
|
label: '实际加工速度',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
width: 128,
|
width: 128,
|
||||||
prop: 'designProcSpeed',
|
prop: 'designProcSpeed',
|
||||||
label: '理论加工速度',
|
label: '理论加工速度',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
width: 128,
|
width: 128,
|
||||||
prop: 'peEfficiency',
|
prop: 'peEfficiency',
|
||||||
label: '速度开动率',
|
label: '速度开动率',
|
||||||
|
align: 'center',
|
||||||
filter: (val) => (val != null ? +val.toFixed(3) : '-'),
|
filter: (val) => (val != null ? +val.toFixed(3) : '-'),
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
@ -178,17 +171,19 @@ export default {
|
|||||||
{
|
{
|
||||||
prop: 'oee',
|
prop: 'oee',
|
||||||
label: 'OEE',
|
label: 'OEE',
|
||||||
|
align: 'center',
|
||||||
filter: (val) => (val != null ? +val.toFixed(3) : '-'),
|
filter: (val) => (val != null ? +val.toFixed(3) : '-'),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
prop: 'teep',
|
prop: 'teep',
|
||||||
label: 'TEEP',
|
label: 'TEEP',
|
||||||
|
align: 'center',
|
||||||
filter: (val) => (val != null ? +val.toFixed(3) : '-'),
|
filter: (val) => (val != null ? +val.toFixed(3) : '-'),
|
||||||
},
|
},
|
||||||
// {
|
// {
|
||||||
// _action: 'view-trend',
|
// _action: 'view-trend',
|
||||||
// label: '趋势',
|
// label: '趋势',
|
||||||
// ,
|
// align: 'center',
|
||||||
// subcomponent: {
|
// subcomponent: {
|
||||||
// props: ['injectData'],
|
// props: ['injectData'],
|
||||||
// render: function (h) {
|
// render: function (h) {
|
||||||
@ -245,7 +240,7 @@ export default {
|
|||||||
parent: 'dateFilterType',
|
parent: 'dateFilterType',
|
||||||
// 时间段选择
|
// 时间段选择
|
||||||
type: 'datePicker',
|
type: 'datePicker',
|
||||||
// label: '时间段',
|
label: '时间段',
|
||||||
dateType: 'daterange',
|
dateType: 'daterange',
|
||||||
format: 'yyyy-MM-dd',
|
format: 'yyyy-MM-dd',
|
||||||
valueFormat: 'yyyy-MM-dd HH:mm:ss',
|
valueFormat: 'yyyy-MM-dd HH:mm:ss',
|
||||||
@ -259,7 +254,7 @@ export default {
|
|||||||
parent: 'dateFilterType',
|
parent: 'dateFilterType',
|
||||||
// 日期选择
|
// 日期选择
|
||||||
type: 'datePicker',
|
type: 'datePicker',
|
||||||
// label: '日期',
|
label: '日期',
|
||||||
dateType: 'date',
|
dateType: 'date',
|
||||||
placeholder: '选择日期',
|
placeholder: '选择日期',
|
||||||
format: 'yyyy-MM-dd',
|
format: 'yyyy-MM-dd',
|
||||||
@ -274,16 +269,16 @@ export default {
|
|||||||
name: 'search',
|
name: 'search',
|
||||||
color: 'primary',
|
color: 'primary',
|
||||||
},
|
},
|
||||||
// {
|
{
|
||||||
// type: 'separate',
|
type: 'separate',
|
||||||
// },
|
},
|
||||||
// {
|
{
|
||||||
// type: 'button',
|
type: 'button',
|
||||||
// btnName: '设备可视化',
|
btnName: '设备可视化',
|
||||||
// name: 'visualization',
|
name: 'visualization',
|
||||||
// plain: true,
|
plain: true,
|
||||||
// color: 'success',
|
color: 'success',
|
||||||
// },
|
},
|
||||||
// {
|
// {
|
||||||
// type: 'button',
|
// type: 'button',
|
||||||
// btnName: 'OEE',
|
// btnName: 'OEE',
|
||||||
@ -369,6 +364,7 @@ export default {
|
|||||||
params: this.queryParams,
|
params: this.queryParams,
|
||||||
});
|
});
|
||||||
if (code == 0) {
|
if (code == 0) {
|
||||||
|
console.log('data', data);
|
||||||
this.list = data;
|
this.list = data;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@ -411,8 +407,6 @@ export default {
|
|||||||
},
|
},
|
||||||
|
|
||||||
submitForm() {},
|
submitForm() {},
|
||||||
|
|
||||||
handleTabClick() {},
|
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
</script>
|
</script>
|
||||||
@ -422,141 +416,4 @@ export default {
|
|||||||
display: grid;
|
display: grid;
|
||||||
grid-template-columns: repeat(3, minmax(240px, 1fr));
|
grid-template-columns: repeat(3, minmax(240px, 1fr));
|
||||||
}
|
}
|
||||||
|
|
||||||
:deep(.custom-tabs) {
|
|
||||||
.el-tabs__header {
|
|
||||||
margin-bottom: 8px;
|
|
||||||
display: inline-block;
|
|
||||||
transform: translateY(-12px);
|
|
||||||
}
|
|
||||||
|
|
||||||
.el-tabs__item {
|
|
||||||
padding-left: 0 !important;
|
|
||||||
padding-right: 0 !important;
|
|
||||||
line-height: 36px !important;
|
|
||||||
height: 36px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.blue-title {
|
|
||||||
position: relative;
|
|
||||||
padding: 4px 0;
|
|
||||||
padding-left: 12px;
|
|
||||||
font-size: 14px;
|
|
||||||
|
|
||||||
&::before {
|
|
||||||
content: '';
|
|
||||||
position: absolute;
|
|
||||||
left: 0;
|
|
||||||
top: 6px;
|
|
||||||
height: 16px;
|
|
||||||
width: 4px;
|
|
||||||
border-radius: 1px;
|
|
||||||
background: #0b58ff;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.graph-grid {
|
|
||||||
margin-top: 8px;
|
|
||||||
padding: 12px;
|
|
||||||
position: relative;
|
|
||||||
border-radius: 12px;
|
|
||||||
border: 1px solid #ccc;
|
|
||||||
// background: #0003;
|
|
||||||
}
|
|
||||||
.bg-grid {
|
|
||||||
display: grid;
|
|
||||||
place-content: center;
|
|
||||||
grid-template-columns: repeat(4, minmax(280px, 1fr));
|
|
||||||
grid-auto-columns: 280px;
|
|
||||||
grid-auto-rows: 290px;
|
|
||||||
overflow: hidden;
|
|
||||||
position: relative;
|
|
||||||
}
|
|
||||||
|
|
||||||
.grid-line::after {
|
|
||||||
content: '';
|
|
||||||
position: absolute;
|
|
||||||
top: -1px;
|
|
||||||
left: -1px;
|
|
||||||
width: calc(100% + 2px);
|
|
||||||
height: calc(100% + 2px);
|
|
||||||
display: inline-block;
|
|
||||||
border: 8px solid #fff;
|
|
||||||
}
|
|
||||||
|
|
||||||
.grid-charts {
|
|
||||||
position: absolute;
|
|
||||||
width: calc(100% - 24px);
|
|
||||||
top: 12px;
|
|
||||||
left: 12px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.grid-item {
|
|
||||||
border: 1px solid #ccc;
|
|
||||||
}
|
|
||||||
|
|
||||||
.grid-item:not(:first-child) {
|
|
||||||
border-left: 0;
|
|
||||||
border-top: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.legend {
|
|
||||||
position: absolute;
|
|
||||||
top: 8px;
|
|
||||||
right: 12px;
|
|
||||||
display: flex;
|
|
||||||
}
|
|
||||||
|
|
||||||
.legend .legend-item {
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
margin-left: 12px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.legend .legend-item .icon {
|
|
||||||
width: 10px;
|
|
||||||
height: 10px;
|
|
||||||
border-radius: 1px;
|
|
||||||
margin-right: 4px;
|
|
||||||
margin-top: 1px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.legend .legend-item .text {
|
|
||||||
color: #8c8c8c;
|
|
||||||
}
|
|
||||||
|
|
||||||
.blue {
|
|
||||||
background-color: #3da8fd;
|
|
||||||
}
|
|
||||||
|
|
||||||
.green {
|
|
||||||
background-color: #8ef0ab;
|
|
||||||
}
|
|
||||||
|
|
||||||
.purple {
|
|
||||||
background-color: #6b5cfd;
|
|
||||||
}
|
|
||||||
|
|
||||||
.yellow {
|
|
||||||
background-color: #ffc72a;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (max-width: 1390px) {
|
|
||||||
.bg-grid {
|
|
||||||
grid-template-columns: repeat(3, minmax(280px, 1fr));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (max-width: 1190px) {
|
|
||||||
.bg-grid {
|
|
||||||
grid-template-columns: repeat(2, minmax(280px, 1fr));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (max-width: 640px) {
|
|
||||||
.bg-grid {
|
|
||||||
grid-template-columns: repeat(1, minmax(280px, 1fr));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</style>
|
</style>
|
||||||
|
@ -50,47 +50,39 @@ export default {
|
|||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
searchBarKeys: ['name', 'code'],
|
searchBarKeys: ['name', 'code'],
|
||||||
// tableBtn: [
|
|
||||||
// this.$auth.hasPermi('base:equipment-group:update')
|
|
||||||
// ? {
|
|
||||||
// type: 'edit',
|
|
||||||
// btnName: '修改',
|
|
||||||
// }
|
|
||||||
// : undefined,
|
|
||||||
// this.$auth.hasPermi('base:equipment-group:delete')
|
|
||||||
// ? {
|
|
||||||
// type: 'delete',
|
|
||||||
// btnName: '删除',
|
|
||||||
// }
|
|
||||||
// : undefined,
|
|
||||||
// ].filter((v) => v),
|
|
||||||
tableBtn: [
|
tableBtn: [
|
||||||
{
|
this.$auth.hasPermi('base:equipment-group:update')
|
||||||
|
? {
|
||||||
type: 'edit',
|
type: 'edit',
|
||||||
btnName: '修改',
|
btnName: '修改',
|
||||||
},
|
}
|
||||||
{
|
: undefined,
|
||||||
|
this.$auth.hasPermi('base:equipment-group:delete')
|
||||||
|
? {
|
||||||
type: 'delete',
|
type: 'delete',
|
||||||
btnName: '删除',
|
btnName: '删除',
|
||||||
},
|
}
|
||||||
],
|
: undefined,
|
||||||
|
].filter((v) => v),
|
||||||
tableProps: [
|
tableProps: [
|
||||||
{ prop: 'lineName', label: '产线' },
|
{ prop: 'lineName', label: '产线', align: 'center' },
|
||||||
{ prop: 'sectionName', label: '工段' },
|
{ prop: 'sectionName', label: '工段', align: 'center' },
|
||||||
{ prop: 'equipmentName', label: '设备' },
|
{ prop: 'equipmentName', label: '设备', align: 'center' },
|
||||||
{
|
{
|
||||||
width: 240,
|
width: 188,
|
||||||
prop: 'mtbf',
|
prop: 'mtbf',
|
||||||
label: '平均故障间隔时间[MTBF](h)',
|
label: '平均故障间隔时间[MTBF](h)',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
width: 240,
|
width: 180,
|
||||||
prop: 'mttr',
|
prop: 'mttr',
|
||||||
label: '平均维修时间[MTTR](h)',
|
label: '平均维修时间[MTTR](h)',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{ width: 128, prop: 'workTime', label: '工作时长(h)' },
|
{ prop: 'workTime', label: '工作时长(h)', align: 'center' },
|
||||||
{ width: 128, prop: 'downTime', label: '故障时长(h)' },
|
{ prop: 'downTime', label: '故障时长(h)', align: 'center' },
|
||||||
{ prop: 'downCount', label: '故障次数' },
|
{ prop: 'downCount', label: '故障次数', align: 'center' },
|
||||||
],
|
],
|
||||||
searchBarFormConfig: [
|
searchBarFormConfig: [
|
||||||
{
|
{
|
||||||
@ -121,8 +113,6 @@ export default {
|
|||||||
],
|
],
|
||||||
// 查询参数
|
// 查询参数
|
||||||
queryParams: {
|
queryParams: {
|
||||||
pageNo: 1,
|
|
||||||
pageSize: 10,
|
|
||||||
lineId: null,
|
lineId: null,
|
||||||
factoryId: null,
|
factoryId: null,
|
||||||
recordTime: null,
|
recordTime: null,
|
||||||
@ -172,8 +162,10 @@ export default {
|
|||||||
this.queryParams.recordTime = [
|
this.queryParams.recordTime = [
|
||||||
moment()
|
moment()
|
||||||
.month(btn.month - 1)
|
.month(btn.month - 1)
|
||||||
.format('YYYY-MM') + '-01 00:00:00',
|
.format('YYYY-MM')+'-01 00:00:00',
|
||||||
moment().month(btn.month).format('YYYY-MM') + '-01 00:00:00',
|
moment()
|
||||||
|
.month(btn.month)
|
||||||
|
.format('YYYY-MM')+'-01 00:00:00',
|
||||||
];
|
];
|
||||||
} else {
|
} else {
|
||||||
this.queryParams.recordTime = null;
|
this.queryParams.recordTime = null;
|
||||||
|
@ -15,143 +15,27 @@ import * as echarts from 'echarts';
|
|||||||
export default {
|
export default {
|
||||||
name: 'LineChart',
|
name: 'LineChart',
|
||||||
components: {},
|
components: {},
|
||||||
props: ['config', 'list'],
|
props: ['config'],
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
chart: null,
|
chart: null,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
// watch: {
|
computed: {},
|
||||||
// list: {
|
|
||||||
// handler(listdata) {
|
|
||||||
// if (listdata && listdata.length) {
|
|
||||||
// console.log('[linechart] list changed', listdata);
|
|
||||||
// const option = this.handleList(listdata);
|
|
||||||
// this.setOption(option);
|
|
||||||
// }
|
|
||||||
// },
|
|
||||||
// immediate: true,
|
|
||||||
// },
|
|
||||||
// },
|
|
||||||
computed: {
|
|
||||||
option() {
|
|
||||||
const opt = [];
|
|
||||||
this.list.map((eq) => {
|
|
||||||
/** [设备名, ok数量, 不ok数量] */
|
|
||||||
opt.push([eq.equipmentName, eq.okQuantity, eq.nokQuantity]);
|
|
||||||
});
|
|
||||||
return {
|
|
||||||
color: ['#288AFF', '#8EF0AB'],
|
|
||||||
tooltip: {
|
|
||||||
trigger: 'axis',
|
|
||||||
axisPointer: {
|
|
||||||
type: 'shadow',
|
|
||||||
},
|
|
||||||
},
|
|
||||||
legend: {
|
|
||||||
itemWidth: 12,
|
|
||||||
itemHeight: 12,
|
|
||||||
right: 0
|
|
||||||
},
|
|
||||||
grid: {
|
|
||||||
left: '1%',
|
|
||||||
right: '1%',
|
|
||||||
top: '8%',
|
|
||||||
bottom: '3%',
|
|
||||||
containLabel: true,
|
|
||||||
},
|
|
||||||
// xAxis: [
|
|
||||||
// {
|
|
||||||
// type: 'category',
|
|
||||||
// data: ['设备1', '设备2', '设备3', '设备4', '设备5'],
|
|
||||||
// },
|
|
||||||
// ],
|
|
||||||
// yAxis: [
|
|
||||||
// {
|
|
||||||
// type: 'value',
|
|
||||||
// splitLine: {
|
|
||||||
// lineStyle: {
|
|
||||||
// color: '#0001',
|
|
||||||
// },
|
|
||||||
// },
|
|
||||||
// },
|
|
||||||
// ],
|
|
||||||
xAxis: {
|
|
||||||
type: 'category',
|
|
||||||
axisTick: { show: false },
|
|
||||||
data: opt.map((item) => item[0]),
|
|
||||||
},
|
|
||||||
yAxis: {
|
|
||||||
type: 'value',
|
|
||||||
splitLine: {
|
|
||||||
lineStyle: {
|
|
||||||
color: '#0001',
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
series: [
|
|
||||||
{
|
|
||||||
name: '合格数量',
|
|
||||||
type: 'bar',
|
|
||||||
barWidth: 20,
|
|
||||||
stack: 's',
|
|
||||||
data: opt.map((item) => item[1]),
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: '不合格数量',
|
|
||||||
type: 'bar',
|
|
||||||
barWidth: 20,
|
|
||||||
stack: 's',
|
|
||||||
data: opt.map((item) => item[2]),
|
|
||||||
},
|
|
||||||
],
|
|
||||||
};
|
|
||||||
},
|
|
||||||
},
|
|
||||||
mounted() {
|
mounted() {
|
||||||
console.log('[linechart] mounted');
|
|
||||||
this.init();
|
this.init();
|
||||||
},
|
},
|
||||||
beforeDestroy() {
|
beforeDestroy() {
|
||||||
if (this.chart) {
|
if (this.chart) {
|
||||||
this.chart.dispose();
|
this.chart.dispose();
|
||||||
}
|
}
|
||||||
console.log('[linechart] destroyed');
|
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
init() {
|
init() {
|
||||||
|
console.log('thsi el', this.$el);
|
||||||
if (!this.chart) this.chart = echarts.init(this.$el);
|
if (!this.chart) this.chart = echarts.init(this.$el);
|
||||||
console.log('[linechart] initialized', this.$el);
|
this.chart.setOption(this.config);
|
||||||
this.$nextTick(() => {
|
|
||||||
this.setOption();
|
|
||||||
});
|
|
||||||
},
|
},
|
||||||
|
|
||||||
setOption() {
|
|
||||||
if (this.chart) this.chart.setOption(this.option);
|
|
||||||
console.log('[linechart] option settled');
|
|
||||||
},
|
|
||||||
|
|
||||||
// handleList(list) {
|
|
||||||
// /** 清空数据 */
|
|
||||||
// this.option.series[0].data.splice(0);
|
|
||||||
// this.option.series[1].data.splice(0);
|
|
||||||
// this.option.xAxis.data.splice(0);
|
|
||||||
|
|
||||||
// list.map((eq) => {
|
|
||||||
// this.option.xAxis.data.push(eq.equipmentName);
|
|
||||||
// this.option.series[0].data.push(eq.nokQuantity);
|
|
||||||
// this.option.series[1].data.push(eq.okQuantity);
|
|
||||||
// });
|
|
||||||
|
|
||||||
// this.setOption();
|
|
||||||
|
|
||||||
// // const pureList = list.map((eq) => ({
|
|
||||||
// // name: eq.equipmentName,
|
|
||||||
// // ok: eq.okQuantity,
|
|
||||||
// // nok: eq.nokQuantity,
|
|
||||||
// // }));
|
|
||||||
// },
|
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
</script>
|
</script>
|
||||||
@ -159,7 +43,7 @@ export default {
|
|||||||
<style scoped lang="scss">
|
<style scoped lang="scss">
|
||||||
.line-chart {
|
.line-chart {
|
||||||
padding: 0 12px;
|
padding: 0 12px;
|
||||||
height: 1px;
|
background: #e1e1e1;
|
||||||
flex: 1;
|
min-height: 320px;
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
@ -13,13 +13,6 @@
|
|||||||
ref="search-bar"
|
ref="search-bar"
|
||||||
@headBtnClick="handleSearchBarBtnClick" />
|
@headBtnClick="handleSearchBarBtnClick" />
|
||||||
|
|
||||||
<el-row>
|
|
||||||
<el-col class="custom-tabs">
|
|
||||||
<el-tabs
|
|
||||||
v-model="activeName"
|
|
||||||
:stretch="true"
|
|
||||||
@tab-click="handleTabClick">
|
|
||||||
<el-tab-pane :label="'数据列表'" name="table">
|
|
||||||
<!-- 列表 -->
|
<!-- 列表 -->
|
||||||
<base-table
|
<base-table
|
||||||
:table-props="tableProps"
|
:table-props="tableProps"
|
||||||
@ -27,21 +20,21 @@
|
|||||||
:limit="queryParams.pageSize"
|
:limit="queryParams.pageSize"
|
||||||
:table-data="list"
|
:table-data="list"
|
||||||
@emitFun="handleEmitFun"></base-table>
|
@emitFun="handleEmitFun"></base-table>
|
||||||
</el-tab-pane>
|
|
||||||
<el-tab-pane :label="'\u3000柱状图\u3000'" name="graph">
|
<!-- 图形分析 dialog -->
|
||||||
<div v-if="activeName == 'graph'" class="graph" style="height: 40vh; display: flex; flex-direction: column;">
|
<!-- <base-dialog
|
||||||
<div class="blue-title">各设备加工数量</div>
|
dialogTitle="图形视角"
|
||||||
<LineChart :list="list" />
|
:dialogVisible="dialogVisible"
|
||||||
</div>
|
width="60%"
|
||||||
</el-tab-pane>
|
@close="dialogClose"
|
||||||
</el-tabs>
|
@cancel="dialogClose"
|
||||||
</el-col>
|
@confirm="dialogClose">
|
||||||
</el-row>
|
<LineChart v-if="dialogVisible" :config="lineChartConfig" />
|
||||||
|
</base-dialog> -->
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import moment from 'moment';
|
|
||||||
import LineChart from './components/lineChart.vue';
|
import LineChart from './components/lineChart.vue';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
@ -49,14 +42,12 @@ export default {
|
|||||||
components: { LineChart },
|
components: { LineChart },
|
||||||
props: {},
|
props: {},
|
||||||
data() {
|
data() {
|
||||||
const now = new Date();
|
|
||||||
const [y, m, d] = [now.getFullYear(), now.getMonth(), now.getDate()];
|
|
||||||
return {
|
return {
|
||||||
dialogVisible: false,
|
dialogVisible: false,
|
||||||
urls: {
|
urls: {
|
||||||
page: '/analysis/equipment-analysis/quality',
|
page: '/analysis/equipment-analysis/quality',
|
||||||
},
|
},
|
||||||
activeName: 'table', // defaults to 'table'
|
mode: 'table', // defaults to 'table'
|
||||||
searchBarFormConfig: [
|
searchBarFormConfig: [
|
||||||
// 产品
|
// 产品
|
||||||
{
|
{
|
||||||
@ -81,30 +72,13 @@ export default {
|
|||||||
dateType: 'daterange', // datetimerange
|
dateType: 'daterange', // datetimerange
|
||||||
// format: 'yyyy-MM-dd HH:mm:ss',
|
// format: 'yyyy-MM-dd HH:mm:ss',
|
||||||
format: 'yyyy-MM-dd',
|
format: 'yyyy-MM-dd',
|
||||||
// valueFormat: 'timestamp',
|
|
||||||
valueFormat: 'yyyy-MM-dd HH:mm:ss',
|
valueFormat: 'yyyy-MM-dd HH:mm:ss',
|
||||||
|
// valueFormat: 'timestamp',
|
||||||
rangeSeparator: '-',
|
rangeSeparator: '-',
|
||||||
startPlaceholder: '开始日期',
|
startPlaceholder: '开始日期',
|
||||||
endPlaceholder: '结束日期',
|
endPlaceholder: '结束日期',
|
||||||
|
defaultTime: ['00:00:00', '23:59:59'],
|
||||||
param: 'recordTime',
|
param: 'recordTime',
|
||||||
defaultSelect: [
|
|
||||||
new Date(y, m, d)
|
|
||||||
.toLocaleString()
|
|
||||||
.split('/')
|
|
||||||
.map((item, index) => {
|
|
||||||
if (index == 1 || index == 2) return item.padStart(2, '0');
|
|
||||||
return item;
|
|
||||||
})
|
|
||||||
.join('-'),
|
|
||||||
new Date(y, m, d, 23, 59, 59)
|
|
||||||
.toLocaleString()
|
|
||||||
.split('/')
|
|
||||||
.map((item, index) => {
|
|
||||||
if (index == 1 || index == 2) return item.padStart(2, '0');
|
|
||||||
return item;
|
|
||||||
})
|
|
||||||
.join('-'),
|
|
||||||
],
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
type: 'button',
|
type: 'button',
|
||||||
@ -112,9 +86,9 @@ export default {
|
|||||||
name: 'search',
|
name: 'search',
|
||||||
color: 'primary',
|
color: 'primary',
|
||||||
},
|
},
|
||||||
// {
|
{
|
||||||
// type: 'separate',
|
type: 'separate',
|
||||||
// },
|
},
|
||||||
// {
|
// {
|
||||||
// type: 'button',
|
// type: 'button',
|
||||||
// btnName: '列表数据',
|
// btnName: '列表数据',
|
||||||
@ -137,36 +111,43 @@ export default {
|
|||||||
// width: 160,
|
// width: 160,
|
||||||
prop: 'sectionName',
|
prop: 'sectionName',
|
||||||
label: '工段',
|
label: '工段',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
// width: 160,
|
// width: 160,
|
||||||
prop: 'equipmentName',
|
prop: 'equipmentName',
|
||||||
label: '设备名称',
|
label: '设备名称',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
// width: 160,
|
// width: 160,
|
||||||
prop: 'products',
|
prop: 'products',
|
||||||
label: '产品名称',
|
label: '产品名称',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
// width: 160,
|
// width: 160,
|
||||||
prop: 'inQuantity',
|
prop: 'inQuantity',
|
||||||
label: '进片数量',
|
label: '进片数量',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
// width: 160,
|
// width: 160,
|
||||||
prop: 'outQuantity',
|
prop: 'outQuantity',
|
||||||
label: '出片数量',
|
label: '出片数量',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
// width: 160,
|
// width: 160,
|
||||||
prop: 'nokQuantity',
|
prop: 'nokQuantity',
|
||||||
label: '破损/不合格数',
|
label: '破损/不合格数',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
// width: 160,
|
// width: 160,
|
||||||
prop: 'passRate',
|
prop: 'passRate',
|
||||||
label: '合格率',
|
label: '合格率',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
lineChartConfig: {
|
lineChartConfig: {
|
||||||
@ -186,7 +167,7 @@ export default {
|
|||||||
itemGap: 20,
|
itemGap: 20,
|
||||||
textStyle: {
|
textStyle: {
|
||||||
fontSize: 14,
|
fontSize: 14,
|
||||||
lineHeight: 14,
|
lineHeight: 14
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
xAxis: {
|
xAxis: {
|
||||||
@ -199,9 +180,9 @@ export default {
|
|||||||
nameLocation: 'end',
|
nameLocation: 'end',
|
||||||
nameTextStyle: {
|
nameTextStyle: {
|
||||||
fontSize: 14,
|
fontSize: 14,
|
||||||
align: 'right',
|
align: 'right'
|
||||||
},
|
},
|
||||||
nameGap: 26,
|
nameGap: 26
|
||||||
},
|
},
|
||||||
series: [
|
series: [
|
||||||
{
|
{
|
||||||
@ -248,11 +229,6 @@ export default {
|
|||||||
this.getList();
|
this.getList();
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
handleTabClick(tab, event) {
|
|
||||||
// console.log('tab event', tab, event);
|
|
||||||
// tab is el-tab vue component.
|
|
||||||
},
|
|
||||||
|
|
||||||
async fillLineOptions() {
|
async fillLineOptions() {
|
||||||
const { data } = await this.$axios({
|
const { data } = await this.$axios({
|
||||||
url: '/base/production-line/listAll',
|
url: '/base/production-line/listAll',
|
||||||
@ -364,38 +340,4 @@ export default {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
:deep(.custom-tabs) {
|
|
||||||
.el-tabs__header {
|
|
||||||
margin-bottom: 8px;
|
|
||||||
display: inline-block;
|
|
||||||
transform: translateY(-12px);
|
|
||||||
}
|
|
||||||
|
|
||||||
.el-tabs__item {
|
|
||||||
padding-left: 0 !important;
|
|
||||||
padding-right: 0 !important;
|
|
||||||
line-height: 36px !important;
|
|
||||||
height: 36px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.blue-title {
|
|
||||||
position: relative;
|
|
||||||
padding: 4px 0;
|
|
||||||
padding-left: 12px;
|
|
||||||
font-size: 14px;
|
|
||||||
|
|
||||||
&::before {
|
|
||||||
content: "";
|
|
||||||
position: absolute;
|
|
||||||
left: 0;
|
|
||||||
top: 6px;
|
|
||||||
height: 16px;
|
|
||||||
width: 4px;
|
|
||||||
border-radius: 1px;
|
|
||||||
background: #0b58ff;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
</style>
|
</style>
|
||||||
|
@ -21,14 +21,7 @@ export default {
|
|||||||
chart: null,
|
chart: null,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
watch: {
|
computed: {},
|
||||||
config: {
|
|
||||||
handler(value) {
|
|
||||||
if (value != null) this.setOption(value);
|
|
||||||
},
|
|
||||||
deep: true,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
mounted() {
|
mounted() {
|
||||||
this.init();
|
this.init();
|
||||||
},
|
},
|
||||||
@ -39,11 +32,9 @@ export default {
|
|||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
init() {
|
init() {
|
||||||
|
console.log('thsi el', this.$el);
|
||||||
if (!this.chart) this.chart = echarts.init(this.$el);
|
if (!this.chart) this.chart = echarts.init(this.$el);
|
||||||
this.setOption(this.config);
|
this.chart.setOption(this.config);
|
||||||
},
|
|
||||||
setOption(option) {
|
|
||||||
if (this.chart) this.chart.setOption(option);
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -6,44 +6,25 @@
|
|||||||
-->
|
-->
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div
|
<div class="app-container">
|
||||||
class="production-timegraph-container"
|
<h1>设备产量时序图</h1>
|
||||||
style="background: #f2f4f9; flex: 1">
|
|
||||||
<el-row
|
|
||||||
class=""
|
|
||||||
style="
|
|
||||||
margin-bottom: 12px;
|
|
||||||
background: #fff;
|
|
||||||
padding: 16px 16px 0;
|
|
||||||
border-radius: 8px;
|
|
||||||
">
|
|
||||||
<div class="blue-title">生产节拍时序图</div>
|
|
||||||
<!-- <h1>设备状态时序图</h1> -->
|
|
||||||
<!-- 搜索工作栏 -->
|
<!-- 搜索工作栏 -->
|
||||||
<SearchBar
|
<SearchBar
|
||||||
:formConfigs="searchBarFormConfig"
|
:formConfigs="searchBarFormConfig"
|
||||||
ref="search-bar"
|
ref="search-bar"
|
||||||
:remove-blue="true"
|
|
||||||
@headBtnClick="handleSearchBarBtnClick" />
|
@headBtnClick="handleSearchBarBtnClick" />
|
||||||
</el-row>
|
|
||||||
|
|
||||||
<el-row
|
|
||||||
class=""
|
|
||||||
style="
|
|
||||||
margin-bottom: 12px;
|
|
||||||
background: #fff;
|
|
||||||
padding: 16px 16px 24px;
|
|
||||||
border-radius: 8px;
|
|
||||||
">
|
|
||||||
<div class="blue-title">设备产量时序图</div>
|
|
||||||
|
|
||||||
<div class="main-area">
|
<div class="main-area">
|
||||||
<div class="graphs" v-if="graphList.length">
|
<div class="graphs" v-if="graphList.length">
|
||||||
<LineChart :config="templateConfig" />
|
<div class="graph" v-for="(eq, index) in graphList" :key="eq.key">
|
||||||
|
<h2 class="graph-title">{{ eq.key }}</h2>
|
||||||
|
<LineChart
|
||||||
|
:key="eq.key + '__linechart'"
|
||||||
|
:config="getRealConfig(index)" />
|
||||||
</div>
|
</div>
|
||||||
<div class="no-data-bg" v-else></div>
|
|
||||||
</div>
|
</div>
|
||||||
</el-row>
|
<h2 v-else>请添加设备</h2>
|
||||||
|
</div>
|
||||||
|
|
||||||
<!-- 对话框(添加 / 修改) -->
|
<!-- 对话框(添加 / 修改) -->
|
||||||
<base-dialog
|
<base-dialog
|
||||||
@ -77,7 +58,6 @@ export default {
|
|||||||
props: {},
|
props: {},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
accumulators: new Map(),
|
|
||||||
searchBarFormConfig: [
|
searchBarFormConfig: [
|
||||||
{
|
{
|
||||||
type: 'select',
|
type: 'select',
|
||||||
@ -97,16 +77,15 @@ export default {
|
|||||||
{
|
{
|
||||||
type: 'datePicker',
|
type: 'datePicker',
|
||||||
label: '时间段',
|
label: '时间段',
|
||||||
dateType: 'date', // datetimerange
|
dateType: 'daterange', // datetimerange
|
||||||
// format: 'yyyy-MM-dd HH:mm:ss',
|
// format: 'yyyy-MM-dd HH:mm:ss',
|
||||||
format: 'yyyy-MM-dd',
|
format: 'yyyy-MM-dd',
|
||||||
valueFormat: 'yyyy-MM-dd HH:mm:ss',
|
valueFormat: 'yyyy-MM-dd HH:mm:ss',
|
||||||
// valueFormat: 'timestamp',
|
// valueFormat: 'timestamp',
|
||||||
// rangeSeparator: '-',
|
rangeSeparator: '-',
|
||||||
// startPlaceholder: '开始日期',
|
startPlaceholder: '开始日期',
|
||||||
// endPlaceholder: '结束日期',
|
endPlaceholder: '结束日期',
|
||||||
// defaultTime: ['00:00:00', '23:59:59'],
|
defaultTime: ['00:00:00', '23:59:59'],
|
||||||
placeholder: '选择日期',
|
|
||||||
param: 'recordTime',
|
param: 'recordTime',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -120,9 +99,9 @@ export default {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
type: 'button',
|
type: 'button',
|
||||||
btnName: '添加对比',
|
btnName: '设备对比',
|
||||||
name: 'compare',
|
name: 'compare',
|
||||||
color: 'primary',
|
color: 'warning',
|
||||||
plain: true,
|
plain: true,
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
@ -136,47 +115,30 @@ export default {
|
|||||||
eqList: [],
|
eqList: [],
|
||||||
graphList: [],
|
graphList: [],
|
||||||
templateConfig: {
|
templateConfig: {
|
||||||
color: ['#283D68', '#FFB61F', '#4481FF', '#5AD8A6', '#E97466'],
|
|
||||||
grid: {
|
grid: {
|
||||||
top: 48,
|
top: 88,
|
||||||
left: 48,
|
left: 56,
|
||||||
right: 24,
|
right: 56,
|
||||||
bottom: 24,
|
bottom: 56,
|
||||||
},
|
},
|
||||||
legend: {
|
legend: {
|
||||||
top: 0,
|
top: 0,
|
||||||
right: 12,
|
left: 0,
|
||||||
padding: 6,
|
padding: 5,
|
||||||
itemWidth: 16,
|
icon: 'roundRect',
|
||||||
itemHeight: 8,
|
itemWidth: 12,
|
||||||
|
itemHeight: 12,
|
||||||
itemGap: 20,
|
itemGap: 20,
|
||||||
textStyle: {
|
textStyle: {
|
||||||
fontSize: 12,
|
fontSize: 14,
|
||||||
lineHeight: 12,
|
lineHeight: 14,
|
||||||
color: '#0007',
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
tooltip: {
|
|
||||||
show: true,
|
|
||||||
trigger: 'axis',
|
|
||||||
},
|
|
||||||
xAxis: {
|
xAxis: {
|
||||||
type: 'category',
|
type: 'category',
|
||||||
boundaryGap: true,
|
data: Array(24)
|
||||||
axisTick: {
|
.fill(1)
|
||||||
// show: false,
|
.map((item, index) => `${index}:00`),
|
||||||
alignWithLabel: true,
|
|
||||||
lineStyle: {
|
|
||||||
color: '#0003',
|
|
||||||
},
|
|
||||||
},
|
|
||||||
axisLabel: {
|
|
||||||
color: '#0007',
|
|
||||||
},
|
|
||||||
data: [],
|
|
||||||
// data: Array(24)
|
|
||||||
// .fill(1)
|
|
||||||
// .map((item, index) => `${index}:00`),
|
|
||||||
},
|
},
|
||||||
yAxis: {
|
yAxis: {
|
||||||
type: 'value',
|
type: 'value',
|
||||||
@ -184,41 +146,19 @@ export default {
|
|||||||
nameLocation: 'end',
|
nameLocation: 'end',
|
||||||
nameTextStyle: {
|
nameTextStyle: {
|
||||||
fontSize: 14,
|
fontSize: 14,
|
||||||
align: 'center',
|
align: 'right',
|
||||||
},
|
},
|
||||||
nameGap: 26,
|
nameGap: 26,
|
||||||
max: function (value) {
|
|
||||||
return value.max + Math.floor(value.max / 5);
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
series: [
|
series: [
|
||||||
// {
|
{
|
||||||
// name: '产线1',
|
name: '产线1',
|
||||||
// data: Array(24)
|
data: Array(24)
|
||||||
// .fill(1)
|
.fill(1)
|
||||||
// .map(() => Math.random() * 100),
|
.map(() => Math.random() * 100),
|
||||||
// type: 'line',
|
type: 'line',
|
||||||
// symbol: 'circle',
|
smooth: true,
|
||||||
// // smooth: true,
|
},
|
||||||
// },
|
|
||||||
// {
|
|
||||||
// name: '产线2',
|
|
||||||
// data: Array(24)
|
|
||||||
// .fill(1)
|
|
||||||
// .map(() => Math.random() * 100),
|
|
||||||
// type: 'line',
|
|
||||||
// symbol: 'circle',
|
|
||||||
// // smooth: true,
|
|
||||||
// },
|
|
||||||
// {
|
|
||||||
// name: '产线3',
|
|
||||||
// data: Array(24)
|
|
||||||
// .fill(1)
|
|
||||||
// .map(() => Math.random() * 100),
|
|
||||||
// type: 'line',
|
|
||||||
// symbol: 'circle',
|
|
||||||
// // smooth: true,
|
|
||||||
// },
|
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
@ -236,12 +176,7 @@ export default {
|
|||||||
this.queryParams.lineId = payload.lineId || null;
|
this.queryParams.lineId = payload.lineId || null;
|
||||||
this.queryParams.sectionId = payload.sectionId || null;
|
this.queryParams.sectionId = payload.sectionId || null;
|
||||||
this.queryParams.equipmentId = payload.equipmentId || null;
|
this.queryParams.equipmentId = payload.equipmentId || null;
|
||||||
this.queryParams.recordTime = payload.recordTime
|
this.queryParams.recordTime = payload.recordTime || null;
|
||||||
? [
|
|
||||||
payload.recordTime,
|
|
||||||
payload.recordTime.replace('00:00:00', '23:59:59'),
|
|
||||||
]
|
|
||||||
: null;
|
|
||||||
this.getList();
|
this.getList();
|
||||||
break;
|
break;
|
||||||
case 'compare':
|
case 'compare':
|
||||||
@ -295,41 +230,10 @@ export default {
|
|||||||
// ];
|
// ];
|
||||||
// eq2.key = 'SS2';
|
// eq2.key = 'SS2';
|
||||||
// this.graphList = [eq1, eq2];
|
// this.graphList = [eq1, eq2];
|
||||||
|
console.log('graph list', this.graphList);
|
||||||
this.graphList.forEach(this.setSeries);
|
|
||||||
} else {
|
|
||||||
this.graphList = [];
|
|
||||||
this.graphList.forEach(this.setSeries);
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
setSeries(eqArr) {
|
|
||||||
if (eqArr.length == 0) {
|
|
||||||
this.templateConfig.series = [];
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
let isInit = false;
|
|
||||||
if (this.accumulators.has(eqArr.key) == false) {
|
|
||||||
this.accumulators.set(eqArr.key, 0);
|
|
||||||
isInit = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
let accumulator = this.accumulators.get(eqArr.key);
|
|
||||||
if ((accumulator && !isInit) || (accumulator == 0 && isInit == false)) {
|
|
||||||
accumulator++;
|
|
||||||
this.accumulators.set(eqArr.key, accumulator);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.templateConfig.series.push({
|
|
||||||
name: eqArr.key + (accumulator == 0 ? '' : '-' + accumulator),
|
|
||||||
// name: Math.random(),
|
|
||||||
type: 'line',
|
|
||||||
symbol: 'circle',
|
|
||||||
data: this.getEquipmentQuantity(eqArr),
|
|
||||||
});
|
|
||||||
},
|
|
||||||
|
|
||||||
/** 获得设备产量 */
|
/** 获得设备产量 */
|
||||||
getEquipmentQuantity(equipmentArr) {
|
getEquipmentQuantity(equipmentArr) {
|
||||||
return equipmentArr.map((item) => item.totalQuantity);
|
return equipmentArr.map((item) => item.totalQuantity);
|
||||||
@ -342,6 +246,19 @@ export default {
|
|||||||
);
|
);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
getRealConfig(index) {
|
||||||
|
// if (!this.graphList || this.graphList.length == 0) return;
|
||||||
|
const config = JSON.parse(JSON.stringify(this.templateConfig));
|
||||||
|
// config.legend.data = this.graphList[index].key;
|
||||||
|
config.series[0].name = this.graphList[index]?.key;
|
||||||
|
// console.log("this.graphList?.[index]", this.graphList?.[index]);
|
||||||
|
config.series[0].data = this.getEquipmentQuantity(
|
||||||
|
this.graphList?.[index] || []
|
||||||
|
);
|
||||||
|
config.xAxis.data = this.getTimeinfo(this.graphList?.[index] || []);
|
||||||
|
return config;
|
||||||
|
},
|
||||||
|
|
||||||
/** 准备设备数据 */
|
/** 准备设备数据 */
|
||||||
async initEquipment() {
|
async initEquipment() {
|
||||||
const { code, data } = await this.$axios({
|
const { code, data } = await this.$axios({
|
||||||
@ -396,42 +313,18 @@ export default {
|
|||||||
method: 'get',
|
method: 'get',
|
||||||
params: this.queryParams,
|
params: this.queryParams,
|
||||||
});
|
});
|
||||||
|
|
||||||
this.queryParams.equipmentId = null; // 清空一下
|
|
||||||
if (code == 0) {
|
if (code == 0) {
|
||||||
const newEqlist = this.objectToArray(data);
|
const newEqlist = this.objectToArray(data);
|
||||||
if (!newEqlist || newEqlist.length == 0) {
|
if (!newEqlist || newEqlist.length == 0) {
|
||||||
this.$message.error('该设备没有产量数据');
|
this.$message.error('该设备没有产量数据');
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
this.graphList.push(...newEqlist);
|
this.graphList.push(newEqlist[0]);
|
||||||
newEqlist.forEach(this.setSeries);
|
|
||||||
}
|
}
|
||||||
this.open = false;
|
this.open = false;
|
||||||
},
|
}
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style scoped lang="scss">
|
<style scoped lang="scss"></style>
|
||||||
.blue-title {
|
|
||||||
position: relative;
|
|
||||||
padding: 4px 0;
|
|
||||||
padding-left: 12px;
|
|
||||||
font-size: 14px;
|
|
||||||
color: #606266;
|
|
||||||
font-weight: 700;
|
|
||||||
margin-bottom: 12px;
|
|
||||||
|
|
||||||
&::before {
|
|
||||||
content: '';
|
|
||||||
position: absolute;
|
|
||||||
left: 0;
|
|
||||||
top: 6px;
|
|
||||||
height: 16px;
|
|
||||||
width: 4px;
|
|
||||||
border-radius: 1px;
|
|
||||||
background: #0b58ff;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
|
@ -6,38 +6,16 @@
|
|||||||
-->
|
-->
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div class="status-timegraph-container" style="background: #f2f4f9; flex: 1">
|
<div class="app-container">
|
||||||
<el-row
|
<h1>设备状态时序图</h1>
|
||||||
class=""
|
|
||||||
style="
|
|
||||||
margin-bottom: 12px;
|
|
||||||
background: #fff;
|
|
||||||
padding: 16px 16px 0;
|
|
||||||
border-radius: 8px;
|
|
||||||
">
|
|
||||||
<div class="blue-title">生产节拍时序图</div>
|
|
||||||
<!-- <h1>设备状态时序图</h1> -->
|
|
||||||
<!-- 搜索工作栏 -->
|
<!-- 搜索工作栏 -->
|
||||||
<SearchBar
|
<SearchBar
|
||||||
:formConfigs="searchBarFormConfig"
|
:formConfigs="searchBarFormConfig"
|
||||||
ref="search-bar"
|
ref="search-bar"
|
||||||
:remove-blue="true"
|
|
||||||
@headBtnClick="handleSearchBarBtnClick" />
|
@headBtnClick="handleSearchBarBtnClick" />
|
||||||
</el-row>
|
|
||||||
|
|
||||||
<el-row
|
<div class="main-area">
|
||||||
class=""
|
<div class="legend-row">
|
||||||
style="
|
|
||||||
margin-bottom: 12px;
|
|
||||||
background: #fff;
|
|
||||||
padding: 16px 16px 32px;
|
|
||||||
border-radius: 8px;
|
|
||||||
">
|
|
||||||
<el-row :gutter="20">
|
|
||||||
<el-col :span="6">
|
|
||||||
<div class="blue-title">设备状态时序图</div>
|
|
||||||
</el-col>
|
|
||||||
<el-col :span="18" class="legend-row">
|
|
||||||
<div class="legend">
|
<div class="legend">
|
||||||
<div class="icon running"></div>
|
<div class="icon running"></div>
|
||||||
<div>运行中</div>
|
<div>运行中</div>
|
||||||
@ -62,47 +40,79 @@
|
|||||||
<div class="icon stop"></div>
|
<div class="icon stop"></div>
|
||||||
<div>计划停机</div>
|
<div>计划停机</div>
|
||||||
</div>
|
</div>
|
||||||
</el-col>
|
</div>
|
||||||
</el-row>
|
|
||||||
<div class="main-area">
|
|
||||||
<div class="graphs" v-if="graphList.length">
|
<div class="graphs" v-if="graphList.length">
|
||||||
|
<!-- <div class="graph">
|
||||||
|
<h2 class="graph-title">设备1</h2>
|
||||||
|
<div class="graph-item running tick" data-time="00:00"></div>
|
||||||
|
<div class="graph-item running"></div>
|
||||||
|
<div class="graph-item running"></div>
|
||||||
|
<div class="graph-item lack tick" data-time="03:00"></div>
|
||||||
|
<div class="graph-item full tick" data-time="04:00"></div>
|
||||||
|
<div class="graph-item waiting tick" data-time="05:00"></div>
|
||||||
|
<div class="graph-item running tick" data-time="06:00"></div>
|
||||||
|
<div class="graph-item running"></div>
|
||||||
|
<div class="graph-item fault tick" data-time="08:00"></div>
|
||||||
|
<div class="graph-item waiting tick" data-time="09:00"></div>
|
||||||
|
<div class="graph-item running tick" data-time="10:00"></div>
|
||||||
|
<div class="graph-item running"></div>
|
||||||
|
<div class="graph-item running"></div>
|
||||||
|
<div class="graph-item lack tick" data-time="13:00"></div>
|
||||||
|
<div class="graph-item full tick" data-time="14:00"></div>
|
||||||
|
<div class="graph-item running tick" data-time="15:00"></div>
|
||||||
|
<div class="graph-item running"></div>
|
||||||
|
<div class="graph-item running"></div>
|
||||||
|
<div class="graph-item fault tick" data-time="18:00"></div>
|
||||||
|
<div class="graph-item running tick" data-time="19:00"></div>
|
||||||
|
<div class="graph-item running"></div>
|
||||||
|
<div class="graph-item running"></div>
|
||||||
|
<div class="graph-item running"></div>
|
||||||
|
<div class="graph-item stop tick" data-time="23:00"></div>
|
||||||
|
</div> -->
|
||||||
<div class="graph" v-for="eq in graphList" :key="eq.key">
|
<div class="graph" v-for="eq in graphList" :key="eq.key">
|
||||||
<h2 class="graph-title">{{ eq.key }}</h2>
|
<h2 class="graph-title">{{ eq.key }}</h2>
|
||||||
|
<div
|
||||||
<div class="graph-content">
|
|
||||||
<el-popover
|
|
||||||
trigger="hover"
|
|
||||||
v-for="blc in eq"
|
v-for="blc in eq"
|
||||||
:key="blc.startTime"
|
:key="blc.startTime"
|
||||||
:title="
|
|
||||||
blc.status == 0
|
|
||||||
? '运行'
|
|
||||||
: blc.status == 2
|
|
||||||
? '故障'
|
|
||||||
: '计划停机'
|
|
||||||
"
|
|
||||||
placement="top"
|
|
||||||
:content="new Date(blc.startTime).toLocaleTimeString()">
|
|
||||||
<div
|
|
||||||
slot="reference"
|
|
||||||
:key="blc.startTime + '__div'"
|
|
||||||
class="graph-item-fixed tick"
|
class="graph-item-fixed tick"
|
||||||
:class="{
|
:class="{
|
||||||
running: blc.status == 0,
|
running: blc.status == 0,
|
||||||
fault: blc.status == 2,
|
fault: blc.status == 2,
|
||||||
stop: blc.status == 1,
|
stop: blc.status == 1,
|
||||||
}"
|
}"
|
||||||
:style="{ height: '32px', width: blc.duration * 2 + 'px' }"
|
:style="{ width: blc.duration * 2 + 'px' }"
|
||||||
:data-time="
|
:data-time="new Date(blc.startTime).toLocaleTimeString()"></div>
|
||||||
new Date(blc.startTime).toLocaleTimeString()
|
|
||||||
"></div>
|
|
||||||
</el-popover>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
|
<!-- <div class="graph">
|
||||||
|
<h2 class="graph-title">设备3</h2>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
<div class="graph-item"></div>
|
||||||
|
</div> -->
|
||||||
</div>
|
</div>
|
||||||
<h2 v-else>请添加设备</h2>
|
<h2 v-else>请添加设备</h2>
|
||||||
</div>
|
</div>
|
||||||
</el-row>
|
|
||||||
|
|
||||||
<!-- 对话框(添加 / 修改) -->
|
<!-- 对话框(添加 / 修改) -->
|
||||||
<base-dialog
|
<base-dialog
|
||||||
@ -175,9 +185,9 @@ export default {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
type: 'button',
|
type: 'button',
|
||||||
btnName: '添加对比',
|
btnName: '设备对比',
|
||||||
name: 'compare',
|
name: 'compare',
|
||||||
color: 'primary',
|
color: 'warning',
|
||||||
plain: true,
|
plain: true,
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
@ -334,52 +344,26 @@ export default {
|
|||||||
|
|
||||||
<style scoped lang="scss">
|
<style scoped lang="scss">
|
||||||
.graph {
|
.graph {
|
||||||
// border: 1px solid #ccc;
|
border: 1px solid #ccc;
|
||||||
// padding: 12px 12px 28px 12px;
|
padding: 12px 12px 28px 12px;
|
||||||
// margin: 64px 0;
|
margin: 64px 0;
|
||||||
position: relative;
|
position: relative;
|
||||||
display: flex;
|
display: flex;
|
||||||
}
|
}
|
||||||
|
|
||||||
.graph-title {
|
.graph-title {
|
||||||
// position: absolute;
|
|
||||||
// top: -64px;
|
|
||||||
// left: -1px;
|
|
||||||
// padding: 8px 18px;
|
|
||||||
padding: 0 12px;
|
|
||||||
font-size: 14px;
|
|
||||||
line-height: 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
.graph-content {
|
|
||||||
display: flex;
|
|
||||||
flex: 1;
|
|
||||||
padding: 22px 12px;
|
|
||||||
border: 1px solid #ccc;
|
|
||||||
border-bottom-width: 2px;
|
|
||||||
border-top: none;
|
|
||||||
position: relative;
|
|
||||||
}
|
|
||||||
|
|
||||||
.graph-content::after,
|
|
||||||
.graph-content::before {
|
|
||||||
content: '';
|
|
||||||
position: absolute;
|
position: absolute;
|
||||||
width: 3px;
|
top: -64px;
|
||||||
height: 80%;
|
|
||||||
background: #fff;
|
|
||||||
right: -1px;
|
|
||||||
top: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.graph-content::before {
|
|
||||||
right: unset;
|
|
||||||
left: -1px;
|
left: -1px;
|
||||||
|
padding: 8px 18px;
|
||||||
|
background: #ccc;
|
||||||
|
font-size: 18px;
|
||||||
|
line-height: 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
.graph-item,
|
.graph-item,
|
||||||
.graph-item-fixed {
|
.graph-item-fixed {
|
||||||
// height: 88px;
|
height: 88px;
|
||||||
// width: 24px;
|
// width: 24px;
|
||||||
flex: 1;
|
flex: 1;
|
||||||
// border: 1px solid #ccc;
|
// border: 1px solid #ccc;
|
||||||
@ -421,40 +405,32 @@ export default {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.running {
|
.running {
|
||||||
background-color: #5ad8a6;
|
background-color: #84f04e;
|
||||||
// background-color: #84f04e;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.waiting {
|
.waiting {
|
||||||
background-color: #5ad8a6;
|
background-color: #409eff;
|
||||||
// background-color: #409eff;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.fault {
|
.fault {
|
||||||
// background-color: #ea5b5b;
|
background-color: #ea5b5b;
|
||||||
background-color: #fc9c91;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.full {
|
.full {
|
||||||
// background-color: #e6a23c;
|
background-color: #e6a23c;
|
||||||
background-color: #598fff;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.lack {
|
.lack {
|
||||||
// background-color: #a69c8d;
|
background-color: #a69c8d;
|
||||||
background-color: #7585a2;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.stop {
|
.stop {
|
||||||
background-color: #000;
|
background-color: #000c;
|
||||||
}
|
}
|
||||||
|
|
||||||
.legend-row {
|
.legend-row {
|
||||||
margin: 6px 0;
|
margin: 12px 0;
|
||||||
padding-right: 12px;
|
|
||||||
display: flex;
|
display: flex;
|
||||||
justify-content: flex-end;
|
|
||||||
|
|
||||||
> .legend:not(:last-child) {
|
> .legend:not(:last-child) {
|
||||||
margin-right: 12px;
|
margin-right: 12px;
|
||||||
}
|
}
|
||||||
@ -465,32 +441,9 @@ export default {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.icon {
|
.icon {
|
||||||
width: 8px;
|
width: 16px;
|
||||||
height: 8px;
|
|
||||||
border-radius: 2px;
|
|
||||||
margin-right: 4px;
|
|
||||||
margin-top: 1px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.blue-title {
|
|
||||||
position: relative;
|
|
||||||
padding: 4px 0;
|
|
||||||
padding-left: 12px;
|
|
||||||
font-size: 14px;
|
|
||||||
color: #606266;
|
|
||||||
font-weight: 700;
|
|
||||||
margin-bottom: 12px;
|
|
||||||
|
|
||||||
&::before {
|
|
||||||
content: '';
|
|
||||||
position: absolute;
|
|
||||||
left: 0;
|
|
||||||
top: 6px;
|
|
||||||
height: 16px;
|
height: 16px;
|
||||||
width: 4px;
|
margin-right: 8px;
|
||||||
border-radius: 1px;
|
|
||||||
background: #0b58ff;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
@ -16,7 +16,6 @@
|
|||||||
<method-btn
|
<method-btn
|
||||||
v-if="tableBtn.length"
|
v-if="tableBtn.length"
|
||||||
slot="handleBtn"
|
slot="handleBtn"
|
||||||
:width="120"
|
|
||||||
label="操作"
|
label="操作"
|
||||||
:method-list="tableBtn"
|
:method-list="tableBtn"
|
||||||
@clickBtn="handleTableBtnClick" />
|
@clickBtn="handleTableBtnClick" />
|
||||||
@ -82,12 +81,13 @@ export default {
|
|||||||
: undefined,
|
: undefined,
|
||||||
].filter((v) => v),
|
].filter((v) => v),
|
||||||
tableProps: [
|
tableProps: [
|
||||||
{ width: 128, prop: 'productionLine', label: '产线' },
|
{ width: 128, prop: 'productionLine', label: '产线', align: 'center' },
|
||||||
{ width: 128, prop: 'workshopSection', label: '工段' },
|
{ width: 128, prop: 'workshopSection', label: '工段', align: 'center' },
|
||||||
{ width: 128, prop: 'equipment', label: '设备名称' },
|
{ width: 128, prop: 'equipment', label: '设备名称', align: 'center' },
|
||||||
{
|
{
|
||||||
prop: 'alarmGrade',
|
prop: 'alarmGrade',
|
||||||
label: '报警级别',
|
label: '报警级别',
|
||||||
|
align: 'center',
|
||||||
filter: publicFormatter(this.DICT_TYPE.EQU_ALARM_LEVEL),
|
filter: publicFormatter(this.DICT_TYPE.EQU_ALARM_LEVEL),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -96,11 +96,11 @@ export default {
|
|||||||
width: 180,
|
width: 180,
|
||||||
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
||||||
},
|
},
|
||||||
{ prop: 'alarmContent', label: '报警内容' },
|
{ prop: 'alarmContent', label: '报警内容', align: 'center' },
|
||||||
// {
|
// {
|
||||||
// _action: 'equipment-group-show-alert',
|
// _action: 'equipment-group-show-alert',
|
||||||
// label: '报警',
|
// label: '报警',
|
||||||
// ,
|
// align: 'center',
|
||||||
// subcomponent: {
|
// subcomponent: {
|
||||||
// props: ['injectData'],
|
// props: ['injectData'],
|
||||||
// render: function (h) {
|
// render: function (h) {
|
||||||
|
@ -35,9 +35,7 @@
|
|||||||
" />
|
" />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div v-else style="margin-top: 20px; color: #c7c7c7; text-align: center">
|
<div v-else style="margin-top: 20px; color: #c7c7c7; text-align: center;">暂无数据</div>
|
||||||
暂无数据
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
@ -141,16 +139,19 @@ export default {
|
|||||||
width: 48,
|
width: 48,
|
||||||
prop: 'index',
|
prop: 'index',
|
||||||
label: '序号',
|
label: '序号',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
width: 160,
|
width: 160,
|
||||||
prop: 'time',
|
prop: 'time',
|
||||||
label: '时间',
|
label: '时间',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
width: 200,
|
width: 200,
|
||||||
prop: 'plcCode',
|
prop: 'plcCode',
|
||||||
label: 'PLC编码',
|
label: 'PLC编码',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
const firstLineData = {
|
const firstLineData = {
|
||||||
@ -161,6 +162,7 @@ export default {
|
|||||||
otherList.forEach((item) => {
|
otherList.forEach((item) => {
|
||||||
props.push({
|
props.push({
|
||||||
label: item.name,
|
label: item.name,
|
||||||
|
align: 'center',
|
||||||
prop: item.name,
|
prop: item.name,
|
||||||
width: 128,
|
width: 128,
|
||||||
});
|
});
|
||||||
|
@ -17,16 +17,15 @@ import * as echarts from 'echarts';
|
|||||||
export default {
|
export default {
|
||||||
name: 'LineChartInEquipmentProcessAmount',
|
name: 'LineChartInEquipmentProcessAmount',
|
||||||
components: {},
|
components: {},
|
||||||
props: ['equipmentList', 'render'],
|
props: ['equipmentList'],
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
chart: null,
|
chart: null,
|
||||||
option: {
|
option: {
|
||||||
color: ['#288AFF'],
|
|
||||||
grid: {
|
grid: {
|
||||||
top: 64,
|
top: 64,
|
||||||
left: 56,
|
left: 56,
|
||||||
right: 64,
|
right: 24,
|
||||||
bottom: 56,
|
bottom: 56,
|
||||||
},
|
},
|
||||||
title: {
|
title: {
|
||||||
@ -65,10 +64,6 @@ export default {
|
|||||||
color: '#ccc',
|
color: '#ccc',
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
name: '数量',
|
|
||||||
nameTextStyle: {
|
|
||||||
fontSize: 14,
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
series: [
|
series: [
|
||||||
{
|
{
|
||||||
@ -90,19 +85,16 @@ export default {
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
watch: {
|
mounted() {
|
||||||
render: {
|
// console.log('this.eq list', this.equipmentList);
|
||||||
handler: function (newVal, oldVal) {
|
|
||||||
if (!this.chart) this.chart = echarts.init(this.$refs.chart);
|
if (!this.chart) this.chart = echarts.init(this.$refs.chart);
|
||||||
|
|
||||||
this.$nextTick(() => {
|
this.$nextTick(() => {
|
||||||
if (this.chart) this.chart.setOption(this.updateConfig(this.option));
|
this.chart.setOption(this.updateConfig(this.option));
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
deep: true,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
beforeDestroy() {
|
beforeDestroy() {
|
||||||
if (this.chart) this.chart.dispose();
|
this.chart.dispose();
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
updateConfig(config) {
|
updateConfig(config) {
|
||||||
@ -130,6 +122,5 @@ export default {
|
|||||||
.chart {
|
.chart {
|
||||||
height: 100%;
|
height: 100%;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
// background: lightcoral;
|
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
@ -9,52 +9,15 @@
|
|||||||
<div style="flex: 1; display: flex; background: #f2f4f9">
|
<div style="flex: 1; display: flex; background: #f2f4f9">
|
||||||
<div
|
<div
|
||||||
class="app-container"
|
class="app-container"
|
||||||
style="
|
style="margin-right: 12px; border-radius: 8px; background: #fff">
|
||||||
margin-right: 12px;
|
|
||||||
border-radius: 8px;
|
|
||||||
background: #fff;
|
|
||||||
padding: 0;
|
|
||||||
">
|
|
||||||
<div
|
|
||||||
class="factory-list__selector"
|
|
||||||
style="margin: 12px"
|
|
||||||
title="点击切换工厂"
|
|
||||||
@mouseenter="factoryListOpen = true"
|
|
||||||
@mouseleave="factoryListOpen = false">
|
|
||||||
{{ currentFactory?.label || '工厂名称' }}
|
|
||||||
<div class="factory-list__wrapper" :class="{ open: factoryListOpen }">
|
|
||||||
<ul
|
|
||||||
class="factory-list"
|
|
||||||
v-if="sidebarContent.length"
|
|
||||||
@click.prevent="factoryChangeHandler">
|
|
||||||
<li
|
|
||||||
v-for="fc in sidebarContent"
|
|
||||||
:key="fc.id"
|
|
||||||
:data-value="fc.id"
|
|
||||||
class="factory-list__item"
|
|
||||||
:class="{ 'is-current': fc.id == currentFactory?.id }">
|
|
||||||
{{ fc.label }}
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
<div v-else style="color: #0008; width: 128px; text-align: center">
|
|
||||||
- 无 -
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- side bar -->
|
<!-- side bar -->
|
||||||
<div class="side-bar__left" style="width: 240px; height: 100%">
|
<div
|
||||||
|
class="side-bar__left"
|
||||||
|
style="width: 240px; padding: 12px; height: 100%">
|
||||||
<el-tree
|
<el-tree
|
||||||
class="custom-tree-class"
|
:data="sidebarContent"
|
||||||
:data="currentFactory?.children"
|
|
||||||
:props="treeProps"
|
:props="treeProps"
|
||||||
:empty-text="' - 暂无数据 - '"
|
@node-click="handleSidebarItemClick" />
|
||||||
icon-class="custom-icon-class"
|
|
||||||
@node-click="handleSidebarItemClick">
|
|
||||||
<!-- <div class="custom-tree-node" slot-scope="{ node, data }">
|
|
||||||
<span class="icon"></span>
|
|
||||||
<span>{{ node.label }}</span>
|
|
||||||
</div> -->
|
|
||||||
</el-tree>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div
|
<div
|
||||||
@ -67,10 +30,7 @@
|
|||||||
ref="search-bar"
|
ref="search-bar"
|
||||||
@headBtnClick="handleSearchBarBtnClick" />
|
@headBtnClick="handleSearchBarBtnClick" />
|
||||||
|
|
||||||
<el-row>
|
<transition appear name="vvv" mode="out-in">
|
||||||
<el-col class="custom-tabs">
|
|
||||||
<el-tabs v-model="activeName" @tab-click="handleTabClick">
|
|
||||||
<el-tab-pane :label="'\u2002数据列表\u2002'" name="table">
|
|
||||||
<base-table
|
<base-table
|
||||||
v-if="mode == 'table'"
|
v-if="mode == 'table'"
|
||||||
:table-props="tableProps"
|
:table-props="tableProps"
|
||||||
@ -85,30 +45,13 @@
|
|||||||
:method-list="tableBtn"
|
:method-list="tableBtn"
|
||||||
@clickBtn="handleTableBtnClick" /> -->
|
@clickBtn="handleTableBtnClick" /> -->
|
||||||
</base-table>
|
</base-table>
|
||||||
</el-tab-pane>
|
|
||||||
<el-tab-pane :label="'\u3000柱状图\u3000'" name="graph">
|
|
||||||
<div class="graph" style="height: 56vh">
|
|
||||||
<!-- graph -->
|
|
||||||
<Graph
|
|
||||||
v-if="list.length"
|
|
||||||
:equipment-list="list"
|
|
||||||
:render="renderKey" />
|
|
||||||
<div
|
|
||||||
v-if="list.length == 0"
|
|
||||||
style="
|
|
||||||
color: #c7c7c7;
|
|
||||||
text-align: center;
|
|
||||||
margin-top: 20px;
|
|
||||||
">
|
|
||||||
没有设备
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</el-tab-pane>
|
|
||||||
</el-tabs>
|
|
||||||
</el-col>
|
|
||||||
</el-row>
|
|
||||||
|
|
||||||
<!-- <transition appear name="vvv" mode="out-in"></transition> -->
|
<div class="graph" style="height: 56vh;" v-else>
|
||||||
|
<!-- graph -->
|
||||||
|
<Graph v-if="list.length" :equipment-list="list" />
|
||||||
|
<div v-else style="color: #c7c7c7; text-align: center; margin-top: 20px;">没有设备</div>
|
||||||
|
</div>
|
||||||
|
</transition>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -123,17 +66,6 @@ export default {
|
|||||||
props: {},
|
props: {},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
renderKey: Math.random(),
|
|
||||||
factoryListOpen: false,
|
|
||||||
currentFactory: null,
|
|
||||||
factoryList: [
|
|
||||||
{ name: '1', value: 1 },
|
|
||||||
{ name: '2', value: 2 },
|
|
||||||
{ name: '3', value: 3 },
|
|
||||||
{ name: '4', value: 4 },
|
|
||||||
{ name: '5', value: 5 },
|
|
||||||
{ name: '6', value: 6 },
|
|
||||||
],
|
|
||||||
sidebarContent: [
|
sidebarContent: [
|
||||||
// {
|
// {
|
||||||
// id: 'fc1',
|
// id: 'fc1',
|
||||||
@ -220,7 +152,6 @@ export default {
|
|||||||
// ],
|
// ],
|
||||||
// },
|
// },
|
||||||
],
|
],
|
||||||
activeName: 'table',
|
|
||||||
searchBarFormConfig: [
|
searchBarFormConfig: [
|
||||||
{
|
{
|
||||||
type: 'datePicker',
|
type: 'datePicker',
|
||||||
@ -241,23 +172,23 @@ export default {
|
|||||||
name: 'search',
|
name: 'search',
|
||||||
color: 'primary',
|
color: 'primary',
|
||||||
},
|
},
|
||||||
// {
|
{
|
||||||
// type: 'separate',
|
type: 'separate',
|
||||||
// },
|
},
|
||||||
// {
|
{
|
||||||
// type: 'button',
|
type: 'button',
|
||||||
// btnName: '表格',
|
btnName: '表格',
|
||||||
// name: 'table',
|
name: 'table',
|
||||||
// plain: true,
|
plain: true,
|
||||||
// color: 'success',
|
color: 'success',
|
||||||
// },
|
},
|
||||||
// {
|
{
|
||||||
// type: 'button',
|
type: 'button',
|
||||||
// btnName: '图表',
|
btnName: '图表',
|
||||||
// name: 'graph',
|
name: 'graph',
|
||||||
// plain: true,
|
plain: true,
|
||||||
// color: 'warning',
|
color: 'warning',
|
||||||
// },
|
},
|
||||||
// {
|
// {
|
||||||
// type: this.$auth.hasPermi('base:equipment-group:export') ? 'button' : '',
|
// type: this.$auth.hasPermi('base:equipment-group:export') ? 'button' : '',
|
||||||
// btnName: '导出',
|
// btnName: '导出',
|
||||||
@ -266,11 +197,11 @@ export default {
|
|||||||
// },
|
// },
|
||||||
],
|
],
|
||||||
tableProps: [
|
tableProps: [
|
||||||
{ prop: 'lineName', label: '产线' },
|
{ prop: 'lineName', label: '产线', align: 'center' },
|
||||||
{ prop: 'sectionName', label: '工段' },
|
{ prop: 'sectionName', label: '工段', align: 'center' },
|
||||||
{ prop: 'externalCode', label: '设备编码' },
|
{ prop: 'externalCode', label: '设备编码', align: 'center' },
|
||||||
{ prop: 'equipmentName', label: '设备名称' },
|
{ prop: 'equipmentName', label: '设备名称', align: 'center' },
|
||||||
{ prop: 'totalQuantity', label: '加工数量' },
|
{ prop: 'totalQuantity', label: '加工数量', align: 'center' },
|
||||||
],
|
],
|
||||||
mode: 'table', // table | graph
|
mode: 'table', // table | graph
|
||||||
queryParams: {
|
queryParams: {
|
||||||
@ -299,20 +230,20 @@ export default {
|
|||||||
this.$set(factory, 'label', factory.name);
|
this.$set(factory, 'label', factory.name);
|
||||||
this.$set(factory, 'type', '工厂');
|
this.$set(factory, 'type', '工厂');
|
||||||
delete factory.name;
|
delete factory.name;
|
||||||
// factory.children = factory.lines;
|
factory.children = factory.lines;
|
||||||
// delete factory.lines;
|
delete factory.lines;
|
||||||
factory.children?.forEach((line) => {
|
factory.children?.forEach((line) => {
|
||||||
this.$set(line, 'label', line.name);
|
this.$set(line, 'label', line.name);
|
||||||
this.$set(line, 'type', '产线');
|
this.$set(line, 'type', '产线');
|
||||||
delete line.name;
|
delete line.name;
|
||||||
// line.children = line.sections;
|
line.children = line.sections;
|
||||||
// delete line.sections;
|
delete line.sections;
|
||||||
line.children?.forEach((ws) => {
|
line.children?.forEach((ws) => {
|
||||||
this.$set(ws, 'label', ws.name);
|
this.$set(ws, 'label', ws.name);
|
||||||
this.$set(ws, 'type', '工段');
|
this.$set(ws, 'type', '工段');
|
||||||
delete ws.name;
|
delete ws.name;
|
||||||
// ws.children = ws.equipments;
|
ws.children = ws.equipments;
|
||||||
// delete ws.equipments;
|
delete ws.equipments;
|
||||||
ws.children?.forEach((eq) => {
|
ws.children?.forEach((eq) => {
|
||||||
this.$set(eq, 'label', eq.name);
|
this.$set(eq, 'label', eq.name);
|
||||||
this.$set(eq, 'type', '设备');
|
this.$set(eq, 'type', '设备');
|
||||||
@ -327,22 +258,10 @@ export default {
|
|||||||
const { data } = await this.$axios('/base/factory/getTree');
|
const { data } = await this.$axios('/base/factory/getTree');
|
||||||
this.sidebarContent = data;
|
this.sidebarContent = data;
|
||||||
this.buildTree(data);
|
this.buildTree(data);
|
||||||
console.log('tree', this.sidebarContent);
|
|
||||||
},
|
|
||||||
|
|
||||||
handleTabClick(tab, event) {
|
|
||||||
if (tab.name == 'graph') this.renderKey = Math.random();
|
|
||||||
},
|
|
||||||
|
|
||||||
factoryChangeHandler(event) {
|
|
||||||
this.factoryListOpen = false;
|
|
||||||
const fcId = event.target.dataset.value;
|
|
||||||
this.handleSidebarItemClick({ id: fcId, type: '工厂' });
|
|
||||||
this.currentFactory = this.sidebarContent.find((item) => item.id == fcId);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
handleSidebarItemClick({ label, id, type }) {
|
handleSidebarItemClick({ label, id, type }) {
|
||||||
console.log('label clicked!', label, id, type);
|
console.log('lable clicked!', label, id, type);
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case '设备':
|
case '设备':
|
||||||
this.queryParams.equipmentId = id;
|
this.queryParams.equipmentId = id;
|
||||||
@ -398,10 +317,8 @@ export default {
|
|||||||
|
|
||||||
<style scoped>
|
<style scoped>
|
||||||
.side-bar__left >>> .is-current {
|
.side-bar__left >>> .is-current {
|
||||||
padding: 0;
|
|
||||||
color: #111;
|
color: #111;
|
||||||
/* background: #f2f4f7; */
|
background: #f2f4f7;
|
||||||
background: #e3efff !important;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.vvv-enter,
|
.vvv-enter,
|
||||||
@ -421,149 +338,4 @@ export default {
|
|||||||
/* transform: translateY(0) scaleY(1); */
|
/* transform: translateY(0) scaleY(1); */
|
||||||
transform: translateY(0);
|
transform: translateY(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
.custom-tabs >>> .el-tabs__header {
|
|
||||||
margin-bottom: 8px;
|
|
||||||
display: inline-block;
|
|
||||||
transform: translateY(-12px);
|
|
||||||
}
|
|
||||||
.custom-tabs >>> .el-tabs__item {
|
|
||||||
padding-left: 0px !important;
|
|
||||||
padding-right: 0px !important;
|
|
||||||
line-height: 36px !important;
|
|
||||||
height: 36px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.factory-list__selector {
|
|
||||||
position: relative;
|
|
||||||
height: 36px;
|
|
||||||
font-size: 16px;
|
|
||||||
line-height: 36px;
|
|
||||||
padding-left: 28px;
|
|
||||||
background: url(../../../assets/images/factory-icon.png) 0 / 10% no-repeat;
|
|
||||||
}
|
|
||||||
|
|
||||||
.factory-list__selector:hover {
|
|
||||||
cursor: pointer;
|
|
||||||
color: #0008;
|
|
||||||
}
|
|
||||||
|
|
||||||
.factory-list__selector::after {
|
|
||||||
/* content: ''; */
|
|
||||||
position: absolute;
|
|
||||||
top: 16px;
|
|
||||||
right: 12px;
|
|
||||||
display: inline-block;
|
|
||||||
width: 8px;
|
|
||||||
height: 8px;
|
|
||||||
/* background: #5c5c5c; */
|
|
||||||
border-color: #000;
|
|
||||||
border-width: 4px;
|
|
||||||
border-style: solid;
|
|
||||||
border-top-color: transparent;
|
|
||||||
border-right-color: transparent;
|
|
||||||
border-bottom-color: transparent;
|
|
||||||
}
|
|
||||||
.factory-list__selector:hover::after {
|
|
||||||
/* cursor: pointer; */
|
|
||||||
border-left-color: #0008;
|
|
||||||
}
|
|
||||||
|
|
||||||
.factory-list__wrapper {
|
|
||||||
visibility: hidden;
|
|
||||||
position: absolute;
|
|
||||||
background: #fff;
|
|
||||||
box-shadow: 0 0 32px 10px #0002;
|
|
||||||
border-radius: 8px;
|
|
||||||
top: 36px;
|
|
||||||
left: 90px;
|
|
||||||
/* max-width: 128px; */
|
|
||||||
height: auto;
|
|
||||||
width: auto;
|
|
||||||
white-space: nowrap;
|
|
||||||
overflow: hidden;
|
|
||||||
/* transition: all 0.3s ease-out; */
|
|
||||||
z-index: 1000;
|
|
||||||
}
|
|
||||||
|
|
||||||
.factory-list__wrapper.open {
|
|
||||||
visibility: visible;
|
|
||||||
}
|
|
||||||
|
|
||||||
ul,
|
|
||||||
li {
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
list-style: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.factory-list {
|
|
||||||
color: #0008;
|
|
||||||
max-height: 240px;
|
|
||||||
overflow-y: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
.factory-list__item {
|
|
||||||
font-size: 16px;
|
|
||||||
line-height: 1;
|
|
||||||
padding: 8px 64px 8px 16px;
|
|
||||||
/* min-width: 64px; */
|
|
||||||
position: relative;
|
|
||||||
}
|
|
||||||
|
|
||||||
.factory-list__item:hover,
|
|
||||||
.factory-list__item.is-current {
|
|
||||||
background: #e3efff;
|
|
||||||
color: #0b58ff;
|
|
||||||
}
|
|
||||||
|
|
||||||
.factory-list__item.is-current::after {
|
|
||||||
content: '√';
|
|
||||||
position: absolute;
|
|
||||||
top: 8px;
|
|
||||||
right: 16px;
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
.custom-tree-class >>> .el-tree-node__content {
|
|
||||||
height: auto !important;
|
|
||||||
padding: 8px 12px !important;
|
|
||||||
}
|
|
||||||
.custom-tree-class >>> .el-tree-node__content:hover {
|
|
||||||
background: #e3efff;
|
|
||||||
}
|
|
||||||
|
|
||||||
.custom-tree-class >>> .el-tree-node__children .el-tree-node__content {
|
|
||||||
padding: 8px 18px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.custom-tree-class
|
|
||||||
>>> .el-tree-node__children
|
|
||||||
.el-tree-node__children
|
|
||||||
.el-tree-node__content {
|
|
||||||
padding: 8px 24px !important;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
|
|
||||||
<style>
|
|
||||||
.custom-icon-class {
|
|
||||||
margin-right: 8px;
|
|
||||||
width: 20px;
|
|
||||||
height: 24px;
|
|
||||||
background: url('../../../assets/images/tree-icon-1.png') 100% / contain
|
|
||||||
no-repeat;
|
|
||||||
}
|
|
||||||
|
|
||||||
.custom-icon-class.el-tree-node__expand-icon.expanded {
|
|
||||||
transform: unset;
|
|
||||||
}
|
|
||||||
|
|
||||||
.el-tree-node__children .custom-icon-class {
|
|
||||||
background: url('../../../assets/images/tree-icon-2.png') 100% / contain
|
|
||||||
no-repeat;
|
|
||||||
}
|
|
||||||
|
|
||||||
.el-tree-node__children .el-tree-node__children .custom-icon-class {
|
|
||||||
background: unset;
|
|
||||||
}
|
|
||||||
</style>
|
</style>
|
||||||
|
@ -11,9 +11,8 @@
|
|||||||
:formConfigs="[{ label: '设备近24小时生产记录', type: 'title' }]"
|
:formConfigs="[{ label: '设备近24小时生产记录', type: 'title' }]"
|
||||||
ref="search-bar" />
|
ref="search-bar" />
|
||||||
<el-skeleton v-if="initing" :rows="6" animated />
|
<el-skeleton v-if="initing" :rows="6" animated />
|
||||||
<div v-else :class="{ 'no-data-bg': !list || list.length == 0 }">
|
|
||||||
<base-table
|
<base-table
|
||||||
v-if="list && list.length > 0"
|
v-else
|
||||||
:span-method="mergeColumnHandler"
|
:span-method="mergeColumnHandler"
|
||||||
:table-props="tableProps"
|
:table-props="tableProps"
|
||||||
:table-data="list"
|
:table-data="list"
|
||||||
@ -21,7 +20,6 @@
|
|||||||
<!-- :page="queryParams.pageNo"
|
<!-- :page="queryParams.pageNo"
|
||||||
:limit="queryParams.pageSize" -->
|
:limit="queryParams.pageSize" -->
|
||||||
</div>
|
</div>
|
||||||
</div>
|
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
@ -39,7 +37,6 @@ export default {
|
|||||||
list: [],
|
list: [],
|
||||||
tableProps: [],
|
tableProps: [],
|
||||||
spanInfo: {},
|
spanInfo: {},
|
||||||
noData: true,
|
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
computed: {},
|
computed: {},
|
||||||
@ -54,22 +51,24 @@ export default {
|
|||||||
} = item;
|
} = item;
|
||||||
|
|
||||||
const props = [
|
const props = [
|
||||||
{ prop: 'productLine', label: '产线' },
|
{ prop: 'productLine', label: '产线', align: 'center' },
|
||||||
{ prop: 'specification', label: '规格' },
|
{ prop: 'specification', label: '规格', align: 'center' },
|
||||||
{ prop: 'equipmentName', label: '设备' },
|
{ prop: 'equipmentName', label: '设备', align: 'center' },
|
||||||
{ prop: 'totalQuantity', label: '生产总数' },
|
{ prop: 'totalQuantity', label: '生产总数', align: 'center' },
|
||||||
];
|
];
|
||||||
|
|
||||||
for (const key of Object.keys(hourData).sort()) {
|
for (const key of Object.keys(hourData).sort()) {
|
||||||
const subprop = {
|
const subprop = {
|
||||||
label: key,
|
label: key,
|
||||||
|
align: 'center',
|
||||||
children: [
|
children: [
|
||||||
{ prop: key + '__in', label: '进数据' },
|
{ prop: key + '__in', label: '进数据', align: 'center' },
|
||||||
{ prop: key + '__out', label: '出数据' },
|
{ prop: key + '__out', label: '出数据', align: 'center' },
|
||||||
{ prop: key + '__nok', label: '报废数据' },
|
{ prop: key + '__nok', label: '报废数据', align: 'center' },
|
||||||
{
|
{
|
||||||
prop: key + '__ratio',
|
prop: key + '__ratio',
|
||||||
label: '报废率',
|
label: '报废率',
|
||||||
|
align: 'center',
|
||||||
filter: (val) => (val != null ? val + ' %' : '-'),
|
filter: (val) => (val != null ? val + ' %' : '-'),
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
@ -139,13 +138,6 @@ export default {
|
|||||||
// console.log('recent-24', data);
|
// console.log('recent-24', data);
|
||||||
|
|
||||||
this.initing = true;
|
this.initing = true;
|
||||||
|
|
||||||
if (!data || !data.length) {
|
|
||||||
this.initing = false;
|
|
||||||
this.noData = true;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
this.noData = false;
|
|
||||||
this.buildProps(data[0]);
|
this.buildProps(data[0]);
|
||||||
this.buildData(data);
|
this.buildData(data);
|
||||||
this.queryParams.pageSize = this.list.length;
|
this.queryParams.pageSize = this.list.length;
|
||||||
|
@ -18,7 +18,6 @@
|
|||||||
v-if="tableBtn.length"
|
v-if="tableBtn.length"
|
||||||
slot="handleBtn"
|
slot="handleBtn"
|
||||||
label="操作"
|
label="操作"
|
||||||
:width="120"
|
|
||||||
:method-list="tableBtn"
|
:method-list="tableBtn"
|
||||||
@clickBtn="handleTableBtnClick" />
|
@clickBtn="handleTableBtnClick" />
|
||||||
</base-table>
|
</base-table>
|
||||||
@ -75,24 +74,28 @@ export default {
|
|||||||
width: 128,
|
width: 128,
|
||||||
prop: 'equipmentName',
|
prop: 'equipmentName',
|
||||||
label: '设备名称',
|
label: '设备名称',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
width: 128,
|
width: 128,
|
||||||
prop: 'equipmentCode',
|
prop: 'equipmentCode',
|
||||||
label: '设备编码',
|
label: '设备编码',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{ width: 128, prop: 'inQuantity', label: '投入数' },
|
{ width: 128, prop: 'inQuantity', label: '投入数', align: 'center' },
|
||||||
{ width: 128, prop: 'outQuantity', label: '产出数' },
|
{ width: 128, prop: 'outQuantity', label: '产出数', align: 'center' },
|
||||||
{
|
{
|
||||||
width: 128,
|
width: 128,
|
||||||
prop: 'run',
|
prop: 'run',
|
||||||
label: '是否运行',
|
label: '是否运行',
|
||||||
|
align: 'center',
|
||||||
filter: (val) => (val != null ? (val ? '是' : '否') : '-'),
|
filter: (val) => (val != null ? (val ? '是' : '否') : '-'),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
width: 128,
|
width: 128,
|
||||||
prop: 'status',
|
prop: 'status',
|
||||||
label: '状态',
|
label: '状态',
|
||||||
|
align: 'center',
|
||||||
filter: (val) =>
|
filter: (val) =>
|
||||||
val != null ? ['正常', '计划停机', '故障'][val] : '-',
|
val != null ? ['正常', '计划停机', '故障'][val] : '-',
|
||||||
},
|
},
|
||||||
@ -100,6 +103,7 @@ export default {
|
|||||||
width: 128,
|
width: 128,
|
||||||
prop: 'error',
|
prop: 'error',
|
||||||
label: '是否故障',
|
label: '是否故障',
|
||||||
|
align: 'center',
|
||||||
filter: (val) => (val != null ? (val ? '是' : '否') : '-'),
|
filter: (val) => (val != null ? (val ? '是' : '否') : '-'),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -117,6 +121,7 @@ export default {
|
|||||||
{
|
{
|
||||||
_action: 'params-monitor',
|
_action: 'params-monitor',
|
||||||
label: '参数监控',
|
label: '参数监控',
|
||||||
|
align: 'center',
|
||||||
subcomponent: {
|
subcomponent: {
|
||||||
props: ['injectData'],
|
props: ['injectData'],
|
||||||
render: function (h) {
|
render: function (h) {
|
||||||
@ -124,7 +129,7 @@ export default {
|
|||||||
return h(
|
return h(
|
||||||
'el-button',
|
'el-button',
|
||||||
{
|
{
|
||||||
props: { type: 'text' },
|
props: { type: 'text', size: 'mini' },
|
||||||
on: {
|
on: {
|
||||||
click: function () {
|
click: function () {
|
||||||
console.log('inejctdata', _this.injectData);
|
console.log('inejctdata', _this.injectData);
|
||||||
|
@ -1,238 +0,0 @@
|
|||||||
<!--
|
|
||||||
filename: dialogForm.vue
|
|
||||||
author: liubin
|
|
||||||
date: 2023-09-11 15:55:13
|
|
||||||
description: DialogForm for equipmentBindSection only
|
|
||||||
-->
|
|
||||||
|
|
||||||
<template>
|
|
||||||
<el-form
|
|
||||||
ref="form"
|
|
||||||
:model="dataForm"
|
|
||||||
label-width="100px"
|
|
||||||
v-loading="formLoading">
|
|
||||||
<el-row :gutter="20">
|
|
||||||
<el-col>
|
|
||||||
<el-form-item
|
|
||||||
label="产线"
|
|
||||||
prop="productionId"
|
|
||||||
:rules="[{ required: true, message: '不能为空', trigger: 'blur' }]">
|
|
||||||
<el-select
|
|
||||||
v-model="dataForm.productionId"
|
|
||||||
placeholder="请选择产线"
|
|
||||||
filterable
|
|
||||||
@change="handleProductlineChange">
|
|
||||||
<el-option
|
|
||||||
v-for="opt in productionLineList"
|
|
||||||
:key="opt.value"
|
|
||||||
:label="opt.label"
|
|
||||||
:value="opt.value" />
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
</el-col>
|
|
||||||
<el-col>
|
|
||||||
<el-form-item
|
|
||||||
label="工段"
|
|
||||||
prop="sectionId"
|
|
||||||
:rules="[{ required: true, message: '不能为空', trigger: 'blur' }]">
|
|
||||||
<el-select
|
|
||||||
v-model="dataForm.sectionId"
|
|
||||||
placeholder="请选择工段"
|
|
||||||
filterable
|
|
||||||
@change="$emit('update', dataForm)">
|
|
||||||
<el-option
|
|
||||||
v-for="opt in workshopSectionList"
|
|
||||||
:key="opt.value"
|
|
||||||
:label="opt.label"
|
|
||||||
:value="opt.value" />
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
</el-col>
|
|
||||||
|
|
||||||
<el-col>
|
|
||||||
<el-form-item
|
|
||||||
label="按钮盒识别码"
|
|
||||||
prop="buttonId"
|
|
||||||
:rules="[
|
|
||||||
{ required: true, message: '不能为空', trigger: 'blur' },
|
|
||||||
{
|
|
||||||
type: 'number',
|
|
||||||
message: '请输入整数',
|
|
||||||
trigger: 'blur',
|
|
||||||
transform: (val) => Number.isInteger(Number(val)) && Number(val),
|
|
||||||
},
|
|
||||||
]">
|
|
||||||
<el-input
|
|
||||||
v-model="dataForm.buttonId"
|
|
||||||
@change="$emit('update', dataForm)"
|
|
||||||
placeholder="请输入整数" />
|
|
||||||
</el-form-item>
|
|
||||||
<!--
|
|
||||||
<el-form-item
|
|
||||||
label="报警编码"
|
|
||||||
prop="code"
|
|
||||||
:rules="[{ required: true, message: '不能为空', trigger: 'blur' }]">
|
|
||||||
<el-select
|
|
||||||
v-model="dataForm.code"
|
|
||||||
placeholder="请选择产线"
|
|
||||||
@change="handleProductlineChange">
|
|
||||||
<el-option
|
|
||||||
v-for="opt in productionLineList"
|
|
||||||
:key="opt.value"
|
|
||||||
:label="opt.label"
|
|
||||||
:value="opt.value" />
|
|
||||||
</el-select>
|
|
||||||
</el-form-item> -->
|
|
||||||
</el-col>
|
|
||||||
|
|
||||||
<el-col>
|
|
||||||
<el-form-item label="按钮盒模式" prop="model">
|
|
||||||
<el-input
|
|
||||||
v-model="dataForm.model"
|
|
||||||
@change="$emit('update', dataForm)"
|
|
||||||
placeholder="请输入按钮盒模式" />
|
|
||||||
</el-form-item>
|
|
||||||
</el-col>
|
|
||||||
|
|
||||||
<el-col>
|
|
||||||
<el-form-item
|
|
||||||
label="按钮值"
|
|
||||||
prop="keyValue"
|
|
||||||
:rules="[
|
|
||||||
{ required: true, message: '不能为空', trigger: 'blur' },
|
|
||||||
{
|
|
||||||
type: 'number',
|
|
||||||
message: '请输入100以内的整数',
|
|
||||||
trigger: 'blur',
|
|
||||||
transform: (val) =>
|
|
||||||
Number.isInteger(+val) &&
|
|
||||||
Number(val) >= 0 &&
|
|
||||||
Number(val) <= 100 &&
|
|
||||||
Number(val),
|
|
||||||
},
|
|
||||||
]">
|
|
||||||
<el-input
|
|
||||||
v-model="dataForm.keyValue"
|
|
||||||
type="number"
|
|
||||||
min="0"
|
|
||||||
max="100"
|
|
||||||
@change="$emit('update', dataForm)"
|
|
||||||
placeholder="请输入按钮盒模式" />
|
|
||||||
</el-form-item>
|
|
||||||
</el-col>
|
|
||||||
|
|
||||||
<el-col>
|
|
||||||
<el-form-item label="检测内容" prop="inspectionDetContent">
|
|
||||||
<el-input
|
|
||||||
type="textarea"
|
|
||||||
v-model="dataForm.inspectionDetContent"
|
|
||||||
placeholder="请输入检测内容"
|
|
||||||
@change="$emit('update', dataForm)"></el-input>
|
|
||||||
</el-form-item>
|
|
||||||
</el-col>
|
|
||||||
</el-row>
|
|
||||||
</el-form>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script>
|
|
||||||
export default {
|
|
||||||
name: 'DialogForm',
|
|
||||||
model: {
|
|
||||||
prop: 'dataForm',
|
|
||||||
event: 'update',
|
|
||||||
},
|
|
||||||
emits: ['update'],
|
|
||||||
components: {},
|
|
||||||
props: {
|
|
||||||
dataForm: {
|
|
||||||
type: Object,
|
|
||||||
default: () => ({}),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
data() {
|
|
||||||
return {
|
|
||||||
formLoading: true,
|
|
||||||
productionLineList: [],
|
|
||||||
workshopSectionList: [],
|
|
||||||
};
|
|
||||||
},
|
|
||||||
mounted() {
|
|
||||||
this.getProductionLineList();
|
|
||||||
// this.getWorksectionList();
|
|
||||||
// this.getCode('/base/equipment-group-alarm/getCode').then((code) => {
|
|
||||||
// this.formLoading = false;
|
|
||||||
// this.$emit('update', {
|
|
||||||
// ...this.dataForm,
|
|
||||||
// code,
|
|
||||||
// });
|
|
||||||
// });
|
|
||||||
},
|
|
||||||
watch: {
|
|
||||||
'dataForm.productionId': {
|
|
||||||
handler(id) {
|
|
||||||
if (id != null) this.getWorksectionList(id);
|
|
||||||
},
|
|
||||||
immediate: true,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
methods: {
|
|
||||||
/** 模拟透传 ref */
|
|
||||||
validate(cb) {
|
|
||||||
return this.$refs.form.validate(cb);
|
|
||||||
},
|
|
||||||
resetFields(args) {
|
|
||||||
return this.$refs.form.resetFields(args);
|
|
||||||
},
|
|
||||||
async getProductionLineList() {
|
|
||||||
this.formLoading = true;
|
|
||||||
const res = await this.$axios({
|
|
||||||
url: '/base/production-line/listAll',
|
|
||||||
method: 'get',
|
|
||||||
});
|
|
||||||
if (res.code == 0) {
|
|
||||||
this.productionLineList = res.data.map((item) => ({
|
|
||||||
label: item.name,
|
|
||||||
value: item.id,
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
this.formLoading = false;
|
|
||||||
},
|
|
||||||
|
|
||||||
async getWorksectionList(id) {
|
|
||||||
this.formLoading = true;
|
|
||||||
const res = await this.$axios({
|
|
||||||
url: '/base/workshop-section/listByParentId',
|
|
||||||
method: 'get',
|
|
||||||
params: {
|
|
||||||
id,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
if (res.code == 0) {
|
|
||||||
this.workshopSectionList = res.data.map((item) => ({
|
|
||||||
label: item.name,
|
|
||||||
value: item.id,
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
this.formLoading = false;
|
|
||||||
},
|
|
||||||
|
|
||||||
async handleProductlineChange(id) {
|
|
||||||
await this.getWorksectionList(id);
|
|
||||||
this.dataForm.sectionId = null;
|
|
||||||
this.$emit('update', this.dataForm);
|
|
||||||
},
|
|
||||||
|
|
||||||
async getCode(url) {
|
|
||||||
const response = await this.$axios(url);
|
|
||||||
return response.data;
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style scoped lang="scss">
|
|
||||||
.el-date-editor,
|
|
||||||
.el-select {
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
</style>
|
|
@ -17,7 +17,6 @@
|
|||||||
v-if="tableBtn.length"
|
v-if="tableBtn.length"
|
||||||
slot="handleBtn"
|
slot="handleBtn"
|
||||||
label="操作"
|
label="操作"
|
||||||
:width="120"
|
|
||||||
fixed="right"
|
fixed="right"
|
||||||
:method-list="tableBtn"
|
:method-list="tableBtn"
|
||||||
@clickBtn="handleTableBtnClick" />
|
@clickBtn="handleTableBtnClick" />
|
||||||
@ -39,7 +38,7 @@
|
|||||||
@close="cancel"
|
@close="cancel"
|
||||||
@cancel="cancel"
|
@cancel="cancel"
|
||||||
@confirm="submitForm">
|
@confirm="submitForm">
|
||||||
<DialogForm v-if="open" ref="form" v-model="form" :rows="rows" />
|
<DialogForm v-if="open" ref="form" :dataForm="form" :rows="rows" />
|
||||||
</base-dialog>
|
</base-dialog>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
@ -55,12 +54,11 @@ import {
|
|||||||
} from '@/api/base/qualityInspectionBoxBtn';
|
} from '@/api/base/qualityInspectionBoxBtn';
|
||||||
import basicPageMixin from '@/mixins/lb/basicPageMixin';
|
import basicPageMixin from '@/mixins/lb/basicPageMixin';
|
||||||
import moment from 'moment';
|
import moment from 'moment';
|
||||||
import DialogForm from './dialogForm.vue';
|
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'QualityInspectionBoxBtn',
|
name: 'QualityInspectionBoxBtn',
|
||||||
mixins: [basicPageMixin],
|
mixins: [basicPageMixin],
|
||||||
components: { DialogForm },
|
components: {},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
rows: [
|
rows: [
|
||||||
@ -83,9 +81,6 @@ export default {
|
|||||||
url: '/base/workshop-section/listAll',
|
url: '/base/workshop-section/listAll',
|
||||||
prop: 'sectionId',
|
prop: 'sectionId',
|
||||||
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
||||||
bind: {
|
|
||||||
filterable: true,
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
@ -96,10 +91,9 @@ export default {
|
|||||||
rules: [
|
rules: [
|
||||||
{
|
{
|
||||||
type: 'number',
|
type: 'number',
|
||||||
message: '请输入整数',
|
message: '请输入数字',
|
||||||
trigger: 'blur',
|
trigger: 'blur',
|
||||||
transform: (val) =>
|
transform: (val) => Number(val),
|
||||||
Number.isInteger(Number(val)) && Number(val),
|
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
@ -113,10 +107,9 @@ export default {
|
|||||||
rules: [
|
rules: [
|
||||||
{
|
{
|
||||||
type: 'number',
|
type: 'number',
|
||||||
message: '请输入100以内的整数',
|
message: '请输入100以内的数字',
|
||||||
trigger: 'blur',
|
trigger: 'blur',
|
||||||
transform: (val) =>
|
transform: (val) => Number(val) <= 100 && Number(val),
|
||||||
Number(val) <= 100 && Number.isInteger(+val) && Number(val),
|
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
bind: { type: 'number', min: 0, max: 100 },
|
bind: { type: 'number', min: 0, max: 100 },
|
||||||
@ -127,7 +120,7 @@ export default {
|
|||||||
textarea: true,
|
textarea: true,
|
||||||
label: '检测内容',
|
label: '检测内容',
|
||||||
prop: 'inspectionDetContent',
|
prop: 'inspectionDetContent',
|
||||||
// rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
@ -180,36 +173,43 @@ export default {
|
|||||||
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
width: 128,
|
||||||
prop: 'productionName',
|
prop: 'productionName',
|
||||||
label: '产线',
|
label: '产线',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
width: 128,
|
||||||
prop: 'sectionName',
|
prop: 'sectionName',
|
||||||
label: '工段',
|
label: '工段',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
width: 128,
|
||||||
prop: 'inspectionDetContent',
|
prop: 'inspectionDetContent',
|
||||||
label: '检测内容',
|
label: '检测内容',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
width: 160,
|
width: 160,
|
||||||
prop: 'buttonId',
|
prop: 'buttonId',
|
||||||
label: '按钮盒识别码',
|
label: '按钮盒识别码',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
// {
|
// {
|
||||||
// width: 256,
|
// width: 256,
|
||||||
// prop: 'productionId',
|
// prop: 'productionId',
|
||||||
// label: '按钮盒所在产线ID',
|
// label: '按钮盒所在产线ID',
|
||||||
// ,
|
// align: 'center',
|
||||||
// },
|
// },
|
||||||
// {
|
// {
|
||||||
// width: 256,
|
// width: 256,
|
||||||
// prop: 'sectionId',
|
// prop: 'sectionId',
|
||||||
// label: '按钮盒所在工段ID',
|
// label: '按钮盒所在工段ID',
|
||||||
// ,
|
// align: 'center',
|
||||||
// },
|
// },
|
||||||
{ width: 90, prop: 'keyValue', label: '按钮值' },
|
{ width: 90, prop: 'keyValue', label: '按钮值', align: 'center' },
|
||||||
{ width: 128, prop: 'model', label: '按钮盒模式' },
|
{ width: 128, prop: 'model', label: '按钮盒模式', align: 'center' },
|
||||||
],
|
],
|
||||||
// 查询参数
|
// 查询参数
|
||||||
queryParams: {
|
queryParams: {
|
||||||
@ -220,13 +220,13 @@ export default {
|
|||||||
// 搜索框需要的 keys, 与上面 queryParams 的除 pageNo, pageSize 之外的 key 一一对应
|
// 搜索框需要的 keys, 与上面 queryParams 的除 pageNo, pageSize 之外的 key 一一对应
|
||||||
searchBarKeys: ['inspectionDetContent'],
|
searchBarKeys: ['inspectionDetContent'],
|
||||||
form: {
|
form: {
|
||||||
id: null,
|
id: undefined,
|
||||||
buttonId: null,
|
inspectionDetId: undefined,
|
||||||
inspectionDetContent: null,
|
inspectionDetContent: undefined,
|
||||||
productionId: null,
|
productionId: undefined,
|
||||||
sectionId: null,
|
sectionId: undefined,
|
||||||
model: null,
|
model: undefined,
|
||||||
keyValue: null,
|
keyValue: undefined,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
@ -247,13 +247,13 @@ export default {
|
|||||||
/** 表单重置 */
|
/** 表单重置 */
|
||||||
reset() {
|
reset() {
|
||||||
this.form = {
|
this.form = {
|
||||||
id: null,
|
id: undefined,
|
||||||
buttonId: null,
|
inspectionDetId: undefined,
|
||||||
inspectionDetContent: null,
|
inspectionDetContent: undefined,
|
||||||
productionId: null,
|
productionId: undefined,
|
||||||
sectionId: null,
|
sectionId: undefined,
|
||||||
model: null,
|
model: undefined,
|
||||||
keyValue: null,
|
keyValue: undefined,
|
||||||
};
|
};
|
||||||
this.resetForm('form');
|
this.resetForm('form');
|
||||||
},
|
},
|
||||||
@ -300,7 +300,7 @@ export default {
|
|||||||
handleDelete(row) {
|
handleDelete(row) {
|
||||||
const id = row.id;
|
const id = row.id;
|
||||||
this.$modal
|
this.$modal
|
||||||
.confirm('是否确认删除"' + row.sectionName + '"?')
|
.confirm('是否确认删除安灯按钮16键对应编号为"' + id + '"的数据项?')
|
||||||
.then(function () {
|
.then(function () {
|
||||||
return deleteQualityInspectionBoxBtn(id);
|
return deleteQualityInspectionBoxBtn(id);
|
||||||
})
|
})
|
||||||
|
@ -17,7 +17,6 @@
|
|||||||
v-if="tableBtn.length"
|
v-if="tableBtn.length"
|
||||||
slot="handleBtn"
|
slot="handleBtn"
|
||||||
label="操作"
|
label="操作"
|
||||||
:width="120"
|
|
||||||
fixed="right"
|
fixed="right"
|
||||||
:method-list="tableBtn"
|
:method-list="tableBtn"
|
||||||
@clickBtn="handleTableBtnClick" />
|
@clickBtn="handleTableBtnClick" />
|
||||||
@ -173,10 +172,10 @@ export default {
|
|||||||
width: 180,
|
width: 180,
|
||||||
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
||||||
},
|
},
|
||||||
{ prop: 'typeName', label: '类型名称', },
|
{ prop: 'typeName', label: '类型名称', align: 'center' },
|
||||||
{ prop: 'content', label: '检测内容', },
|
{ prop: 'content', label: '检测内容', align: 'center' },
|
||||||
{ prop: 'code', label: '检测编码', },
|
{ prop: 'code', label: '检测编码', align: 'center' },
|
||||||
{ prop: 'remark', label: '备注', },
|
{ prop: 'remark', label: '备注', align: 'center' },
|
||||||
],
|
],
|
||||||
// 查询参数
|
// 查询参数
|
||||||
queryParams: {
|
queryParams: {
|
||||||
@ -276,7 +275,7 @@ export default {
|
|||||||
handleDelete(row) {
|
handleDelete(row) {
|
||||||
const id = row.id;
|
const id = row.id;
|
||||||
this.$modal
|
this.$modal
|
||||||
.confirm('是否确认删除检测信息"' + row.content + '"?')
|
.confirm('是否确认删除质量检测信息基础编号为"' + id + '"的数据项?')
|
||||||
.then(function () {
|
.then(function () {
|
||||||
return deleteQualityInspectionDet(id);
|
return deleteQualityInspectionDet(id);
|
||||||
})
|
})
|
||||||
|
@ -17,7 +17,6 @@
|
|||||||
v-if="tableBtn.length"
|
v-if="tableBtn.length"
|
||||||
slot="handleBtn"
|
slot="handleBtn"
|
||||||
label="操作"
|
label="操作"
|
||||||
:width="120"
|
|
||||||
:method-list="tableBtn"
|
:method-list="tableBtn"
|
||||||
@clickBtn="handleTableBtnClick" />
|
@clickBtn="handleTableBtnClick" />
|
||||||
</base-table>
|
</base-table>
|
||||||
@ -107,9 +106,9 @@ export default {
|
|||||||
width: 180,
|
width: 180,
|
||||||
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
||||||
},
|
},
|
||||||
{ prop: 'name', label: '检测类型名称' },
|
{ prop: 'name', label: '检测类型名称', align: 'center' },
|
||||||
{ prop: 'code', label: '检测类型编码' },
|
{ prop: 'code', label: '检测类型编码', align: 'center' },
|
||||||
{ prop: 'remark', label: '备注' },
|
{ prop: 'remark', label: '备注', align: 'center' },
|
||||||
// {
|
// {
|
||||||
// label: '操作',
|
// label: '操作',
|
||||||
// alignt: 'center',
|
// alignt: 'center',
|
||||||
@ -322,7 +321,7 @@ export default {
|
|||||||
handleDelete(row) {
|
handleDelete(row) {
|
||||||
const id = row.id;
|
const id = row.id;
|
||||||
this.$modal
|
this.$modal
|
||||||
.confirm('是否确认删除该质量检测类型?')
|
.confirm('是否确认删除质量检测类型基础编号为"' + id + '"的数据项?')
|
||||||
.then(function () {
|
.then(function () {
|
||||||
return deleteQualityInspectionType(id);
|
return deleteQualityInspectionType(id);
|
||||||
})
|
})
|
||||||
|
@ -17,7 +17,6 @@
|
|||||||
v-if="tableBtn.length"
|
v-if="tableBtn.length"
|
||||||
slot="handleBtn"
|
slot="handleBtn"
|
||||||
label="操作"
|
label="操作"
|
||||||
:width="120"
|
|
||||||
fixed="right"
|
fixed="right"
|
||||||
:method-list="tableBtn"
|
:method-list="tableBtn"
|
||||||
@clickBtn="handleTableBtnClick" />
|
@clickBtn="handleTableBtnClick" />
|
||||||
@ -69,7 +68,7 @@ export default {
|
|||||||
[
|
[
|
||||||
{
|
{
|
||||||
select: true,
|
select: true,
|
||||||
label: '检测内容',
|
label: '检测内容ID',
|
||||||
url: '/base/quality-inspection-det/listAll',
|
url: '/base/quality-inspection-det/listAll',
|
||||||
prop: 'inspectionDetId',
|
prop: 'inspectionDetId',
|
||||||
labelKey: 'content',
|
labelKey: 'content',
|
||||||
@ -98,9 +97,6 @@ export default {
|
|||||||
label: '产线',
|
label: '产线',
|
||||||
url: '/base/production-line/listAll',
|
url: '/base/production-line/listAll',
|
||||||
prop: 'productionLineId',
|
prop: 'productionLineId',
|
||||||
bind: {
|
|
||||||
filterable: true,
|
|
||||||
},
|
|
||||||
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -109,9 +105,6 @@ export default {
|
|||||||
url: '/base/workshop-section/listAll', // 这个 url 其实可加可不加,因为下面会更新 options
|
url: '/base/workshop-section/listAll', // 这个 url 其实可加可不加,因为下面会更新 options
|
||||||
options: [], // 这个options也可加可不加, 因为下面会更新 options
|
options: [], // 这个options也可加可不加, 因为下面会更新 options
|
||||||
prop: 'sectionId',
|
prop: 'sectionId',
|
||||||
bind: {
|
|
||||||
filterable: true,
|
|
||||||
},
|
|
||||||
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
@ -125,7 +118,6 @@ export default {
|
|||||||
datetime: true,
|
datetime: true,
|
||||||
label: '检测时间',
|
label: '检测时间',
|
||||||
prop: 'checkTime',
|
prop: 'checkTime',
|
||||||
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
|
||||||
bind: {
|
bind: {
|
||||||
format: 'yyyy-MM-dd HH:mm:ss',
|
format: 'yyyy-MM-dd HH:mm:ss',
|
||||||
'value-format': 'timestamp',
|
'value-format': 'timestamp',
|
||||||
@ -134,15 +126,15 @@ export default {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
// [
|
[
|
||||||
// {
|
{
|
||||||
// textarea: true,
|
textarea: true,
|
||||||
// label: '检测内容',
|
label: '检测内容',
|
||||||
// prop: 'inspectionDetContent',
|
prop: 'inspectionDetContent',
|
||||||
// value: '',
|
value: '',
|
||||||
// rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
rules: [{ required: true, message: '不能为空', trigger: 'blur' }],
|
||||||
// },
|
},
|
||||||
// ],
|
],
|
||||||
[{ textarea: true, label: '描述', prop: 'explainText' }],
|
[{ textarea: true, label: '描述', prop: 'explainText' }],
|
||||||
[{ input: true, label: '备注', prop: 'remark' }],
|
[{ input: true, label: '备注', prop: 'remark' }],
|
||||||
],
|
],
|
||||||
@ -221,28 +213,32 @@ export default {
|
|||||||
width: 128,
|
width: 128,
|
||||||
prop: 'inspectionDetContent',
|
prop: 'inspectionDetContent',
|
||||||
label: '检测内容',
|
label: '检测内容',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
// width: 128,
|
// width: 128,
|
||||||
prop: 'lineName',
|
prop: 'lineName',
|
||||||
label: '产线',
|
label: '产线',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
// width: 128,
|
// width: 128,
|
||||||
prop: 'checkPerson',
|
prop: 'checkPerson',
|
||||||
label: '检测人员',
|
label: '检测人员',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
// width: 160,
|
// width: 160,
|
||||||
prop: 'checkTime',
|
prop: 'checkTime',
|
||||||
label: '检测时间',
|
label: '检测时间',
|
||||||
filter: (val) =>
|
align: 'center',
|
||||||
val != null ? moment(val).format('yyyy-MM-DD HH:mm:ss') : '-',
|
filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
width: 90,
|
width: 90,
|
||||||
prop: 'source',
|
prop: 'source',
|
||||||
label: '来源',
|
label: '来源',
|
||||||
|
align: 'center',
|
||||||
filter: (val) => ['未知', '手动', '自动'][val],
|
filter: (val) => ['未知', '手动', '自动'][val],
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
@ -398,7 +394,7 @@ export default {
|
|||||||
handleDelete(row) {
|
handleDelete(row) {
|
||||||
const id = row.id;
|
const id = row.id;
|
||||||
this.$modal
|
this.$modal
|
||||||
.confirm('是否确认删除"' + row.inspectionDetContent + '"?')
|
.confirm('是否确认删除质量检查信息记录表编号为"' + id + '"的数据项?')
|
||||||
.then(function () {
|
.then(function () {
|
||||||
return deleteQualityInspectionRecord(id);
|
return deleteQualityInspectionRecord(id);
|
||||||
})
|
})
|
||||||
|
@ -13,20 +13,18 @@
|
|||||||
<!-- <pre><code v-html="jsondemo"></code></pre> -->
|
<!-- <pre><code v-html="jsondemo"></code></pre> -->
|
||||||
|
|
||||||
<el-skeleton v-if="initing" :rows="6" animated />
|
<el-skeleton v-if="initing" :rows="6" animated />
|
||||||
<div v-else :class="{ 'no-data-bg': !list || list.length == 0 }">
|
|
||||||
<base-table
|
<base-table
|
||||||
v-if="list && list.length > 0"
|
v-else
|
||||||
:table-props="tableProps"
|
:table-props="tableProps"
|
||||||
:page="queryParams.pageNo"
|
:page="queryParams.pageNo"
|
||||||
:limit="queryParams.pageSize"
|
:limit="queryParams.pageSize"
|
||||||
:table-data="list"
|
:table-data="list"
|
||||||
@emitFun="handleEmitFun"></base-table>
|
@emitFun="handleEmitFun"></base-table>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
// import response from './response.json';
|
import response from './response.json';
|
||||||
import { handleNameData, handleDynamicData } from '@/utils/dynamicProps';
|
import { handleNameData, handleDynamicData } from '@/utils/dynamicProps';
|
||||||
// import hljs from 'highlight.js/lib/highlight';
|
// import hljs from 'highlight.js/lib/highlight';
|
||||||
// import json from 'highlight.js/lib/languages/json';
|
// import json from 'highlight.js/lib/languages/json';
|
||||||
@ -45,6 +43,7 @@ export default {
|
|||||||
pageNo: 1,
|
pageNo: 1,
|
||||||
pageSize: 10,
|
pageSize: 10,
|
||||||
},
|
},
|
||||||
|
// jsondemo: '',
|
||||||
list: [
|
list: [
|
||||||
// {
|
// {
|
||||||
// inspectionContent: '检测内容1',
|
// inspectionContent: '检测内容1',
|
||||||
@ -57,6 +56,7 @@ export default {
|
|||||||
{
|
{
|
||||||
prop: 'inspectionContent',
|
prop: 'inspectionContent',
|
||||||
label: '检测内容',
|
label: '检测内容',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
};
|
};
|
||||||
@ -67,10 +67,20 @@ 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);
|
||||||
|
// const {
|
||||||
|
// // data: { nameData },
|
||||||
|
// code,
|
||||||
|
// } = response;
|
||||||
|
// this.jsondemo = hljs.highlight(
|
||||||
|
// 'json',
|
||||||
|
// JSON.stringify(response, null, 2),
|
||||||
|
// true
|
||||||
|
// ).value;
|
||||||
const {
|
const {
|
||||||
data: { data: dyanmicData, nameData },
|
data: { data: dyanmicData, nameData },
|
||||||
} = response;
|
} = response;
|
||||||
|
@ -82,22 +82,18 @@ export default {
|
|||||||
computed: {
|
computed: {
|
||||||
config() {
|
config() {
|
||||||
return {
|
return {
|
||||||
color: ['#fde19a', '#8be2b9', '#288aff', '#7164ff'],
|
|
||||||
// title: {
|
// title: {
|
||||||
// text: '折线图',
|
// text: '折线图',
|
||||||
// },
|
// },
|
||||||
grid: {
|
grid: {
|
||||||
top: '12%',
|
top: '24%',
|
||||||
left: '2%',
|
left: '3%',
|
||||||
right: '5%',
|
right: '5%',
|
||||||
bottom: '5%',
|
bottom: '5%',
|
||||||
containLabel: true,
|
containLabel: true,
|
||||||
},
|
},
|
||||||
tooltip: {
|
tooltip: {
|
||||||
trigger: 'axis',
|
trigger: 'axis',
|
||||||
axisPointer: {
|
|
||||||
type: 'shadow',
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
legend: {
|
legend: {
|
||||||
data: this.legend,
|
data: this.legend,
|
||||||
@ -111,145 +107,13 @@ export default {
|
|||||||
// },
|
// },
|
||||||
xAxis: {
|
xAxis: {
|
||||||
type: 'category',
|
type: 'category',
|
||||||
boundaryGap: true,
|
boundaryGap: false,
|
||||||
onZero: false,
|
|
||||||
axisTick: {
|
|
||||||
show: false,
|
|
||||||
},
|
|
||||||
axisLine: {
|
|
||||||
lineStyle: {
|
|
||||||
// color: 'red'
|
|
||||||
},
|
|
||||||
},
|
|
||||||
data: this.xProps,
|
data: this.xProps,
|
||||||
// data: [
|
|
||||||
// '设备1',
|
|
||||||
// '设备2',
|
|
||||||
// '设备3',
|
|
||||||
// '设备4',
|
|
||||||
// '设备5',
|
|
||||||
// '设备6',
|
|
||||||
// '设备7',
|
|
||||||
// '设备8',
|
|
||||||
// '设备9',
|
|
||||||
// '设备10',
|
|
||||||
// '设备11',
|
|
||||||
// '设备12',
|
|
||||||
// '设备13',
|
|
||||||
// '设备14',
|
|
||||||
// '设备15',
|
|
||||||
// '设备16',
|
|
||||||
// '设备17',
|
|
||||||
// '设备18',
|
|
||||||
// '设备19',
|
|
||||||
// '设备20',
|
|
||||||
// ],
|
|
||||||
},
|
},
|
||||||
yAxis: {
|
yAxis: {
|
||||||
type: 'value',
|
type: 'value',
|
||||||
name: '单位/片',
|
|
||||||
nameTextStyle: {
|
|
||||||
color: '#999',
|
|
||||||
fontSize: 14,
|
|
||||||
align: 'right',
|
|
||||||
},
|
|
||||||
max: function (value) {
|
|
||||||
return value.max + Math.floor(value.max / 5);
|
|
||||||
},
|
|
||||||
},
|
|
||||||
// 缩放 - 滑动
|
|
||||||
dataZoom: {
|
|
||||||
type: 'inside',
|
|
||||||
},
|
},
|
||||||
series: this.series,
|
series: this.series,
|
||||||
// series: [
|
|
||||||
// {
|
|
||||||
// name: '上片数',
|
|
||||||
// type: 'bar',
|
|
||||||
// // barWidth: 12,
|
|
||||||
// data: [
|
|
||||||
// 10,
|
|
||||||
// 12,
|
|
||||||
// 43,
|
|
||||||
// 4,
|
|
||||||
// 22,
|
|
||||||
// 32,
|
|
||||||
// 12,
|
|
||||||
// 8,
|
|
||||||
// 122,
|
|
||||||
// 0,
|
|
||||||
// ,
|
|
||||||
// 43,
|
|
||||||
// 4,
|
|
||||||
// 22,
|
|
||||||
// 32,
|
|
||||||
// 12,
|
|
||||||
// 8,
|
|
||||||
// 122,
|
|
||||||
// 77,
|
|
||||||
// 99,
|
|
||||||
// ],
|
|
||||||
// },
|
|
||||||
// {
|
|
||||||
// name: '下片数',
|
|
||||||
// type: 'bar',
|
|
||||||
// // barWidth: 12,
|
|
||||||
// data: [
|
|
||||||
// 10,
|
|
||||||
// 12,
|
|
||||||
// 43,
|
|
||||||
// 4,
|
|
||||||
// 22,
|
|
||||||
// 32,
|
|
||||||
// 12,
|
|
||||||
// 8,
|
|
||||||
// 122,
|
|
||||||
// 0,
|
|
||||||
// 4,
|
|
||||||
// 22,
|
|
||||||
// 32,
|
|
||||||
// 12,
|
|
||||||
// 8,
|
|
||||||
// 122,
|
|
||||||
// 0,
|
|
||||||
// ,
|
|
||||||
// 43,
|
|
||||||
// 4,
|
|
||||||
// 22,
|
|
||||||
// 32,
|
|
||||||
// ],
|
|
||||||
// },
|
|
||||||
// {
|
|
||||||
// name: '检测数',
|
|
||||||
// type: 'bar',
|
|
||||||
// // barWidth: 12,
|
|
||||||
// barCategoryGap: 12,
|
|
||||||
// data: [
|
|
||||||
// 10,
|
|
||||||
// 12,
|
|
||||||
// 43,
|
|
||||||
// 4,
|
|
||||||
// 22,
|
|
||||||
// 4,
|
|
||||||
// 22,
|
|
||||||
// 32,
|
|
||||||
// 12,
|
|
||||||
// 8,
|
|
||||||
// 122,
|
|
||||||
// 0,
|
|
||||||
// ,
|
|
||||||
// 43,
|
|
||||||
// 4,
|
|
||||||
// 22,
|
|
||||||
// 32,
|
|
||||||
// 32,
|
|
||||||
// 12,
|
|
||||||
// 8,
|
|
||||||
// 122,
|
|
||||||
// 0,
|
|
||||||
// ],
|
|
||||||
// },
|
|
||||||
// ],
|
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -7,9 +7,9 @@
|
|||||||
|
|
||||||
<template>
|
<template>
|
||||||
<!-- 列表 -->
|
<!-- 列表 -->
|
||||||
<!-- height="35vh" -->
|
|
||||||
<base-table
|
<base-table
|
||||||
:table-props="tableProps"
|
:table-props="tableProps"
|
||||||
|
height="35vh"
|
||||||
:page="queryParams.pageNo"
|
:page="queryParams.pageNo"
|
||||||
:limit="queryParams.pageSize"
|
:limit="queryParams.pageSize"
|
||||||
:table-data="list"></base-table>
|
:table-data="list"></base-table>
|
||||||
@ -35,22 +35,27 @@ export default {
|
|||||||
{
|
{
|
||||||
prop: 'lineName',
|
prop: 'lineName',
|
||||||
label: '产线',
|
label: '产线',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
prop: 'sumUp',
|
prop: 'sumUp',
|
||||||
label: '上片总数',
|
label: '上片总数',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
prop: 'sumDown',
|
prop: 'sumDown',
|
||||||
label: '下片总数',
|
label: '下片总数',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
prop: 'sumCheck',
|
prop: 'sumCheck',
|
||||||
label: '检测总数',
|
label: '检测总数',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
prop: 'scrapRatio',
|
prop: 'scrapRatio',
|
||||||
label: '比例(%)',
|
label: '比例(%)',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
};
|
};
|
||||||
|
@ -7,20 +7,14 @@
|
|||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div class="graph-page">
|
<div class="graph-page">
|
||||||
<!-- <DetailGraph id="dg1" key="dg1" ref="dg1" title="数据总览">
|
<DetailGraph id="dg1" key="dg1" ref="dg1" title="数据总览">
|
||||||
<TotalGraph :summary-list="summaryList" />
|
<TotalGraph :summary-list="summaryList" />
|
||||||
</DetailGraph> -->
|
</DetailGraph>
|
||||||
<!-- <DetailGraph id="dg2" key="dg2" ref="dg2" title="检测内容数据">
|
<DetailGraph id="dg2" key="dg2" ref="dg2" title="检测内容数据">
|
||||||
<LineGraph :x-props="lineData.xProps" :legend="legend" :series="series" />
|
<LineGraph :x-props="lineData.xProps" :legend="legend" :series="series" />
|
||||||
</DetailGraph> -->
|
</DetailGraph>
|
||||||
<!-- <DetailGraph id="dg3" key="dg3" ref="dg3" />
|
<!-- <DetailGraph id="dg3" key="dg3" ref="dg3" />
|
||||||
<DetailGraph id="dg4" key="dg4" ref="dg4" /> -->
|
<DetailGraph id="dg4" key="dg4" ref="dg4" /> -->
|
||||||
<div v-if="!series || series.length == 0" style="color: #777; font-size: 16px; letter-spacing: 1px; text-align: center; padding-top: 56px; text-decoration: underline;">暂无数据</div>
|
|
||||||
<LineGraph
|
|
||||||
v-else
|
|
||||||
:x-props="lineData.xProps"
|
|
||||||
:legend="legend"
|
|
||||||
:series="series" />
|
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
@ -61,8 +55,7 @@ export default {
|
|||||||
console.log('this.list', this.lineData.list, this.lineData.xProps);
|
console.log('this.list', this.lineData.list, this.lineData.xProps);
|
||||||
const seriesItem = {
|
const seriesItem = {
|
||||||
name: item.inspectionContent,
|
name: item.inspectionContent,
|
||||||
type: 'bar',
|
type: 'line',
|
||||||
barCategoryGap: 12,
|
|
||||||
data: [],
|
data: [],
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -6,63 +6,16 @@
|
|||||||
-->
|
-->
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div class="quality-container" style="background: #f2f4f9; flex: 1">
|
<div class="app-container">
|
||||||
<el-row
|
|
||||||
class=""
|
|
||||||
style="
|
|
||||||
margin-bottom: 12px;
|
|
||||||
background: #fff;
|
|
||||||
padding: 16px 16px 0;
|
|
||||||
border-radius: 8px;
|
|
||||||
">
|
|
||||||
<!-- 搜索工作栏 -->
|
<!-- 搜索工作栏 -->
|
||||||
<SearchBar
|
<SearchBar
|
||||||
:formConfigs="searchBarFormConfig"
|
:formConfigs="searchBarFormConfig"
|
||||||
ref="search-bar"
|
ref="search-bar"
|
||||||
@headBtnClick="handleSearchBarBtnClick" />
|
@headBtnClick="handleSearchBarBtnClick" />
|
||||||
</el-row>
|
|
||||||
|
|
||||||
<el-row
|
|
||||||
class=""
|
|
||||||
style="
|
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: 12px;
|
|
||||||
background: #fff;
|
|
||||||
padding: 12px 16px 16px;
|
|
||||||
border-radius: 8px;
|
|
||||||
">
|
|
||||||
<div class="blue-title">产线检测总览</div>
|
|
||||||
<summaryTable :list="summaryList" />
|
|
||||||
</el-row>
|
|
||||||
|
|
||||||
<el-row
|
|
||||||
class=""
|
|
||||||
style="
|
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: 12px;
|
|
||||||
background: #fff;
|
|
||||||
padding: 12px 16px 16px;
|
|
||||||
border-radius: 8px;
|
|
||||||
">
|
|
||||||
<el-row style="display: flex; align-items: center">
|
|
||||||
<div class="blue-title">产线检测详细</div>
|
|
||||||
<div class="custom-tabs">
|
|
||||||
<el-tabs
|
|
||||||
v-model="activeName"
|
|
||||||
:stretch="true"
|
|
||||||
@tab-click="handleTabClick">
|
|
||||||
<el-tab-pane
|
|
||||||
:label="'\u2002数据列表\u2002'"
|
|
||||||
name="table"></el-tab-pane>
|
|
||||||
<el-tab-pane
|
|
||||||
:label="'\u3000柱状图\u3000'"
|
|
||||||
name="graph"></el-tab-pane>
|
|
||||||
</el-tabs>
|
|
||||||
</div>
|
|
||||||
</el-row>
|
|
||||||
|
|
||||||
<transition mode="out-in" name="fade-down">
|
<transition mode="out-in" name="fade-down">
|
||||||
<template v-if="mode == 'table'">
|
<template v-if="mode == 'table'">
|
||||||
|
<!-- 列表 -->
|
||||||
<base-table
|
<base-table
|
||||||
v-if="mode == 'table'"
|
v-if="mode == 'table'"
|
||||||
:table-props="tableProps"
|
:table-props="tableProps"
|
||||||
@ -75,15 +28,11 @@
|
|||||||
<GraphPage
|
<GraphPage
|
||||||
v-else
|
v-else
|
||||||
:summary-list="summaryList"
|
:summary-list="summaryList"
|
||||||
:line-data="{
|
:line-data="{ list: list, xProps: dynamicProps.map((v) => v.prop) }" />
|
||||||
list: list,
|
|
||||||
xProps: dynamicProps.map((v) => v.prop),
|
|
||||||
}" />
|
|
||||||
</transition>
|
</transition>
|
||||||
</el-row>
|
|
||||||
|
|
||||||
<!-- todo: 数据总览,用弹窗包裹的 table 实现 -->
|
<!-- todo: 数据总览,用弹窗包裹的 table 实现 -->
|
||||||
<!-- <base-dialog
|
<base-dialog
|
||||||
dialogTitle="数据总览"
|
dialogTitle="数据总览"
|
||||||
:dialogVisible="summaryOpen"
|
:dialogVisible="summaryOpen"
|
||||||
width="50%"
|
width="50%"
|
||||||
@ -91,7 +40,7 @@
|
|||||||
@cancel="handleSummaryClose"
|
@cancel="handleSummaryClose"
|
||||||
@confirm="handleSummaryClose">
|
@confirm="handleSummaryClose">
|
||||||
<summaryTable :list="summaryList" />
|
<summaryTable :list="summaryList" />
|
||||||
</base-dialog> -->
|
</base-dialog>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
@ -99,58 +48,13 @@
|
|||||||
import GraphPage from './graphPage.vue';
|
import GraphPage from './graphPage.vue';
|
||||||
import summaryTable from './components/summaryTable.vue';
|
import summaryTable from './components/summaryTable.vue';
|
||||||
|
|
||||||
class DateGetter {
|
|
||||||
constructor() {
|
|
||||||
this.today = new Date();
|
|
||||||
this.y = this.today.getFullYear();
|
|
||||||
this.m = this.today.getMonth();
|
|
||||||
this.d = this.today.getDate();
|
|
||||||
}
|
|
||||||
getWeekRange() {
|
|
||||||
const weekStart = new Date(this.y, this.m, this.d - this.today.getDay());
|
|
||||||
const weekEnd = new Date(
|
|
||||||
this.y,
|
|
||||||
this.m,
|
|
||||||
this.d + (6 - this.today.getDay()),
|
|
||||||
23,
|
|
||||||
59,
|
|
||||||
59
|
|
||||||
);
|
|
||||||
// console.log('week', [weekStart, weekEnd]);
|
|
||||||
return [weekStart, weekEnd];
|
|
||||||
}
|
|
||||||
|
|
||||||
getMonthRange() {
|
|
||||||
const monthStart = new Date(this.y, this.m, 1);
|
|
||||||
const monthEnd = new Date(this.y, this.m + 1, 0, 23, 59, 59);
|
|
||||||
// console.log('month', [monthStart, monthEnd]);
|
|
||||||
return [monthStart, monthEnd];
|
|
||||||
}
|
|
||||||
|
|
||||||
getQuarterRange() {
|
|
||||||
const quarterStart = new Date(this.y, this.m - (this.m % 3), 1);
|
|
||||||
const quarterEnd = new Date(
|
|
||||||
this.y,
|
|
||||||
this.m - (this.m % 3) + 3,
|
|
||||||
0,
|
|
||||||
23,
|
|
||||||
59,
|
|
||||||
59
|
|
||||||
);
|
|
||||||
// console.log('quarter', [quarterStart, quarterEnd]);
|
|
||||||
return [quarterStart, quarterEnd];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'QualityStatistics',
|
name: 'QualityStatistics',
|
||||||
components: { GraphPage, summaryTable },
|
components: { GraphPage, summaryTable },
|
||||||
props: {},
|
props: {},
|
||||||
data() {
|
data() {
|
||||||
const dateGetter = new DateGetter();
|
|
||||||
return {
|
return {
|
||||||
// mode: 'table', // defaults to 'table'
|
mode: 'table', // defaults to 'table'
|
||||||
activeName: 'table', // defaults to 'table'
|
|
||||||
searchBarFormConfig: [
|
searchBarFormConfig: [
|
||||||
{
|
{
|
||||||
type: 'datePicker',
|
type: 'datePicker',
|
||||||
@ -166,28 +70,6 @@ export default {
|
|||||||
defaultSelect: [],
|
defaultSelect: [],
|
||||||
defaultTime: ['00:00:00', '23:59:59'],
|
defaultTime: ['00:00:00', '23:59:59'],
|
||||||
param: 'timerange',
|
param: 'timerange',
|
||||||
pickerOptions: {
|
|
||||||
shortcuts: [
|
|
||||||
{
|
|
||||||
text: '本周',
|
|
||||||
onClick(picker) {
|
|
||||||
picker.$emit('pick', dateGetter.getWeekRange());
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
text: '本月',
|
|
||||||
onClick(picker) {
|
|
||||||
picker.$emit('pick', dateGetter.getMonthRange());
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
text: '本季',
|
|
||||||
onClick(picker) {
|
|
||||||
picker.$emit('pick', dateGetter.getQuarterRange());
|
|
||||||
},
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
type: 'button',
|
type: 'button',
|
||||||
@ -195,33 +77,33 @@ export default {
|
|||||||
name: 'search',
|
name: 'search',
|
||||||
color: 'primary',
|
color: 'primary',
|
||||||
},
|
},
|
||||||
// {
|
{
|
||||||
// type: 'separate',
|
type: 'separate',
|
||||||
// },
|
},
|
||||||
// {
|
{
|
||||||
// type: 'button',
|
type: 'button',
|
||||||
// btnName: '数据总览',
|
btnName: '数据总览',
|
||||||
// name: 'summary',
|
name: 'summary',
|
||||||
// color: 'text',
|
color: 'text',
|
||||||
// },
|
},
|
||||||
// {
|
{
|
||||||
// type: 'separate',
|
type: 'separate',
|
||||||
// },
|
},
|
||||||
// {
|
{
|
||||||
// type: 'button',
|
type: 'button',
|
||||||
// btnName: '表格版',
|
btnName: '表格版',
|
||||||
// name: 'tableVersion',
|
name: 'tableVersion',
|
||||||
// color: 'text btn-table',
|
color: 'text btn-table',
|
||||||
// },
|
},
|
||||||
// {
|
{
|
||||||
// type: 'separate',
|
type: 'separate',
|
||||||
// },
|
},
|
||||||
// {
|
{
|
||||||
// type: 'button',
|
type: 'button',
|
||||||
// btnName: '图形版',
|
btnName: '图形版',
|
||||||
// name: 'graphVersion',
|
name: 'graphVersion',
|
||||||
// color: 'text btn-graph',
|
color: 'text btn-graph',
|
||||||
// },
|
},
|
||||||
],
|
],
|
||||||
// 动态的 props
|
// 动态的 props
|
||||||
dynamicProps: [],
|
dynamicProps: [],
|
||||||
@ -284,26 +166,26 @@ export default {
|
|||||||
};
|
};
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
mode() {
|
|
||||||
return this.activeName;
|
|
||||||
},
|
|
||||||
tableProps() {
|
tableProps() {
|
||||||
return [
|
return [
|
||||||
{
|
{
|
||||||
// width: 160,
|
// width: 160,
|
||||||
prop: 'inspectionContent',
|
prop: 'inspectionContent',
|
||||||
label: '检测内容',
|
label: '检测内容',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
...this.dynamicProps,
|
...this.dynamicProps,
|
||||||
{
|
{
|
||||||
// width: 128,
|
// width: 128,
|
||||||
prop: 'sumInput',
|
prop: 'sumInput',
|
||||||
label: '检测类型总数',
|
label: '检测类型总数',
|
||||||
|
align: 'center',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
// width: 128,
|
// width: 128,
|
||||||
prop: 'ratio',
|
prop: 'ratio',
|
||||||
label: '比例',
|
label: '比例',
|
||||||
|
align: 'center',
|
||||||
// subcomponent: {
|
// subcomponent: {
|
||||||
// name: 'TextOnly',
|
// name: 'TextOnly',
|
||||||
// props: {
|
// props: {
|
||||||
@ -332,47 +214,29 @@ export default {
|
|||||||
},
|
},
|
||||||
mounted() {
|
mounted() {
|
||||||
if (this.$route.params.startTime && this.$route.params.endTime) {
|
if (this.$route.params.startTime && this.$route.params.endTime) {
|
||||||
this.searchBarFormConfig[0].defaultSelect = [
|
this.searchBarFormConfig[0].defaultSelect = [this.$route.params.startTime, this.$route.params.endTime]
|
||||||
this.$route.params.startTime,
|
|
||||||
this.$route.params.endTime,
|
|
||||||
];
|
|
||||||
this.queryParams.param = {};
|
this.queryParams.param = {};
|
||||||
this.$set(
|
this.$set(this.queryParams.param, 'startTime', this.$route.params.startTime);
|
||||||
this.queryParams.param,
|
|
||||||
'startTime',
|
|
||||||
this.$route.params.startTime
|
|
||||||
);
|
|
||||||
this.$set(this.queryParams.param, 'endTime', this.$route.params.endTime);
|
this.$set(this.queryParams.param, 'endTime', this.$route.params.endTime);
|
||||||
} else {
|
} else {
|
||||||
this.searchBarFormConfig[0].defaultSelect = [];
|
this.searchBarFormConfig[0].defaultSelect = []
|
||||||
}
|
}
|
||||||
this.getList();
|
this.getList();
|
||||||
},
|
},
|
||||||
watch: {
|
watch: {
|
||||||
$route: 'initData',
|
$route: 'initData'
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
initData(to) {
|
initData(to) {
|
||||||
// console.log(to)
|
// console.log(to)
|
||||||
if (to.name === 'QualityStatistics') {
|
if (to.name === 'QualityStatistics') {
|
||||||
if (this.$route.params.startTime && this.$route.params.endTime) {
|
if (this.$route.params.startTime && this.$route.params.endTime) {
|
||||||
this.searchBarFormConfig[0].defaultSelect = [
|
this.searchBarFormConfig[0].defaultSelect = [this.$route.params.startTime, this.$route.params.endTime]
|
||||||
this.$route.params.startTime,
|
|
||||||
this.$route.params.endTime,
|
|
||||||
];
|
|
||||||
this.queryParams.param = {};
|
this.queryParams.param = {};
|
||||||
this.$set(
|
this.$set(this.queryParams.param, 'startTime', this.$route.params.startTime);
|
||||||
this.queryParams.param,
|
this.$set(this.queryParams.param, 'endTime', this.$route.params.endTime);
|
||||||
'startTime',
|
|
||||||
this.$route.params.startTime
|
|
||||||
);
|
|
||||||
this.$set(
|
|
||||||
this.queryParams.param,
|
|
||||||
'endTime',
|
|
||||||
this.$route.params.endTime
|
|
||||||
);
|
|
||||||
} else {
|
} else {
|
||||||
this.searchBarFormConfig[0].defaultSelect = [];
|
this.searchBarFormConfig[0].defaultSelect = []
|
||||||
}
|
}
|
||||||
this.getList();
|
this.getList();
|
||||||
}
|
}
|
||||||
@ -385,17 +249,20 @@ export default {
|
|||||||
async getSummaryList() {
|
async getSummaryList() {
|
||||||
const response = await this.$axios({
|
const response = await this.$axios({
|
||||||
url: '/monitoring/statistical-data/getUpPart',
|
url: '/monitoring/statistical-data/getUpPart',
|
||||||
method: 'post',
|
method: 'get',
|
||||||
data: this.queryParams.param
|
params: this.queryParams.param
|
||||||
? {
|
? {
|
||||||
|
param: {
|
||||||
// startTime: new Date(2022, 6, 1, 0, 0, 0).getTime(), // '2023-07-01 00:00:00',
|
// startTime: new Date(2022, 6, 1, 0, 0, 0).getTime(), // '2023-07-01 00:00:00',
|
||||||
// endTime: new Date(2023, 7, 10, 0, 0, 0).getTime(), // '2023-08-10 00:00:00',
|
// endTime: new Date(2023, 7, 10, 0, 0, 0).getTime(), // '2023-08-10 00:00:00',
|
||||||
startTime: this.queryParams.param.startTime,
|
startTime: this.queryParams.param.startTime,
|
||||||
endTime: this.queryParams.param.endTime,
|
endTime: this.queryParams.param.endTime,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
: {},
|
: null,
|
||||||
});
|
});
|
||||||
this.summaryList = response.data;
|
this.summaryList = response.data;
|
||||||
|
console.log('summaryList', this.summaryList);
|
||||||
},
|
},
|
||||||
/** 获取 检测内容和产线关联 列表 */
|
/** 获取 检测内容和产线关联 列表 */
|
||||||
async getDetailedList() {
|
async getDetailedList() {
|
||||||
@ -403,21 +270,22 @@ export default {
|
|||||||
data: { data, otherList, otherMap, nameData },
|
data: { data, otherList, otherMap, nameData },
|
||||||
} = await this.$axios({
|
} = await this.$axios({
|
||||||
url: '/monitoring/statistical-data/getDownPart',
|
url: '/monitoring/statistical-data/getDownPart',
|
||||||
method: 'post',
|
params: this.queryParams.param
|
||||||
data: this.queryParams.param
|
|
||||||
? {
|
? {
|
||||||
|
param: {
|
||||||
// startTime: new Date(2023, 6, 1).getTime(), // '2023-07-01 00:00:00',
|
// startTime: new Date(2023, 6, 1).getTime(), // '2023-07-01 00:00:00',
|
||||||
// endTime: new Date(2023, 7, 22).getTime(), // '2023-08-10 00:00:00',
|
// endTime: new Date(2023, 7, 22).getTime(), // '2023-08-10 00:00:00',
|
||||||
startTime: this.queryParams.param.startTime,
|
startTime: this.queryParams.param.startTime,
|
||||||
endTime: this.queryParams.param.endTime,
|
endTime: this.queryParams.param.endTime,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
: {},
|
: null,
|
||||||
});
|
});
|
||||||
// this.list = response.data;
|
// this.list = response.data;
|
||||||
// console.log('data', data);
|
console.log('data', data);
|
||||||
// console.log('otherList', otherList);
|
console.log('otherList', otherList);
|
||||||
// console.log('otherMap', otherMap);
|
console.log('otherMap', otherMap);
|
||||||
// console.log('nameData', nameData);
|
console.log('nameData', nameData);
|
||||||
|
|
||||||
this.dynamicProps = this.filterNameData(nameData);
|
this.dynamicProps = this.filterNameData(nameData);
|
||||||
this.list = this.filterData(data);
|
this.list = this.filterData(data);
|
||||||
@ -448,14 +316,6 @@ export default {
|
|||||||
};
|
};
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
handleTabClick(tab, event) {
|
|
||||||
const { name } = tab;
|
|
||||||
if (name == 'graph') {
|
|
||||||
// 展示柱状图
|
|
||||||
} else {
|
|
||||||
// 展示表格
|
|
||||||
}
|
|
||||||
},
|
|
||||||
/** 总览关闭 */
|
/** 总览关闭 */
|
||||||
handleSummaryClose() {
|
handleSummaryClose() {
|
||||||
this.summaryOpen = false;
|
this.summaryOpen = false;
|
||||||
@ -540,42 +400,6 @@ export default {
|
|||||||
.fade-down-leave {
|
.fade-down-leave {
|
||||||
transform: translateY(0);
|
transform: translateY(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
.blue-title {
|
|
||||||
position: relative;
|
|
||||||
padding: 4px 0;
|
|
||||||
padding-left: 12px;
|
|
||||||
font-size: 14px;
|
|
||||||
color: #606266;
|
|
||||||
font-weight: 700;
|
|
||||||
margin-bottom: 12px;
|
|
||||||
|
|
||||||
&::before {
|
|
||||||
content: '';
|
|
||||||
position: absolute;
|
|
||||||
left: 0;
|
|
||||||
top: 6px;
|
|
||||||
height: 16px;
|
|
||||||
width: 4px;
|
|
||||||
border-radius: 1px;
|
|
||||||
background: #0b58ff;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
:deep(.custom-tabs) {
|
|
||||||
.el-tabs__header {
|
|
||||||
margin-left: 12px;
|
|
||||||
margin-bottom: 8px;
|
|
||||||
display: inline-block;
|
|
||||||
transform: translateY(-6px);
|
|
||||||
}
|
|
||||||
|
|
||||||
.el-tabs__item {
|
|
||||||
padding-left: 0 !important;
|
|
||||||
padding-right: 0 !important;
|
|
||||||
height: 36px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
@ -583,47 +407,47 @@ export default {
|
|||||||
// width: 128,
|
// width: 128,
|
||||||
// prop: 'line1',
|
// prop: 'line1',
|
||||||
// label: '产线1',
|
// label: '产线1',
|
||||||
// ,
|
// align: 'center',
|
||||||
// },
|
// },
|
||||||
// {
|
// {
|
||||||
// width: 128,
|
// width: 128,
|
||||||
// prop: 'line2',
|
// prop: 'line2',
|
||||||
// label: '产线2',
|
// label: '产线2',
|
||||||
// ,
|
// align: 'center',
|
||||||
// },
|
// },
|
||||||
// {
|
// {
|
||||||
// width: 128,
|
// width: 128,
|
||||||
// prop: 'line3',
|
// prop: 'line3',
|
||||||
// label: '产线3',
|
// label: '产线3',
|
||||||
// ,
|
// align: 'center',
|
||||||
// },
|
// },
|
||||||
// {
|
// {
|
||||||
// width: 128,
|
// width: 128,
|
||||||
// prop: 'line4',
|
// prop: 'line4',
|
||||||
// label: '产线4',
|
// label: '产线4',
|
||||||
// ,
|
// align: 'center',
|
||||||
// },
|
// },
|
||||||
// {
|
// {
|
||||||
// width: 128,
|
// width: 128,
|
||||||
// prop: 'line5',
|
// prop: 'line5',
|
||||||
// label: '产线5',
|
// label: '产线5',
|
||||||
// ,
|
// align: 'center',
|
||||||
// },
|
// },
|
||||||
// {
|
// {
|
||||||
// width: 128,
|
// width: 128,
|
||||||
// prop: 'line6',
|
// prop: 'line6',
|
||||||
// label: '产线6',
|
// label: '产线6',
|
||||||
// ,
|
// align: 'center',
|
||||||
// },
|
// },
|
||||||
// {
|
// {
|
||||||
// width: 128,
|
// width: 128,
|
||||||
// prop: 'line7',
|
// prop: 'line7',
|
||||||
// label: '产线7',
|
// label: '产线7',
|
||||||
// ,
|
// align: 'center',
|
||||||
// },
|
// },
|
||||||
// {
|
// {
|
||||||
// width: 128,
|
// width: 128,
|
||||||
// prop: 'line8',
|
// prop: 'line8',
|
||||||
// label: '产线8',
|
// label: '产线8',
|
||||||
// ,
|
// align: 'center',
|
||||||
// }, -->
|
// }, -->
|
||||||
|
Loading…
Reference in New Issue
Block a user