Merge branch 'test' into dy
This commit is contained in:
commit
ee0affc78f
4
.env.dev
4
.env.dev
@ -14,8 +14,8 @@ VUE_APP_TITLE = 芋道管理系统
|
|||||||
# 芋道管理系统/开发环境
|
# 芋道管理系统/开发环境
|
||||||
# VUE_APP_BASE_API = 'http://192.168.1.49:48080'
|
# VUE_APP_BASE_API = 'http://192.168.1.49:48080'
|
||||||
# VUE_APP_BASE_API = 'http://192.168.1.8:48080'
|
# VUE_APP_BASE_API = 'http://192.168.1.8:48080'
|
||||||
# VUE_APP_BASE_API = 'http://192.168.0.33:48080'
|
VUE_APP_BASE_API = 'http://192.168.0.33:48080'
|
||||||
VUE_APP_BASE_API = 'http://192.168.1.188:48080'
|
# VUE_APP_BASE_API = 'http://192.168.1.188:48080'
|
||||||
|
|
||||||
# 路由懒加载
|
# 路由懒加载
|
||||||
VUE_CLI_BABEL_TRANSPILE_MODULES = true
|
VUE_CLI_BABEL_TRANSPILE_MODULES = true
|
||||||
|
@ -50,3 +50,11 @@ export function getCode() {
|
|||||||
method: 'get'
|
method: 'get'
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 获得可用的排班列表
|
||||||
|
export function listEnabled() {
|
||||||
|
return request({
|
||||||
|
url: '/base/group-team/listEnabled',
|
||||||
|
method: 'get'
|
||||||
|
})
|
||||||
|
}
|
||||||
|
@ -1,54 +1,27 @@
|
|||||||
import request from '@/utils/request'
|
import request from '@/utils/request'
|
||||||
|
|
||||||
// 创建排班信息
|
// 获取某月预排班-已有排班
|
||||||
export function createGroupTeamScheduling(data) {
|
export function getPreset(query) {
|
||||||
return request({
|
return request({
|
||||||
url: '/base/group-team-scheduling/create',
|
url: '/base/group-team-scheduling/getPreset',
|
||||||
method: 'post',
|
|
||||||
data: data
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
// 更新排班信息
|
|
||||||
export function updateGroupTeamScheduling(data) {
|
|
||||||
return request({
|
|
||||||
url: '/base/group-team-scheduling/update',
|
|
||||||
method: 'put',
|
|
||||||
data: data
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
// 删除排班信息
|
|
||||||
export function deleteGroupTeamScheduling(id) {
|
|
||||||
return request({
|
|
||||||
url: '/base/group-team-scheduling/delete?id=' + id,
|
|
||||||
method: 'delete'
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
// 获得排班信息
|
|
||||||
export function getGroupTeamScheduling(id) {
|
|
||||||
return request({
|
|
||||||
url: '/base/group-team-scheduling/get?id=' + id,
|
|
||||||
method: 'get'
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
// 获得排班信息分页
|
|
||||||
export function getGroupTeamSchedulingPage(query) {
|
|
||||||
return request({
|
|
||||||
url: '/base/group-team-scheduling/page',
|
|
||||||
method: 'get',
|
method: 'get',
|
||||||
params: query
|
params: query
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// 导出排班信息 Excel
|
// 批量创建-更新排班信息
|
||||||
export function exportGroupTeamSchedulingExcel(query) {
|
export function createOrUpdateList(data) {
|
||||||
return request({
|
return request({
|
||||||
url: '/base/group-team-scheduling/export-excel',
|
url: '/base/group-team-scheduling/createOrUpdateList',
|
||||||
method: 'get',
|
method: 'post',
|
||||||
params: query,
|
data: data
|
||||||
responseType: 'blob'
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 自动排班,填充上月已有的排班
|
||||||
|
export function autoSet() {
|
||||||
|
return request({
|
||||||
|
url: '/base/group-team-scheduling/autoSet',
|
||||||
|
method: 'get'
|
||||||
|
})
|
||||||
|
}
|
12
src/assets/icons/svg/downward.svg
Normal file
12
src/assets/icons/svg/downward.svg
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg width="18px" height="18px" viewBox="0 0 18 18" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
|
||||||
|
<title>下拉展开</title>
|
||||||
|
<g id="页面" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
|
||||||
|
<g id="编组-43" transform="translate(-1870.000000, -119.000000)" fill-rule="nonzero">
|
||||||
|
<g id="下拉展开" transform="translate(1870.000000, 119.000000)">
|
||||||
|
<rect id="矩形" fill="#000000" opacity="0" x="0" y="0" width="18" height="18"></rect>
|
||||||
|
<path d="M9.79014922,13.2165873 L16.1721224,6.15356667 C16.6092925,5.77338351 16.6092925,5.16518371 16.1721224,4.78500055 C15.964758,4.60350795 15.6800768,4.50112918 15.3827707,4.50112918 C15.0854647,4.50112918 14.8007835,4.60350795 14.5934191,4.78500055 L9.00013482,11.162609 L3.40552499,4.78387137 C3.19816065,4.60237877 2.91347942,4.5 2.61617336,4.5 C2.3188673,4.5 2.03418606,4.60237877 1.82682172,4.78387137 C1.39105943,5.16454327 1.39105943,5.77176559 1.82682172,6.15243749 L8.20879489,13.214329 C8.31400161,13.3066969 8.440317,13.3797143 8.57994259,13.4288732 C8.99637706,13.5753327 9.475517,13.4912854 9.79014922,13.2165873 Z" id="路径" fill="#0B58FF"></path>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 1.3 KiB |
10
src/assets/icons/svg/toggle.svg
Normal file
10
src/assets/icons/svg/toggle.svg
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg width="16px" height="16px" viewBox="0 0 16 16" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
|
||||||
|
<title>切换</title>
|
||||||
|
<g id="1班组管理" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
|
||||||
|
<g id="切换" fill="#FFFFFF" fill-rule="nonzero">
|
||||||
|
<rect id="矩形" opacity="0" x="0" y="0" width="16" height="16"></rect>
|
||||||
|
<path d="M14.5,9.15 C14.969442,9.15 15.35,9.53055796 15.35,10 C15.35,10.4333311 15.0257376,10.7909267 14.6066222,10.8433773 L14.5,10.85 L3.523,10.8493636 L5.10448737,12.4305126 C5.26177017,12.5877954 5.34716031,12.7990496 5.34764236,13.015701 L5.34074746,13.1242515 L5.31933966,13.2323523 C5.24258033,13.518822 5.01882201,13.7425803 4.73235229,13.8193397 C4.48169128,13.8865041 4.21633806,13.832194 4.01342676,13.6770775 L3.93051263,13.6044874 L1.04232939,10.7055042 C0.831903536,10.5688042 0.689345737,10.3541899 0.656994192,10.1075365 L0.65,10 L0.65778959,9.88152374 C0.670925502,9.77175364 0.705946489,9.66606949 0.76033092,9.57061601 L0.821076439,9.47880032 L0.894170559,9.39517056 C1.02591288,9.26342824 1.19742791,9.1808136 1.37731459,9.15882561 L1.5,9.15 L14.5,9.15 Z M11.9865732,2.32292254 L12.0694874,2.39551263 L14.9508862,5.29019827 C15.1653597,5.42263107 15.3074642,5.64305498 15.3419246,5.89182346 L15.35,6 L15.3417548,6.1198336 C15.3282251,6.22918814 15.2930578,6.33441548 15.2387207,6.42946868 L15.1780851,6.52090655 L15.1052179,6.60421789 C14.9738843,6.73555151 14.8030912,6.81820523 14.622959,6.840766 L14.5,6.85 L1.5,6.85 C1.03055796,6.85 0.65,6.46944204 0.65,6 C0.65,5.56666889 0.974262406,5.20907332 1.39337781,5.15662271 L1.5,5.15 L12.475,5.14936355 L10.8955126,3.56948738 C10.7382298,3.41220459 10.6528397,3.20095039 10.6523576,2.98429905 L10.6592525,2.8757485 L10.6806603,2.76764771 C10.7478247,2.5169867 10.9275353,2.31433911 11.1633258,2.21617103 L11.2676477,2.18066033 C11.5183087,2.11349592 11.7836619,2.167806 11.9865732,2.32292254 Z" id="形状结合"></path>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 2.0 KiB |
14
src/assets/icons/svg/upward.svg
Normal file
14
src/assets/icons/svg/upward.svg
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg width="18px" height="18px" viewBox="0 0 18 18" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
|
||||||
|
<title>收起</title>
|
||||||
|
<g id="页面" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
|
||||||
|
<g id="编组-43" transform="translate(-1870.000000, -485.000000)" fill-rule="nonzero">
|
||||||
|
<g id="编组-18备份" transform="translate(1.000000, 366.000000)">
|
||||||
|
<g id="收起" transform="translate(1878.000000, 128.000000) scale(1, -1) translate(-1878.000000, -128.000000) translate(1869.000000, 119.000000)">
|
||||||
|
<rect id="矩形" fill="#000000" opacity="0" x="0" y="0" width="18" height="18"></rect>
|
||||||
|
<path d="M9.79014922,13.2165873 L16.1721224,6.15356667 C16.6092925,5.77338351 16.6092925,5.16518371 16.1721224,4.78500055 C15.964758,4.60350795 15.6800768,4.50112918 15.3827707,4.50112918 C15.0854647,4.50112918 14.8007835,4.60350795 14.5934191,4.78500055 L9.00013482,11.162609 L3.40552499,4.78387137 C3.19816065,4.60237877 2.91347942,4.5 2.61617336,4.5 C2.3188673,4.5 2.03418606,4.60237877 1.82682172,4.78387137 C1.39105943,5.16454327 1.39105943,5.77176559 1.82682172,6.15243749 L8.20879489,13.214329 C8.31400161,13.3066969 8.440317,13.3797143 8.57994259,13.4288732 C8.99637706,13.5753327 9.475517,13.4912854 9.79014922,13.2165873 Z" id="路径" fill="#0B58FF"></path>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 1.5 KiB |
@ -13,8 +13,17 @@ body {
|
|||||||
font-family: Helvetica Neue, Helvetica, PingFang SC, Hiragino Sans GB, Microsoft YaHei, Arial, sans-serif;
|
font-family: Helvetica Neue, Helvetica, PingFang SC, Hiragino Sans GB, Microsoft YaHei, Arial, sans-serif;
|
||||||
}
|
}
|
||||||
|
|
||||||
label {
|
// label {
|
||||||
font-weight: 700;
|
// font-weight: 700;
|
||||||
|
// }
|
||||||
|
.searchBarBox .el-form-item--medium .el-form-item__label {
|
||||||
|
line-height: 40px;
|
||||||
|
}
|
||||||
|
.searchBarBox .el-form-item--medium .el-form-item__content {
|
||||||
|
line-height: 40px;
|
||||||
|
}
|
||||||
|
.searchBarBox .el-range-editor--small.el-input__inner {
|
||||||
|
height: 34px;
|
||||||
}
|
}
|
||||||
|
|
||||||
html {
|
html {
|
||||||
|
@ -52,6 +52,13 @@ Vue.prototype.divide = divide;
|
|||||||
Vue.prototype.tableHeight = function(n) {
|
Vue.prototype.tableHeight = function(n) {
|
||||||
return window.innerHeight - n
|
return window.innerHeight - n
|
||||||
}
|
}
|
||||||
|
Vue.prototype.searchBarWidth = function(name, num) {
|
||||||
|
if (document.getElementById(name) && document.getElementById(name).offsetWidth < num) {
|
||||||
|
return true
|
||||||
|
} else {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// 全局组件挂载
|
// 全局组件挂载
|
||||||
Vue.component('DictTag', DictTag);
|
Vue.component('DictTag', DictTag);
|
||||||
|
@ -1,143 +1,160 @@
|
|||||||
<template>
|
<template>
|
||||||
<el-form :inline="true" class="demo-form-inline">
|
<div class="searchBarBox divHeight" ref="searchBarRef" :style="{ paddingRight: isFold ? '55px' : '0px' }">
|
||||||
<el-form-item label="能源类型">
|
<el-form :inline="true" class="demo-form-inline">
|
||||||
<el-select v-model="queryParams.energyTypeId" placeholder="请选择" style="width: 100px;">
|
<span class="blue-block"></span>
|
||||||
<el-option
|
<el-form-item label="能源类型">
|
||||||
v-for="item in energyTypeList"
|
<el-select v-model="queryParams.energyTypeId" placeholder="请选择" style="width: 100px;" size="small">
|
||||||
:key="item.id"
|
<el-option
|
||||||
:label="item.name"
|
v-for="item in energyTypeList"
|
||||||
:value="item.id">
|
:key="item.id"
|
||||||
</el-option>
|
:label="item.name"
|
||||||
</el-select>
|
:value="item.id">
|
||||||
</el-form-item>
|
</el-option>
|
||||||
<el-form-item label="时间维度">
|
</el-select>
|
||||||
<el-select v-model="queryParams.timeDim" placeholder="请选择" style="width: 80px;">
|
</el-form-item>
|
||||||
<el-option
|
<el-form-item label="时间维度">
|
||||||
v-for="item in getDictDatas(this.DICT_TYPE.TIME_DIM)"
|
<el-select v-model="queryParams.timeDim" placeholder="请选择" style="width: 80px;" size="small">
|
||||||
:key="item.value"
|
<el-option
|
||||||
:label="item.label"
|
v-for="item in getDictDatas(this.DICT_TYPE.TIME_DIM)"
|
||||||
:value="item.value">
|
:key="item.value"
|
||||||
</el-option>
|
:label="item.label"
|
||||||
</el-select>
|
:value="item.value">
|
||||||
</el-form-item>
|
</el-option>
|
||||||
<el-form-item label="时间范围">
|
</el-select>
|
||||||
<div v-show="queryParams.timeDim === '1'">
|
</el-form-item>
|
||||||
<el-date-picker
|
<el-form-item label="时间范围">
|
||||||
v-model="timeValue"
|
<div v-show="queryParams.timeDim === '1'">
|
||||||
type="datetimerange"
|
<el-date-picker
|
||||||
range-separator="至"
|
v-model="timeValue"
|
||||||
start-placeholder="开始日期"
|
type="datetimerange"
|
||||||
end-placeholder="结束日期"
|
range-separator="至"
|
||||||
format="yyyy-MM-dd HH:mm"
|
start-placeholder="开始日期"
|
||||||
value-format="timestamp"
|
end-placeholder="结束日期"
|
||||||
:picker-options="pickerOptions"
|
format="yyyy-MM-dd HH:mm"
|
||||||
popper-class="noneMinute"
|
value-format="timestamp"
|
||||||
@change="timeSelect"
|
:picker-options="pickerOptions"
|
||||||
:clearable="false"
|
popper-class="noneMinute"
|
||||||
|
@change="timeSelect"
|
||||||
|
size="small"
|
||||||
|
style='width:350px;'
|
||||||
|
:clearable="false"
|
||||||
|
>
|
||||||
|
</el-date-picker>
|
||||||
|
</div>
|
||||||
|
<div v-show="queryParams.timeDim === '2'">
|
||||||
|
<el-date-picker
|
||||||
|
v-model="dateValue"
|
||||||
|
type="daterange"
|
||||||
|
range-separator="至"
|
||||||
|
start-placeholder="开始日期"
|
||||||
|
end-placeholder="结束日期"
|
||||||
|
value-format="timestamp"
|
||||||
|
:picker-options="pickerOptions"
|
||||||
|
:clearable="false"
|
||||||
|
size="small"
|
||||||
|
style='width:350px;'
|
||||||
|
@change="timeSelect"
|
||||||
|
>
|
||||||
|
</el-date-picker>
|
||||||
|
</div>
|
||||||
|
<div v-show="queryParams.timeDim === '3'">
|
||||||
|
<el-date-picker
|
||||||
|
v-model="weekValue1"
|
||||||
|
type="week"
|
||||||
|
format="yyyy 第 WW 周"
|
||||||
|
style='width:170px;'
|
||||||
|
:picker-options="pickerOptionsWeek"
|
||||||
|
@change="startWeek"
|
||||||
|
:clearable="false"
|
||||||
|
size="small"
|
||||||
|
placeholder="选择周">
|
||||||
|
</el-date-picker>-
|
||||||
|
<el-date-picker
|
||||||
|
v-model="weekValue2"
|
||||||
|
type="week"
|
||||||
|
format="yyyy 第 WW 周"
|
||||||
|
:picker-options="pickerOptionsWeek"
|
||||||
|
style='width:170px;'
|
||||||
|
@change="endWeek"
|
||||||
|
:clearable="false"
|
||||||
|
size="small"
|
||||||
|
placeholder="选择周">
|
||||||
|
</el-date-picker>
|
||||||
|
</div>
|
||||||
|
<div v-show="queryParams.timeDim === '4'">
|
||||||
|
<el-date-picker
|
||||||
|
v-model="monthValue"
|
||||||
|
type="monthrange"
|
||||||
|
range-separator="至"
|
||||||
|
start-placeholder="开始日期"
|
||||||
|
end-placeholder="结束日期"
|
||||||
|
value-format="timestamp"
|
||||||
|
:clearable="false"
|
||||||
|
:picker-options="pickerOptions"
|
||||||
|
size="small"
|
||||||
|
style='width:350px;'
|
||||||
|
@change="timeSelect"
|
||||||
|
>
|
||||||
|
</el-date-picker>
|
||||||
|
</div>
|
||||||
|
<div v-show="queryParams.timeDim === '5'">
|
||||||
|
<el-date-picker
|
||||||
|
style='width:170px;'
|
||||||
|
v-model="yearValue1"
|
||||||
|
type="year"
|
||||||
|
:picker-options="pickerOptions"
|
||||||
|
value-format="timestamp"
|
||||||
|
placeholder="选择年"
|
||||||
|
@change="startYear"
|
||||||
|
size="small"
|
||||||
|
:clearable="false"
|
||||||
>
|
>
|
||||||
</el-date-picker>
|
</el-date-picker>-
|
||||||
</div>
|
<el-date-picker
|
||||||
<div v-show="queryParams.timeDim === '2'">
|
style='width:170px;'
|
||||||
<el-date-picker
|
v-model="yearValue2"
|
||||||
v-model="dateValue"
|
type="year"
|
||||||
type="daterange"
|
:picker-options="pickerOptions"
|
||||||
range-separator="至"
|
value-format="timestamp"
|
||||||
start-placeholder="开始日期"
|
placeholder="选择年"
|
||||||
end-placeholder="结束日期"
|
@change="endYear"
|
||||||
value-format="timestamp"
|
size="small"
|
||||||
:picker-options="pickerOptions"
|
:clearable="false"
|
||||||
:clearable="false"
|
|
||||||
@change="timeSelect"
|
|
||||||
>
|
>
|
||||||
</el-date-picker>
|
</el-date-picker>
|
||||||
</div>
|
</div>
|
||||||
<div v-show="queryParams.timeDim === '3'">
|
</el-form-item>
|
||||||
<el-date-picker
|
<el-form-item label="对象维度">
|
||||||
v-model="weekValue1"
|
<el-select v-model="queryParams.objType" placeholder="请选择" style="width: 80px;" @change="selectObjs" size="small">
|
||||||
type="week"
|
<el-option
|
||||||
format="yyyy 第 WW 周"
|
v-for="item in getDictDatas(this.DICT_TYPE.OBJECT_TYPE)"
|
||||||
style='width:150px;'
|
:key="item.value"
|
||||||
:picker-options="pickerOptionsWeek"
|
:label="item.label"
|
||||||
@change="startWeek"
|
:value="item.value">
|
||||||
:clearable="false"
|
</el-option>
|
||||||
placeholder="选择周">
|
</el-select>
|
||||||
</el-date-picker>-
|
</el-form-item>
|
||||||
<el-date-picker
|
<el-form-item label="对象选择">
|
||||||
v-model="weekValue2"
|
<el-select v-model="queryParams.objIds" placeholder="请选择" multiple collapse-tags style="width: 200px;" size="small">
|
||||||
type="week"
|
<el-option
|
||||||
format="yyyy 第 WW 周"
|
v-for="item in objectList"
|
||||||
:picker-options="pickerOptionsWeek"
|
:key="item.id"
|
||||||
style='width:150px;'
|
:label="item.name"
|
||||||
@change="endWeek"
|
:value="item.id">
|
||||||
:clearable="false"
|
<span style="float: left">{{ item.name }}</span>
|
||||||
placeholder="选择周">
|
<span style="float: right; color: #8492a6; font-size: 13px">{{ item.code }}</span>
|
||||||
</el-date-picker>
|
</el-option>
|
||||||
</div>
|
</el-select>
|
||||||
<div v-show="queryParams.timeDim === '4'">
|
</el-form-item>
|
||||||
<el-date-picker
|
<el-form-item>
|
||||||
v-model="monthValue"
|
<el-button type="primary" size="small" @click="search">查询</el-button>
|
||||||
type="monthrange"
|
</el-form-item>
|
||||||
range-separator="至"
|
</el-form>
|
||||||
start-placeholder="开始日期"
|
<span v-if="isFold" class="foldClass" @click='switchMode'>
|
||||||
end-placeholder="结束日期"
|
{{ isExpand ? '收起' : '展开' }}
|
||||||
value-format="timestamp"
|
<svg-icon :icon-class="isExpand ? 'upward' : 'downward'" />
|
||||||
:clearable="false"
|
</span>
|
||||||
:picker-options="pickerOptions"
|
</div>
|
||||||
@change="timeSelect"
|
|
||||||
>
|
|
||||||
</el-date-picker>
|
|
||||||
</div>
|
|
||||||
<div v-show="queryParams.timeDim === '5'">
|
|
||||||
<el-date-picker
|
|
||||||
style='width:100px;'
|
|
||||||
v-model="yearValue1"
|
|
||||||
type="year"
|
|
||||||
:picker-options="pickerOptions"
|
|
||||||
value-format="timestamp"
|
|
||||||
placeholder="选择年"
|
|
||||||
@change="startYear"
|
|
||||||
:clearable="false"
|
|
||||||
>
|
|
||||||
</el-date-picker>-
|
|
||||||
<el-date-picker
|
|
||||||
style='width:100px;'
|
|
||||||
v-model="yearValue2"
|
|
||||||
type="year"
|
|
||||||
:picker-options="pickerOptions"
|
|
||||||
value-format="timestamp"
|
|
||||||
placeholder="选择年"
|
|
||||||
@change="endYear"
|
|
||||||
:clearable="false"
|
|
||||||
>
|
|
||||||
</el-date-picker>
|
|
||||||
</div>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item label="对象维度">
|
|
||||||
<el-select v-model="queryParams.objType" placeholder="请选择" style="width: 80px;" @change="selectObjs">
|
|
||||||
<el-option
|
|
||||||
v-for="item in getDictDatas(this.DICT_TYPE.OBJECT_TYPE)"
|
|
||||||
:key="item.value"
|
|
||||||
:label="item.label"
|
|
||||||
:value="item.value">
|
|
||||||
</el-option>
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item label="对象选择">
|
|
||||||
<el-select v-model="queryParams.objIds" placeholder="请选择" multiple collapse-tags style="width: 200px;">
|
|
||||||
<el-option
|
|
||||||
v-for="item in objectList"
|
|
||||||
:key="item.id"
|
|
||||||
:label="item.name"
|
|
||||||
:value="item.id">
|
|
||||||
<span style="float: left">{{ item.name }}</span>
|
|
||||||
<span style="float: right; color: #8492a6; font-size: 13px">{{ item.code }}</span>
|
|
||||||
</el-option>
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item>
|
|
||||||
<el-button type="primary" @click="search">查询</el-button>
|
|
||||||
</el-form-item>
|
|
||||||
</el-form>
|
|
||||||
</template>
|
</template>
|
||||||
<script>
|
<script>
|
||||||
import { getEnergyTypeListAll } from "@/api/base/energyType"
|
import { getEnergyTypeListAll } from "@/api/base/energyType"
|
||||||
@ -147,8 +164,15 @@ import { getEquipmentAll } from "@/api/base/equipment"
|
|||||||
import moment from 'moment'
|
import moment from 'moment'
|
||||||
export default {
|
export default {
|
||||||
name: 'searchArea',
|
name: 'searchArea',
|
||||||
|
props: {
|
||||||
|
isFold: {// 多行模式(默认否)
|
||||||
|
type: Boolean,
|
||||||
|
default: false
|
||||||
|
}
|
||||||
|
},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
isExpand: false, // 展开收起
|
||||||
// 查询参数
|
// 查询参数
|
||||||
queryParams: {
|
queryParams: {
|
||||||
energyTypeId: null,
|
energyTypeId: null,
|
||||||
@ -388,6 +412,15 @@ export default {
|
|||||||
let newData = year+'-12-31 23:59:59'
|
let newData = year+'-12-31 23:59:59'
|
||||||
let value = new Date(newData).getTime()
|
let value = new Date(newData).getTime()
|
||||||
return value
|
return value
|
||||||
|
},
|
||||||
|
switchMode() {// 展开和收起切换
|
||||||
|
this.isExpand = !this.isExpand
|
||||||
|
const element = this.$refs.searchBarRef
|
||||||
|
if (this.isExpand) {
|
||||||
|
element.classList.remove('divHeight')
|
||||||
|
} else {
|
||||||
|
element.classList.add('divHeight')
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -400,4 +433,34 @@ export default {
|
|||||||
.noneMinute .el-scrollbar:nth-of-type(2) {
|
.noneMinute .el-scrollbar:nth-of-type(2) {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
</style>
|
||||||
|
<style lang="scss" scoped>
|
||||||
|
.demo-form-inline {
|
||||||
|
.blue-block {
|
||||||
|
display: inline-block;
|
||||||
|
width: 4px;
|
||||||
|
height: 16px;
|
||||||
|
background-color: #0B58FF;
|
||||||
|
border-radius: 1px;
|
||||||
|
margin-right: 8px;
|
||||||
|
margin-top: 10px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
<style scoped>
|
||||||
|
.searchBarBox .foldClass {
|
||||||
|
position: absolute;
|
||||||
|
top: 14px;
|
||||||
|
right: 0;
|
||||||
|
cursor: pointer;
|
||||||
|
font-size: 12px;
|
||||||
|
color:#0B58FF;
|
||||||
|
}
|
||||||
|
.searchBarBox .foldClass .iconfont {
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
.divHeight {
|
||||||
|
height: 45px;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
</style>
|
</style>
|
@ -1,7 +1,7 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="app-container">
|
<div class="app-container" id="contrastAnalysisBox">
|
||||||
<!-- 搜索工作栏 -->
|
<!-- 搜索工作栏 -->
|
||||||
<search-area @submit="getList"/>
|
<search-area :isFold="isFold" @submit="getList"/>
|
||||||
<el-tabs v-model="activeName" @tab-click="switchChart">
|
<el-tabs v-model="activeName" @tab-click="switchChart">
|
||||||
<el-tab-pane label="柱状图" name="bar">
|
<el-tab-pane label="柱状图" name="bar">
|
||||||
<bar-chart ref="analysisBarChart" :chartData="chartData" />
|
<bar-chart ref="analysisBarChart" :chartData="chartData" />
|
||||||
@ -23,11 +23,19 @@ export default {
|
|||||||
components: { SearchArea, BarChart, LineChart },
|
components: { SearchArea, BarChart, LineChart },
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
isFold: false,
|
||||||
activeName: 'bar',
|
activeName: 'bar',
|
||||||
chartData: []
|
chartData: []
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
mounted() {},
|
mounted() {
|
||||||
|
window.addEventListener('resize', () => {
|
||||||
|
this.tableH = this.tableHeight(260)
|
||||||
|
this.isFold = this.searchBarWidth('contrastAnalysisBox', 1310)
|
||||||
|
// console.log(document.getElementById("contrastAnalysisBox").offsetWidth)
|
||||||
|
})
|
||||||
|
this.isFold = this.searchBarWidth('contrastAnalysisBox', 1310)
|
||||||
|
},
|
||||||
methods: {
|
methods: {
|
||||||
getList(params) {
|
getList(params) {
|
||||||
getCompare({ ...params }).then((res) => {
|
getCompare({ ...params }).then((res) => {
|
||||||
|
@ -1,15 +1,17 @@
|
|||||||
<template>
|
<template>
|
||||||
<el-form :inline="true" class="demo-form-inline">
|
<el-form :inline="true" class="demo-form-inline">
|
||||||
|
<span class="blue-block"></span>
|
||||||
<el-form-item label="对象选择">
|
<el-form-item label="对象选择">
|
||||||
<el-cascader
|
<el-cascader
|
||||||
v-model="objArr"
|
v-model="objArr"
|
||||||
:options="objList"
|
:options="objList"
|
||||||
:props="{ checkStrictly: true, value: 'id', label: 'name' }"
|
:props="{ checkStrictly: true, value: 'id', label: 'name' }"
|
||||||
popper-class="cascaderParent"
|
popper-class="cascaderParent"
|
||||||
|
size="small"
|
||||||
clearable></el-cascader>
|
clearable></el-cascader>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="时间维度">
|
<el-form-item label="时间维度">
|
||||||
<el-select v-model="queryParams.type" placeholder="请选择" style="width: 80px;">
|
<el-select v-model="queryParams.type" placeholder="请选择" style="width: 80px;" size="small">
|
||||||
<el-option
|
<el-option
|
||||||
v-for="item in timeType"
|
v-for="item in timeType"
|
||||||
:key="item.id"
|
:key="item.id"
|
||||||
@ -27,6 +29,7 @@
|
|||||||
:picker-options="pickerOptions"
|
:picker-options="pickerOptions"
|
||||||
@change="selectTime"
|
@change="selectTime"
|
||||||
:clearable="false"
|
:clearable="false"
|
||||||
|
size="small"
|
||||||
placeholder="选择月">
|
placeholder="选择月">
|
||||||
</el-date-picker>
|
</el-date-picker>
|
||||||
</div>
|
</div>
|
||||||
@ -38,6 +41,7 @@
|
|||||||
:picker-options="pickerOptionsWeek"
|
:picker-options="pickerOptionsWeek"
|
||||||
@change="selectTime"
|
@change="selectTime"
|
||||||
:clearable="false"
|
:clearable="false"
|
||||||
|
size="small"
|
||||||
placeholder="选择周">
|
placeholder="选择周">
|
||||||
</el-date-picker>
|
</el-date-picker>
|
||||||
</div>
|
</div>
|
||||||
@ -48,18 +52,19 @@
|
|||||||
:picker-options="pickerOptions"
|
:picker-options="pickerOptions"
|
||||||
@change="selectTime"
|
@change="selectTime"
|
||||||
:clearable="false"
|
:clearable="false"
|
||||||
|
size="small"
|
||||||
placeholder="选择日">
|
placeholder="选择日">
|
||||||
</el-date-picker>
|
</el-date-picker>
|
||||||
</div>
|
</div>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item>
|
<el-form-item>
|
||||||
<el-button type="primary" @click="search">查询</el-button>
|
<el-button type="primary" size="small" @click="search">查询</el-button>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item>
|
<el-form-item>
|
||||||
<span class="separateStyle"></span>
|
<span class="separateStyle"></span>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item>
|
<el-form-item>
|
||||||
<el-button type="primary" @click="exportData" plain>导出</el-button>
|
<el-button type="primary" size="small" @click="exportData" plain>导出</el-button>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
</template>
|
</template>
|
||||||
@ -178,4 +183,17 @@ export default {
|
|||||||
background: #E8E8E8;
|
background: #E8E8E8;
|
||||||
vertical-align: middle;
|
vertical-align: middle;
|
||||||
}
|
}
|
||||||
|
</style>
|
||||||
|
<style lang="scss" scoped>
|
||||||
|
.demo-form-inline {
|
||||||
|
.blue-block {
|
||||||
|
display: inline-block;
|
||||||
|
width: 4px;
|
||||||
|
height: 16px;
|
||||||
|
background-color: #0B58FF;
|
||||||
|
border-radius: 1px;
|
||||||
|
margin-right: 8px;
|
||||||
|
margin-top: 10px;
|
||||||
|
}
|
||||||
|
}
|
||||||
</style>
|
</style>
|
@ -1,122 +1,141 @@
|
|||||||
<template>
|
<template>
|
||||||
<el-form :inline="true" class="demo-form-inline">
|
<div class="searchBarBox divHeight" ref="searchBarRef" :style="{ paddingRight: isFold ? '55px' : '0px' }">
|
||||||
<el-form-item label="能源类型">
|
<el-form :inline="true" class="demo-form-inline">
|
||||||
<el-select v-model="queryParams.energyTypeId" placeholder="请选择" style="width: 100px;">
|
<span class="blue-block"></span>
|
||||||
<el-option
|
<el-form-item label="能源类型">
|
||||||
v-for="item in energyTypeList"
|
<el-select v-model="queryParams.energyTypeId" placeholder="请选择" style="width: 100px;" size="small">
|
||||||
:key="item.id"
|
<el-option
|
||||||
:label="item.name"
|
v-for="item in energyTypeList"
|
||||||
:value="item.id">
|
:key="item.id"
|
||||||
</el-option>
|
:label="item.name"
|
||||||
</el-select>
|
:value="item.id">
|
||||||
</el-form-item>
|
</el-option>
|
||||||
<el-form-item label="对象选择">
|
</el-select>
|
||||||
<el-cascader
|
</el-form-item>
|
||||||
v-model="objArr"
|
<el-form-item label="对象选择">
|
||||||
:options="objList"
|
<el-cascader
|
||||||
:props="{ checkStrictly: true, value: 'id', label: 'name' }"
|
v-model="objArr"
|
||||||
popper-class="cascaderParent"
|
:options="objList"
|
||||||
clearable></el-cascader>
|
:props="{ checkStrictly: true, value: 'id', label: 'name' }"
|
||||||
</el-form-item>
|
popper-class="cascaderParent"
|
||||||
<el-form-item label="时间维度">
|
size="small"
|
||||||
<el-select v-model="queryParams.timeDim" placeholder="请选择" style="width: 80px;">
|
clearable></el-cascader>
|
||||||
<el-option
|
</el-form-item>
|
||||||
v-for="item in getDictDatas(this.DICT_TYPE.TIME_DIM)"
|
<el-form-item label="时间维度">
|
||||||
:key="item.value"
|
<el-select v-model="queryParams.timeDim" placeholder="请选择" style="width: 80px;" size="small">
|
||||||
:label="item.label"
|
<el-option
|
||||||
:value="item.value">
|
v-for="item in getDictDatas(this.DICT_TYPE.TIME_DIM)"
|
||||||
</el-option>
|
:key="item.value"
|
||||||
</el-select>
|
:label="item.label"
|
||||||
</el-form-item>
|
:value="item.value"
|
||||||
<el-form-item label="时间范围">
|
size="small">
|
||||||
<div v-show="queryParams.timeDim === '1'">
|
</el-option>
|
||||||
<el-date-picker
|
</el-select>
|
||||||
v-model="timeValue"
|
</el-form-item>
|
||||||
type="datetimerange"
|
<el-form-item label="时间范围">
|
||||||
range-separator="至"
|
<div v-show="queryParams.timeDim === '1'">
|
||||||
start-placeholder="开始日期"
|
<el-date-picker
|
||||||
end-placeholder="结束日期"
|
v-model="timeValue"
|
||||||
format="yyyy-MM-dd HH:mm"
|
type="datetimerange"
|
||||||
value-format="timestamp"
|
range-separator="至"
|
||||||
:picker-options="pickerOptions"
|
start-placeholder="开始日期"
|
||||||
popper-class="noneMinute"
|
end-placeholder="结束日期"
|
||||||
@change="timeSelect"
|
format="yyyy-MM-dd HH:mm"
|
||||||
|
value-format="timestamp"
|
||||||
|
:picker-options="pickerOptions"
|
||||||
|
popper-class="noneMinute"
|
||||||
|
@change="timeSelect"
|
||||||
|
size="small"
|
||||||
|
style='width:350px;'
|
||||||
|
>
|
||||||
|
</el-date-picker>
|
||||||
|
</div>
|
||||||
|
<div v-show="queryParams.timeDim === '2'">
|
||||||
|
<el-date-picker
|
||||||
|
v-model="dateValue"
|
||||||
|
type="daterange"
|
||||||
|
range-separator="至"
|
||||||
|
start-placeholder="开始日期"
|
||||||
|
end-placeholder="结束日期"
|
||||||
|
value-format="timestamp"
|
||||||
|
:picker-options="pickerOptions"
|
||||||
|
@change="timeSelect"
|
||||||
|
size="small"
|
||||||
|
style='width:350px;'
|
||||||
|
>
|
||||||
|
</el-date-picker>
|
||||||
|
</div>
|
||||||
|
<div v-show="queryParams.timeDim === '3'">
|
||||||
|
<el-date-picker
|
||||||
|
v-model="weekValue1"
|
||||||
|
type="week"
|
||||||
|
format="yyyy 第 WW 周"
|
||||||
|
style='width:170px;'
|
||||||
|
:picker-options="pickerOptionsWeek"
|
||||||
|
@change="startWeek"
|
||||||
|
size="small"
|
||||||
|
placeholder="选择周">
|
||||||
|
</el-date-picker>-
|
||||||
|
<el-date-picker
|
||||||
|
v-model="weekValue2"
|
||||||
|
type="week"
|
||||||
|
format="yyyy 第 WW 周"
|
||||||
|
:picker-options="pickerOptionsWeek"
|
||||||
|
style='width:170px;'
|
||||||
|
@change="endWeek"
|
||||||
|
size="small"
|
||||||
|
placeholder="选择周">
|
||||||
|
</el-date-picker>
|
||||||
|
</div>
|
||||||
|
<div v-show="queryParams.timeDim === '4'">
|
||||||
|
<el-date-picker
|
||||||
|
v-model="monthValue"
|
||||||
|
type="monthrange"
|
||||||
|
range-separator="至"
|
||||||
|
start-placeholder="开始日期"
|
||||||
|
end-placeholder="结束日期"
|
||||||
|
value-format="timestamp"
|
||||||
|
:picker-options="pickerOptions"
|
||||||
|
size="small"
|
||||||
|
style='width:350px;'
|
||||||
|
@change="timeSelect"
|
||||||
|
>
|
||||||
|
</el-date-picker>
|
||||||
|
</div>
|
||||||
|
<div v-show="queryParams.timeDim === '5'">
|
||||||
|
<el-date-picker
|
||||||
|
style='width:170px;'
|
||||||
|
v-model="yearValue1"
|
||||||
|
type="year"
|
||||||
|
:picker-options="pickerOptions"
|
||||||
|
value-format="timestamp"
|
||||||
|
placeholder="选择年"
|
||||||
|
size="small"
|
||||||
|
@change="startYear"
|
||||||
>
|
>
|
||||||
</el-date-picker>
|
</el-date-picker>-
|
||||||
</div>
|
<el-date-picker
|
||||||
<div v-show="queryParams.timeDim === '2'">
|
style='width:170px;'
|
||||||
<el-date-picker
|
v-model="yearValue2"
|
||||||
v-model="dateValue"
|
type="year"
|
||||||
type="daterange"
|
:picker-options="pickerOptions"
|
||||||
range-separator="至"
|
value-format="timestamp"
|
||||||
start-placeholder="开始日期"
|
placeholder="选择年"
|
||||||
end-placeholder="结束日期"
|
size="small"
|
||||||
value-format="timestamp"
|
@change="endYear"
|
||||||
:picker-options="pickerOptions"
|
|
||||||
@change="timeSelect"
|
|
||||||
>
|
>
|
||||||
</el-date-picker>
|
</el-date-picker>
|
||||||
</div>
|
</div>
|
||||||
<div v-show="queryParams.timeDim === '3'">
|
</el-form-item>
|
||||||
<el-date-picker
|
<el-form-item>
|
||||||
v-model="weekValue1"
|
<el-button type="primary" size="small" @click="search">查询</el-button>
|
||||||
type="week"
|
</el-form-item>
|
||||||
format="yyyy 第 WW 周"
|
</el-form>
|
||||||
style='width:150px;'
|
<span v-if="isFold" class="foldClass" @click='switchMode'>
|
||||||
:picker-options="pickerOptionsWeek"
|
{{ isExpand ? '收起' : '展开' }}
|
||||||
@change="startWeek"
|
<svg-icon :icon-class="isExpand ? 'upward' : 'downward'" />
|
||||||
placeholder="选择周">
|
</span>
|
||||||
</el-date-picker>-
|
</div>
|
||||||
<el-date-picker
|
|
||||||
v-model="weekValue2"
|
|
||||||
type="week"
|
|
||||||
format="yyyy 第 WW 周"
|
|
||||||
:picker-options="pickerOptionsWeek"
|
|
||||||
style='width:150px;'
|
|
||||||
@change="endWeek"
|
|
||||||
placeholder="选择周">
|
|
||||||
</el-date-picker>
|
|
||||||
</div>
|
|
||||||
<div v-show="queryParams.timeDim === '4'">
|
|
||||||
<el-date-picker
|
|
||||||
v-model="monthValue"
|
|
||||||
type="monthrange"
|
|
||||||
range-separator="至"
|
|
||||||
start-placeholder="开始日期"
|
|
||||||
end-placeholder="结束日期"
|
|
||||||
value-format="timestamp"
|
|
||||||
:picker-options="pickerOptions"
|
|
||||||
@change="timeSelect"
|
|
||||||
>
|
|
||||||
</el-date-picker>
|
|
||||||
</div>
|
|
||||||
<div v-show="queryParams.timeDim === '5'">
|
|
||||||
<el-date-picker
|
|
||||||
style='width:100px;'
|
|
||||||
v-model="yearValue1"
|
|
||||||
type="year"
|
|
||||||
:picker-options="pickerOptions"
|
|
||||||
value-format="timestamp"
|
|
||||||
placeholder="选择年"
|
|
||||||
@change="startYear"
|
|
||||||
>
|
|
||||||
</el-date-picker>-
|
|
||||||
<el-date-picker
|
|
||||||
style='width:100px;'
|
|
||||||
v-model="yearValue2"
|
|
||||||
type="year"
|
|
||||||
:picker-options="pickerOptions"
|
|
||||||
value-format="timestamp"
|
|
||||||
placeholder="选择年"
|
|
||||||
@change="endYear"
|
|
||||||
>
|
|
||||||
</el-date-picker>
|
|
||||||
</div>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item>
|
|
||||||
<el-button type="primary" @click="search">查询</el-button>
|
|
||||||
</el-form-item>
|
|
||||||
</el-form>
|
|
||||||
</template>
|
</template>
|
||||||
<script>
|
<script>
|
||||||
import { getEnergyTypeListAll } from "@/api/base/energyType"
|
import { getEnergyTypeListAll } from "@/api/base/energyType"
|
||||||
@ -124,8 +143,15 @@ import { getTree } from '@/api/base/factory'
|
|||||||
import moment from 'moment'
|
import moment from 'moment'
|
||||||
export default {
|
export default {
|
||||||
name: 'searchArea',
|
name: 'searchArea',
|
||||||
|
props: {
|
||||||
|
isFold: {// 多行模式(默认否)
|
||||||
|
type: Boolean,
|
||||||
|
default: false
|
||||||
|
}
|
||||||
|
},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
isExpand: false, // 展开收起
|
||||||
// 查询参数
|
// 查询参数
|
||||||
queryParams: {
|
queryParams: {
|
||||||
energyTypeId: null,
|
energyTypeId: null,
|
||||||
@ -162,6 +188,7 @@ export default {
|
|||||||
this.getTypeList()
|
this.getTypeList()
|
||||||
this.getObjTree()
|
this.getObjTree()
|
||||||
this.queryParams.timeDim = this.getDictDatas(this.DICT_TYPE.TIME_DIM)[0].value // 默认时
|
this.queryParams.timeDim = this.getDictDatas(this.DICT_TYPE.TIME_DIM)[0].value // 默认时
|
||||||
|
this.timeValue = [moment().startOf('day'), moment().endOf('day')-59*61*1000]
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
getTypeList() {
|
getTypeList() {
|
||||||
@ -266,7 +293,7 @@ export default {
|
|||||||
this.$modal.msgError('请选择能源类型')
|
this.$modal.msgError('请选择能源类型')
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
if (!this.objArr.length === 0) {
|
if (this.objArr.length === 0) {
|
||||||
this.$modal.msgError('请选择对象')
|
this.$modal.msgError('请选择对象')
|
||||||
return false
|
return false
|
||||||
} else {
|
} else {
|
||||||
@ -345,6 +372,15 @@ export default {
|
|||||||
let newData = year+'-12-31 23:59:59'
|
let newData = year+'-12-31 23:59:59'
|
||||||
let value = new Date(newData).getTime()
|
let value = new Date(newData).getTime()
|
||||||
return value
|
return value
|
||||||
|
},
|
||||||
|
switchMode() {// 展开和收起切换
|
||||||
|
this.isExpand = !this.isExpand
|
||||||
|
const element = this.$refs.searchBarRef
|
||||||
|
if (this.isExpand) {
|
||||||
|
element.classList.remove('divHeight')
|
||||||
|
} else {
|
||||||
|
element.classList.add('divHeight')
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -361,4 +397,34 @@ export default {
|
|||||||
.noneMinute .el-scrollbar:nth-of-type(2) {
|
.noneMinute .el-scrollbar:nth-of-type(2) {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
</style>
|
||||||
|
<style lang="scss" scoped>
|
||||||
|
.demo-form-inline {
|
||||||
|
.blue-block {
|
||||||
|
display: inline-block;
|
||||||
|
width: 4px;
|
||||||
|
height: 16px;
|
||||||
|
background-color: #0B58FF;
|
||||||
|
border-radius: 1px;
|
||||||
|
margin-right: 8px;
|
||||||
|
margin-top: 10px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
<style scoped>
|
||||||
|
.searchBarBox .foldClass {
|
||||||
|
position: absolute;
|
||||||
|
top: 14px;
|
||||||
|
right: 0;
|
||||||
|
cursor: pointer;
|
||||||
|
font-size: 12px;
|
||||||
|
color:#0B58FF;
|
||||||
|
}
|
||||||
|
.searchBarBox .foldClass .iconfont {
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
.divHeight {
|
||||||
|
height: 45px;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
</style>
|
</style>
|
@ -1,7 +1,7 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="app-container">
|
<div class="app-container" id="trendAnalysisBox">
|
||||||
<!-- 搜索工作栏 -->
|
<!-- 搜索工作栏 -->
|
||||||
<search-area @submit="getList"/>
|
<search-area :isFold="isFold" @submit="getList"/>
|
||||||
<el-tabs v-model="activeName" @tab-click="switchChart">
|
<el-tabs v-model="activeName" @tab-click="switchChart">
|
||||||
<el-tab-pane label="柱状图" name="bar">
|
<el-tab-pane label="柱状图" name="bar">
|
||||||
<bar-chart ref="analysisBarChart" :chartData="chartData" />
|
<bar-chart ref="analysisBarChart" :chartData="chartData" />
|
||||||
@ -23,11 +23,18 @@ export default {
|
|||||||
components: { SearchArea, BarChart, LineChart },
|
components: { SearchArea, BarChart, LineChart },
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
isFold: false,
|
||||||
activeName: 'bar',
|
activeName: 'bar',
|
||||||
chartData: []
|
chartData: []
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
mounted() {},
|
mounted() {
|
||||||
|
window.addEventListener('resize', () => {
|
||||||
|
this.tableH = this.tableHeight(260)
|
||||||
|
this.isFold = this.searchBarWidth('trendAnalysisBox', 1146)
|
||||||
|
})
|
||||||
|
this.isFold = this.searchBarWidth('trendAnalysisBox', 1146)
|
||||||
|
},
|
||||||
methods: {
|
methods: {
|
||||||
getList(params) {
|
getList(params) {
|
||||||
getEnergyTrend({ ...params }).then((res) => {
|
getEnergyTrend({ ...params }).then((res) => {
|
||||||
@ -37,16 +44,6 @@ export default {
|
|||||||
this.chartData = []
|
this.chartData = []
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
// getEnergyTrend({
|
|
||||||
// energyTypeId: "1681183397517406210",
|
|
||||||
// objId: "1679031282510532610",
|
|
||||||
// timeDim: "2",
|
|
||||||
// startTime: "1690732800000",
|
|
||||||
// endTime: "1690992000000"
|
|
||||||
// }).then((res) => {
|
|
||||||
// console.log(res)
|
|
||||||
// this.chartData = res.data
|
|
||||||
// })
|
|
||||||
},
|
},
|
||||||
switchChart() {
|
switchChart() {
|
||||||
if (this.activeName === 'bar') {
|
if (this.activeName === 'bar') {
|
||||||
|
@ -1,15 +1,17 @@
|
|||||||
<template>
|
<template>
|
||||||
<el-form :inline="true" class="demo-form-inline">
|
<el-form :inline="true" class="demo-form-inline">
|
||||||
|
<span class="blue-block"></span>
|
||||||
<el-form-item label="对象选择">
|
<el-form-item label="对象选择">
|
||||||
<el-cascader
|
<el-cascader
|
||||||
v-model="objArr"
|
v-model="objArr"
|
||||||
:options="objList"
|
:options="objList"
|
||||||
:props="{ checkStrictly: true, value: 'id', label: 'name' }"
|
:props="{ checkStrictly: true, value: 'id', label: 'name' }"
|
||||||
popper-class="cascaderParent"
|
popper-class="cascaderParent"
|
||||||
|
size="small"
|
||||||
clearable></el-cascader>
|
clearable></el-cascader>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="时间维度">
|
<el-form-item label="时间维度">
|
||||||
<el-select v-model="queryParams.type" placeholder="请选择" style="width: 80px;">
|
<el-select v-model="queryParams.type" placeholder="请选择" style="width: 80px;" size="small">
|
||||||
<el-option
|
<el-option
|
||||||
v-for="item in timeType"
|
v-for="item in timeType"
|
||||||
:key="item.id"
|
:key="item.id"
|
||||||
@ -27,6 +29,7 @@
|
|||||||
:picker-options="pickerOptions"
|
:picker-options="pickerOptions"
|
||||||
@change="selectTime"
|
@change="selectTime"
|
||||||
:clearable="false"
|
:clearable="false"
|
||||||
|
size="small"
|
||||||
placeholder="选择年">
|
placeholder="选择年">
|
||||||
</el-date-picker>
|
</el-date-picker>
|
||||||
</div>
|
</div>
|
||||||
@ -37,18 +40,19 @@
|
|||||||
:picker-options="pickerOptions"
|
:picker-options="pickerOptions"
|
||||||
@change="selectTime"
|
@change="selectTime"
|
||||||
:clearable="false"
|
:clearable="false"
|
||||||
|
size="small"
|
||||||
placeholder="选择月">
|
placeholder="选择月">
|
||||||
</el-date-picker>
|
</el-date-picker>
|
||||||
</div>
|
</div>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item>
|
<el-form-item>
|
||||||
<el-button type="primary" @click="search">查询</el-button>
|
<el-button type="primary" size="small" @click="search">查询</el-button>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item>
|
<el-form-item>
|
||||||
<span class="separateStyle"></span>
|
<span class="separateStyle"></span>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item>
|
<el-form-item>
|
||||||
<el-button type="primary" @click="exportData" plain>导出</el-button>
|
<el-button type="primary" size="small" @click="exportData" plain>导出</el-button>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
</template>
|
</template>
|
||||||
@ -153,4 +157,17 @@ export default {
|
|||||||
background: #E8E8E8;
|
background: #E8E8E8;
|
||||||
vertical-align: middle;
|
vertical-align: middle;
|
||||||
}
|
}
|
||||||
|
</style>
|
||||||
|
<style lang="scss" scoped>
|
||||||
|
.demo-form-inline {
|
||||||
|
.blue-block {
|
||||||
|
display: inline-block;
|
||||||
|
width: 4px;
|
||||||
|
height: 16px;
|
||||||
|
background-color: #0B58FF;
|
||||||
|
border-radius: 1px;
|
||||||
|
margin-right: 8px;
|
||||||
|
margin-top: 10px;
|
||||||
|
}
|
||||||
|
}
|
||||||
</style>
|
</style>
|
@ -92,7 +92,7 @@ export default {
|
|||||||
type: 'input',
|
type: 'input',
|
||||||
label: '标识名',
|
label: '标识名',
|
||||||
placeholder: '标识名',
|
placeholder: '标识名',
|
||||||
param: 'name'
|
param: 'cnName'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
type: 'button',
|
type: 'button',
|
||||||
@ -149,7 +149,7 @@ export default {
|
|||||||
queryParams: {
|
queryParams: {
|
||||||
pageNo: 1,
|
pageNo: 1,
|
||||||
pageSize: 20,
|
pageSize: 20,
|
||||||
name: null
|
cnName: null
|
||||||
},
|
},
|
||||||
paramVisible: false,
|
paramVisible: false,
|
||||||
energyTypeList: [],
|
energyTypeList: [],
|
||||||
@ -173,7 +173,7 @@ export default {
|
|||||||
switch (val.btnName) {
|
switch (val.btnName) {
|
||||||
case 'search':
|
case 'search':
|
||||||
this.queryParams.pageNo = 1;
|
this.queryParams.pageNo = 1;
|
||||||
this.queryParams.name = val.name
|
this.queryParams.cnName = val.cnName
|
||||||
this.getList()
|
this.getList()
|
||||||
break
|
break
|
||||||
default:
|
default:
|
||||||
|
@ -37,12 +37,12 @@
|
|||||||
</el-row>
|
</el-row>
|
||||||
<el-row>
|
<el-row>
|
||||||
<el-col :span="12" v-show="form.pricingMethod === 2">
|
<el-col :span="12" v-show="form.pricingMethod === 2">
|
||||||
<el-form-item label="单价(元)" prop="singlePrice">
|
<el-form-item label="单价(元)" prop="pricingMethod">
|
||||||
<el-input v-model="form.singlePrice"></el-input>
|
<el-input-number v-model="form.singlePrice" :precision="2" :min="0" :max="999999999" style="width: 100%;"></el-input-number>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="24" v-show="form.pricingMethod === 0">
|
<el-col :span="24" v-show="form.pricingMethod === 0">
|
||||||
<el-form-item label="时间段">
|
<el-form-item label="时间段" prop="pricingMethod">
|
||||||
<base-table
|
<base-table
|
||||||
:key='timeKye'
|
:key='timeKye'
|
||||||
:table-props="tableProps1"
|
:table-props="tableProps1"
|
||||||
@ -63,7 +63,7 @@
|
|||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="24" v-show="form.pricingMethod === 1">
|
<el-col :span="24" v-show="form.pricingMethod === 1">
|
||||||
<el-form-item label="使用量">
|
<el-form-item label="使用量" prop="pricingMethod">
|
||||||
<base-table
|
<base-table
|
||||||
:key='usedKye'
|
:key='usedKye'
|
||||||
:table-props="tableProps2"
|
:table-props="tableProps2"
|
||||||
@ -140,12 +140,13 @@ export default {
|
|||||||
name: '',
|
name: '',
|
||||||
code: '',
|
code: '',
|
||||||
nuit: '',
|
nuit: '',
|
||||||
pricingMethod: 1,
|
pricingMethod: 2,
|
||||||
leaderName: ''
|
leaderName: ''
|
||||||
},
|
},
|
||||||
isEdit: false, //是否是编辑
|
isEdit: false, //是否是编辑
|
||||||
rules: {
|
rules: {
|
||||||
name: [{ required: true, message: '能源类型不能为空', trigger: 'blur' }]
|
name: [{ required: true, message: '能源类型不能为空', trigger: 'blur' }],
|
||||||
|
pricingMethod: [{ required: true, message: '计价方式不能为空', trigger: 'change' }]
|
||||||
},
|
},
|
||||||
timeKye: 0,
|
timeKye: 0,
|
||||||
usedKye: 0,
|
usedKye: 0,
|
||||||
@ -275,7 +276,7 @@ export default {
|
|||||||
break;
|
break;
|
||||||
default:// 固定单价
|
default:// 固定单价
|
||||||
if (!this.form.singlePrice) {
|
if (!this.form.singlePrice) {
|
||||||
this.$modal.msgError('单价有误请检查1,请检查')
|
this.$modal.msgError('单价有误请检查,请检查')
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -321,6 +322,7 @@ export default {
|
|||||||
},
|
},
|
||||||
formClear() {
|
formClear() {
|
||||||
this.$refs.form.resetFields()
|
this.$refs.form.resetFields()
|
||||||
|
this.form.singlePrice = 0
|
||||||
this.isEdit = false
|
this.isEdit = false
|
||||||
this.timeKye = 0
|
this.timeKye = 0
|
||||||
this.usedKye = 0
|
this.usedKye = 0
|
||||||
|
@ -47,7 +47,7 @@
|
|||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="消耗量阈值" prop="limitValue">
|
<el-form-item label="消耗量阈值" prop="limitValue">
|
||||||
<el-input v-model="form.limitValue"></el-input>
|
<el-input-number v-model="form.limitValue" :min="0" :max="10000000000000000" style="width: 100%;"></el-input-number>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
</template>
|
</template>
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="app-container">
|
<div class="app-container" id='energyReportBox'>
|
||||||
|
|
||||||
<!-- 搜索工作栏 -->
|
<!-- 搜索工作栏 -->
|
||||||
<search-bar
|
<search-bar
|
||||||
:formConfigs="formConfig"
|
:formConfigs="formConfig"
|
||||||
ref="searchBarForm"
|
ref="searchBarForm"
|
||||||
|
:isFold="isFold"
|
||||||
@headBtnClick="buttonClick"
|
@headBtnClick="buttonClick"
|
||||||
/>
|
/>
|
||||||
<!-- 列表 -->
|
<!-- 列表 -->
|
||||||
@ -72,6 +73,7 @@ export default {
|
|||||||
name: "EnergyLimit",
|
name: "EnergyLimit",
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
isFold: false,
|
||||||
formConfig: [
|
formConfig: [
|
||||||
{
|
{
|
||||||
type: 'select',
|
type: 'select',
|
||||||
@ -138,10 +140,14 @@ export default {
|
|||||||
created() {
|
created() {
|
||||||
window.addEventListener('resize', () => {
|
window.addEventListener('resize', () => {
|
||||||
this.tableH = this.tableHeight(260)
|
this.tableH = this.tableHeight(260)
|
||||||
|
this.isFold = this.searchBarWidth('energyReportBox', 1198)
|
||||||
})
|
})
|
||||||
this.getList()
|
this.getList()
|
||||||
this.getTypeList()
|
this.getTypeList()
|
||||||
},
|
},
|
||||||
|
mounted() {
|
||||||
|
this.isFold = this.searchBarWidth('energyReportBox', 1198)
|
||||||
|
},
|
||||||
methods: {
|
methods: {
|
||||||
getTypeList() {
|
getTypeList() {
|
||||||
getEnergyTypeListAll().then((res) => {
|
getEnergyTypeListAll().then((res) => {
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="app-container">
|
<div class="app-container" id='energyReportSearchBox'>
|
||||||
|
|
||||||
<!-- 搜索工作栏 -->
|
<!-- 搜索工作栏 -->
|
||||||
<search-bar
|
<search-bar
|
||||||
:formConfigs="formConfig"
|
:formConfigs="formConfig"
|
||||||
ref="searchBarForm"
|
ref="searchBarForm"
|
||||||
|
:isFold="isFold"
|
||||||
@headBtnClick="buttonClick"
|
@headBtnClick="buttonClick"
|
||||||
/>
|
/>
|
||||||
<!-- 列表 -->
|
<!-- 列表 -->
|
||||||
@ -53,6 +54,7 @@ export default {
|
|||||||
name: "EnergyReportSearch",
|
name: "EnergyReportSearch",
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
isFold: false,
|
||||||
formConfig: [
|
formConfig: [
|
||||||
{
|
{
|
||||||
type: 'input',
|
type: 'input',
|
||||||
@ -117,13 +119,21 @@ export default {
|
|||||||
created() {
|
created() {
|
||||||
window.addEventListener('resize', () => {
|
window.addEventListener('resize', () => {
|
||||||
this.tableH = this.tableHeight(260)
|
this.tableH = this.tableHeight(260)
|
||||||
|
this.isFold = this.searchBarWidth('energyReportSearchBox', 1180)
|
||||||
})
|
})
|
||||||
this.formConfig[2].defaultSelect = [Date.now() - 7*24*3600000, Date.now()]
|
if (this.$route.params.startTime && this.$route.params.endTime) {
|
||||||
|
this.formConfig[2].defaultSelect = [this.$route.params.startTime, this.$route.params.endTime]
|
||||||
|
} else {
|
||||||
|
this.formConfig[2].defaultSelect = [Date.now() - 7*24*3600000, Date.now()]
|
||||||
|
}
|
||||||
this.queryParams.startTime = this.formConfig[2].defaultSelect[0]
|
this.queryParams.startTime = this.formConfig[2].defaultSelect[0]
|
||||||
this.queryParams.endTime = this.formConfig[2].defaultSelect[1]
|
this.queryParams.endTime = this.formConfig[2].defaultSelect[1]
|
||||||
this.getList()
|
this.getList()
|
||||||
this.getTypeList()
|
this.getTypeList()
|
||||||
},
|
},
|
||||||
|
mounted() {
|
||||||
|
this.isFold = this.searchBarWidth('energyReportSearchBox', 1180)
|
||||||
|
},
|
||||||
methods: {
|
methods: {
|
||||||
getTypeList() {
|
getTypeList() {
|
||||||
getEnergyTypeListAll().then((res) => {
|
getEnergyTypeListAll().then((res) => {
|
||||||
|
@ -75,7 +75,7 @@ export default {
|
|||||||
{
|
{
|
||||||
type: 'input',
|
type: 'input',
|
||||||
label: '参数名称',
|
label: '参数名称',
|
||||||
placeholder: '方案名称',
|
placeholder: '参数名称',
|
||||||
param: 'paramName'
|
param: 'paramName'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -46,7 +46,7 @@
|
|||||||
format='HH:mm'
|
format='HH:mm'
|
||||||
value-format='HH:mm'
|
value-format='HH:mm'
|
||||||
style="width: 100%;"
|
style="width: 100%;"
|
||||||
@change="timeFun"
|
@change="timeFun('start')"
|
||||||
>
|
>
|
||||||
</el-time-picker>
|
</el-time-picker>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
@ -58,7 +58,7 @@
|
|||||||
format='HH:mm'
|
format='HH:mm'
|
||||||
value-format='HH:mm'
|
value-format='HH:mm'
|
||||||
style="width: 100%;"
|
style="width: 100%;"
|
||||||
@change="timeFun"
|
@change="timeFun('end')"
|
||||||
>
|
>
|
||||||
</el-time-picker>
|
</el-time-picker>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
@ -126,12 +126,19 @@ export default {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
timeFun() {
|
timeFun(val) {
|
||||||
if (this.form.startTime && this.form.endTime) {
|
if (this.form.startTime && this.form.endTime) {
|
||||||
if (this.form.startTime > this.form.endTime) {
|
if (this.form.startTime > this.form.endTime) {
|
||||||
this.form.daySpan = 1
|
this.form.daySpan = 1
|
||||||
} else {
|
} else if (this.form.startTime < this.form.endTime) {
|
||||||
this.form.daySpan = 0
|
this.form.daySpan = 0
|
||||||
|
} else {
|
||||||
|
if (val === 'start') {
|
||||||
|
this.form.startTime = ''
|
||||||
|
} else {
|
||||||
|
this.form.endTime = ''
|
||||||
|
}
|
||||||
|
this.$modal.msgWarning('班次开始时间和结束时间不能相同')
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -116,7 +116,17 @@ export default {
|
|||||||
: undefined,
|
: undefined,
|
||||||
{
|
{
|
||||||
type: 'cancel',
|
type: 'cancel',
|
||||||
btnName: '作废'
|
btnName: '作废',
|
||||||
|
showParam: {
|
||||||
|
type: '&',
|
||||||
|
data: [
|
||||||
|
{
|
||||||
|
type: 'unequal',
|
||||||
|
name: 'status',
|
||||||
|
value: '不可用'
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
},
|
},
|
||||||
this.$auth.hasPermi('base:group-classes:delete')
|
this.$auth.hasPermi('base:group-classes:delete')
|
||||||
? {
|
? {
|
||||||
@ -225,8 +235,9 @@ export default {
|
|||||||
},
|
},
|
||||||
/** 删除按钮操作 */
|
/** 删除按钮操作 */
|
||||||
handleDelete(row) {
|
handleDelete(row) {
|
||||||
if (row.status) {
|
console.log(row)
|
||||||
let _this = this
|
let _this = this
|
||||||
|
if (row.status === '可用') {// 可用
|
||||||
_this.$modal.confirm('删除的班次"' + row.name + '"可能会影响交接班计划,请点取消再次确认!').then(function() {
|
_this.$modal.confirm('删除的班次"' + row.name + '"可能会影响交接班计划,请点取消再次确认!').then(function() {
|
||||||
return _this.$modal.confirm('是否确认删除班次名称为"' + row.name + '"的数据项?').then(function() {
|
return _this.$modal.confirm('是否确认删除班次名称为"' + row.name + '"的数据项?').then(function() {
|
||||||
return deleteGroupClasses(row.id);
|
return deleteGroupClasses(row.id);
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
<el-input v-model="form.code" disabled></el-input>
|
<el-input v-model="form.code" disabled></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="班组人数" prop="num">
|
<el-form-item label="班组人数" prop="num">
|
||||||
<el-input v-model="form.num"></el-input>
|
<el-input-number v-model="form.num" :min="1" :max="99999999" style="width: 100%;"></el-input-number>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="班组组长" prop="leaderName">
|
<el-form-item label="班组组长" prop="leaderName">
|
||||||
<el-input v-model="form.leaderName"></el-input>
|
<el-input v-model="form.leaderName"></el-input>
|
||||||
|
@ -1,67 +1,466 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="app-container">
|
<div class="groupTeamScheduling">
|
||||||
<div>
|
<div class="operationArea">
|
||||||
<el-form :inline="true" class="demo-form-inline">
|
<el-form :inline="true" class="demo-form-inline">
|
||||||
|
<span class="blue-block"></span>
|
||||||
<el-form-item label="月份选择">
|
<el-form-item label="月份选择">
|
||||||
<el-date-picker
|
<el-date-picker
|
||||||
v-model="queryParams.startDay"
|
v-model="startDay"
|
||||||
type="month"
|
type="month"
|
||||||
placeholder="选择月">
|
placeholder="选择月"
|
||||||
|
size="small"
|
||||||
|
:disabled="showSetting"
|
||||||
|
@change="selectMonth"
|
||||||
|
:clearable="false"
|
||||||
|
style="width: 120px">
|
||||||
</el-date-picker>
|
</el-date-picker>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item>
|
<el-form-item>
|
||||||
<el-button type="primary">自动排班</el-button>
|
<span class="separateStyle"></span>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item>
|
<el-form-item>
|
||||||
<el-button type="primary">编辑</el-button>
|
<el-button type="primary" size="small" :disabled="showSetting || settingBtnDis" @click="settingMsg">设置</el-button>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item>
|
<el-form-item>
|
||||||
<el-button type="primary" plain @click="toUpperLower">班组上下片查询</el-button>
|
<el-button type="primary" size="small" v-show="showSetting && autoScheduling" @click="schedulingBtn">自动排班</el-button>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item>
|
<el-form-item>
|
||||||
<el-button type="primary" plain>班组能源查询</el-button>
|
<span class="separateStyle" v-show="showSetting"></span>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item>
|
<el-form-item>
|
||||||
<el-button type="primary" plain>班组检测查询</el-button>
|
<el-button type="primary" size="small" v-show="showSetting" @click="confirmSetting">确认</el-button>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item>
|
||||||
|
<el-button type="primary" size="small" plain v-show="showSetting" @click="cancelSetting">取消</el-button>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="请先选择查询的班组" class="rightItem">
|
||||||
|
<el-button type="primary" size="small" :disabled="jumpDisabled" @click="toOtherPage('1')">班组上下片查询</el-button>
|
||||||
|
<el-button type="primary" size="small" :disabled="jumpDisabled" @click="toOtherPage('2')">班组能源查询</el-button>
|
||||||
|
<el-button type="primary" size="small" :disabled="jumpDisabled" @click="toOtherPage('3')">班组检测查询</el-button>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
</div>
|
</div>
|
||||||
<!-- 班组上下片查询 -->
|
<!-- 日历区域 -->
|
||||||
<group-upper-lower v-if="upperLowerVisible" ref="upperLowerParam"></group-upper-lower>
|
<div class="calenderArea">
|
||||||
|
<div style="font-size: 24px;font-weight: 500">{{ this.month }} {{ this.year }}</div>
|
||||||
|
<el-calendar v-model="startDay">
|
||||||
|
<!-- 这里使用的是 2.5 slot 语法,对于新项目请使用 2.6 slot 语法-->
|
||||||
|
<template
|
||||||
|
slot="dateCell"
|
||||||
|
slot-scope="{date, data}">
|
||||||
|
<div v-if="data.type === 'current-month'">
|
||||||
|
<!-- 日期 -->
|
||||||
|
<div class="dateStyle">
|
||||||
|
{{ Number(data.day.split('-')[2]) }}
|
||||||
|
</div>
|
||||||
|
<!-- 班次班组 -->
|
||||||
|
<!-- class有两个样式,一个是类似class1,还有个是选中红框显示 -->
|
||||||
|
<el-row :gutter="2" :class="'class' + (index+1) + (chooseTip === (item.startDay+item.classesId) ? ' team-active' : '')" v-for="(item, index) in list[Number(data.day.split('-')[2])]" :key='index'>
|
||||||
|
<el-col :span="12">
|
||||||
|
<div class="selectDiv">
|
||||||
|
<!-- 选择班组图标 -->
|
||||||
|
<div class="toggle-icon" v-show="showSetting && (new Date(data.day).valueOf() < new Date().valueOf() ? false: true)">
|
||||||
|
<svg-icon icon-class="toggle"/>
|
||||||
|
</div>
|
||||||
|
<!-- 不能选择班组 -->
|
||||||
|
<div class="toggle-icon-hide" v-show="!(showSetting && (new Date(data.day).valueOf() < new Date().valueOf() ? false: true))"></div>
|
||||||
|
<el-select v-model="item.teamId" size='small' :disabled="!showSetting || (new Date(data.day).valueOf() > new Date().valueOf() ? false: true)">
|
||||||
|
<el-option
|
||||||
|
v-for="i in teamList"
|
||||||
|
:key="i.id"
|
||||||
|
:label="i.name"
|
||||||
|
:value="i.id">
|
||||||
|
</el-option>
|
||||||
|
</el-select>
|
||||||
|
</div>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-button class="labelClass" @click="chooseTeam(item)">{{ item.classesName }}</el-button>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-calendar>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import { createGroupTeamScheduling } from "@/api/base/groupTeamScheduling";
|
import { getPreset, createOrUpdateList, autoSet } from "@/api/base/groupTeamScheduling";
|
||||||
import GroupUpperLower from "./components/groupUpperLower.vue"
|
import { listEnabled } from "@/api/base/groupTeam";
|
||||||
|
import moment from 'moment';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: "GroupTeamScheduling",
|
name: "GroupTeamScheduling",
|
||||||
components: { GroupUpperLower },
|
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
monthList: [
|
startDay: '',// 查询参数
|
||||||
{id: ''}
|
year: '',// 2023
|
||||||
],
|
month: '',// 九月
|
||||||
// 查询参数
|
monthList: ["一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","十二月"],
|
||||||
queryParams: {
|
list: {},
|
||||||
pageNo: 1,
|
teamList: [],// 班组下拉
|
||||||
pageSize: 10
|
showSetting: false,// 设置模式。自动排班,确认,取消按钮显示
|
||||||
},
|
settingBtnDis: false,
|
||||||
upperLowerVisible: false
|
jumpDisabled: true,// 操作按钮控制
|
||||||
|
chooseObj: {}, //当前选中的数据,查询按钮用
|
||||||
|
chooseTip: '',// 当前选中数据的唯一值,显示红框
|
||||||
|
autoScheduling: false // 只有在当前日期后的月份才生效
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
created() {
|
created() {
|
||||||
|
this.startDay = new Date()
|
||||||
|
// 设置按钮是否置灰
|
||||||
|
this.settingBtn()
|
||||||
|
this.getTeamList()
|
||||||
|
this.toggleMonth()
|
||||||
this.getList()
|
this.getList()
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
getList() {},
|
// 切换月份
|
||||||
toUpperLower() {
|
selectMonth() {
|
||||||
this.upperLowerVisible = true
|
if (this.startDay) {
|
||||||
this.$nextTick(() => {
|
this.settingBtn() // 设置按钮状态,需在getlist前面
|
||||||
this.$refs.upperLowerParam.init()
|
this.toggleMonth()
|
||||||
|
this.getList()
|
||||||
|
this.clearChoose()
|
||||||
|
if ( moment(this.startDay).valueOf() > moment().endOf('month').valueOf()) {
|
||||||
|
this.autoScheduling = true
|
||||||
|
} else {
|
||||||
|
this.autoScheduling = false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
// 获取班组列表
|
||||||
|
getTeamList() {
|
||||||
|
listEnabled().then(res => {
|
||||||
|
this.teamList = res.data || []
|
||||||
})
|
})
|
||||||
|
},
|
||||||
|
// 获取日历数据
|
||||||
|
getList() {
|
||||||
|
let year = moment(this.startDay).format('YYYY')
|
||||||
|
let month = moment(this.startDay).format('M')
|
||||||
|
getPreset({
|
||||||
|
year: year,
|
||||||
|
month: month
|
||||||
|
}).then(res => {
|
||||||
|
let obj = res.data || {}
|
||||||
|
if (obj) {
|
||||||
|
for (let item in obj) {
|
||||||
|
for (let i = 0; i < obj[item].length; i++) {
|
||||||
|
if (!obj[item][i].teamId) {
|
||||||
|
obj[item][i].teamId = ''
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.list = obj
|
||||||
|
}).catch(() => {
|
||||||
|
this.list = {}
|
||||||
|
this.settingBtnDis = true // 禁用设置按钮
|
||||||
|
})
|
||||||
|
},
|
||||||
|
// 设置
|
||||||
|
settingMsg() {
|
||||||
|
this.showSetting = !this.showSetting
|
||||||
|
this.clearChoose()
|
||||||
|
},
|
||||||
|
// 取消
|
||||||
|
cancelSetting() {
|
||||||
|
this.showSetting = !this.showSetting
|
||||||
|
this.getList() // 数据还原
|
||||||
|
},
|
||||||
|
// 确认
|
||||||
|
confirmSetting() {
|
||||||
|
let num = 0
|
||||||
|
// 当月数据的话,今天及今天之前的不传
|
||||||
|
if (moment(this.startDay).format('YYYY-MM') === moment().format('YYYY-MM')) {
|
||||||
|
num = Number(moment().format('DD'))
|
||||||
|
} else {
|
||||||
|
num = 0
|
||||||
|
}
|
||||||
|
// 下月数据全部都传
|
||||||
|
// 打平数据
|
||||||
|
let tempArr = Object.values(this.list)
|
||||||
|
let arr = []
|
||||||
|
for (let i = num; i < tempArr.length; i++) {
|
||||||
|
for (let j = 0; j < tempArr[i].length; j++) {
|
||||||
|
arr.push(tempArr[i][j])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
createOrUpdateList(arr).then(res => {
|
||||||
|
if (res.code === 0) {
|
||||||
|
this.showSetting = !this.showSetting
|
||||||
|
this.$modal.msgSuccess("操作成功")
|
||||||
|
this.getList() // 数据更新
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
|
// 点击班次红框选中当前数据
|
||||||
|
chooseTeam(value) {
|
||||||
|
if (this.showSetting) {
|
||||||
|
this.$modal.msgWarning("当前处于设置模式")
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
this.chooseObj = value
|
||||||
|
this.chooseTip = value.startDay + value.classesId // 匹配当前的样式
|
||||||
|
this.jumpDisabled = false //查询按钮不禁用
|
||||||
|
},
|
||||||
|
// 自动排班
|
||||||
|
schedulingBtn() {
|
||||||
|
let tempData = this.list
|
||||||
|
// 次月1号有值前端排班
|
||||||
|
if (this.list[1][0].teamId) {
|
||||||
|
let tempArr = Object.values(this.list)
|
||||||
|
let arr = []
|
||||||
|
let n = 0
|
||||||
|
for (let i = 0; i < tempArr.length; i++) {
|
||||||
|
if (n > 0) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
for (let j = 0; j < tempArr[i].length; j++) {
|
||||||
|
if (tempArr[i][j].teamId) {
|
||||||
|
arr.push(tempArr[i][j].teamId)
|
||||||
|
} else {
|
||||||
|
n++
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
let tempNum = 0
|
||||||
|
for (let k = 0; k < tempArr.length; k++) {
|
||||||
|
for (let v = 0; v < tempArr[k].length; v++) {
|
||||||
|
let t = tempNum % arr.length
|
||||||
|
if (arr.length === 1) {
|
||||||
|
tempData[k+1][v].teamId = arr[0]
|
||||||
|
} else {
|
||||||
|
tempData[k+1][v].teamId = arr[t]
|
||||||
|
}
|
||||||
|
tempNum++
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.list = []
|
||||||
|
this.list = tempData
|
||||||
|
} else {
|
||||||
|
// 次月1号没有值,接口排班
|
||||||
|
autoSet().then(res => {
|
||||||
|
this.list = res.data || {}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
},
|
||||||
|
// 设置按钮如果是上个月或者今天是本月最后一天,设置按钮置灰
|
||||||
|
settingBtn() {
|
||||||
|
let nowMonth = moment().startOf('month').valueOf()
|
||||||
|
let startMonth = moment(this.startDay).valueOf()
|
||||||
|
let nowDate = moment(new Date()).date()
|
||||||
|
let sumDate = moment().daysInMonth()
|
||||||
|
if (nowMonth > startMonth) { // 之前月
|
||||||
|
this.settingBtnDis = true
|
||||||
|
} else {
|
||||||
|
if (nowDate < sumDate) {
|
||||||
|
this.settingBtnDis = false
|
||||||
|
} else {
|
||||||
|
this.settingBtnDis = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
// 清除红框选中数据
|
||||||
|
clearChoose() {
|
||||||
|
this.chooseObj = {}
|
||||||
|
this.chooseTip = ""
|
||||||
|
this.jumpDisabled = true
|
||||||
|
},
|
||||||
|
// 切换月份显示
|
||||||
|
toggleMonth() {
|
||||||
|
this.year = moment(this.startDay).format("YYYY")
|
||||||
|
let month = Number(moment(this.startDay).format("MM"))
|
||||||
|
this.month = this.monthList[month - 1]
|
||||||
|
},
|
||||||
|
// 3个跳转按钮
|
||||||
|
toOtherPage(val) {
|
||||||
|
switch (val) {
|
||||||
|
case '1':
|
||||||
|
this.$router.push({
|
||||||
|
// path: '/core/monitoring/production-line-data',
|
||||||
|
name: 'ProductionLineData',
|
||||||
|
params: { startTime: this.chooseObj.startTime, endTime: this.chooseObj.endTime }
|
||||||
|
})
|
||||||
|
break;
|
||||||
|
case '2': // 能源
|
||||||
|
this.$router.push({
|
||||||
|
name: 'EnergyReportSearch',
|
||||||
|
params: { startTime: this.chooseObj.startTime, endTime: this.chooseObj.endTime }
|
||||||
|
})
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
this.$router.push({
|
||||||
|
// path: '/quality/monitoring/quality-statistics',
|
||||||
|
name: 'QualityStatistics',
|
||||||
|
params: { startTime: this.chooseObj.startTime, endTime: this.chooseObj.endTime }
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
|
||||||
</script>
|
</script>
|
||||||
|
<style lang='scss'>
|
||||||
|
.groupTeamScheduling {
|
||||||
|
background-color: #F2F4F9;
|
||||||
|
.operationArea {
|
||||||
|
padding: 14px 10px 0 16px;
|
||||||
|
margin-bottom: 8px;
|
||||||
|
background-color: #fff;
|
||||||
|
border-radius: 8px;
|
||||||
|
.blue-block {
|
||||||
|
display: inline-block;
|
||||||
|
width: 4px;
|
||||||
|
height: 16px;
|
||||||
|
background-color: #0B58FF;
|
||||||
|
border-radius: 1px;
|
||||||
|
margin-right: 8px;
|
||||||
|
margin-top: 10px;
|
||||||
|
}
|
||||||
|
.separateStyle {
|
||||||
|
display: inline-block;
|
||||||
|
width: 1px;
|
||||||
|
height: 24px;
|
||||||
|
background: #E8E8E8;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
.el-form-item {
|
||||||
|
margin-bottom: 10px;
|
||||||
|
}
|
||||||
|
.rightItem {
|
||||||
|
float: right;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// 日历
|
||||||
|
.calenderArea {
|
||||||
|
padding: 14px 10px 0 20px;
|
||||||
|
background-color: #fff;
|
||||||
|
border-radius: 8px;
|
||||||
|
.el-calendar__body {
|
||||||
|
padding: 10px 16px 16px 0;
|
||||||
|
}
|
||||||
|
.el-calendar__header {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.el-calendar-table > thead {
|
||||||
|
height: 48px;
|
||||||
|
font-size: 20px;
|
||||||
|
font-weight: 500;
|
||||||
|
color: #000000;
|
||||||
|
background-color: rgba(242, 244, 249, 1);
|
||||||
|
}
|
||||||
|
.el-calendar-table__row {
|
||||||
|
height: 133px;
|
||||||
|
.prev, .next {
|
||||||
|
pointer-events: none;
|
||||||
|
}
|
||||||
|
.el-calendar-day {
|
||||||
|
padding: 0 10px;
|
||||||
|
height: 100%;
|
||||||
|
.dateStyle {
|
||||||
|
font-size: 20px;
|
||||||
|
font-weight: 500;
|
||||||
|
color: #000000;
|
||||||
|
text-align: right;
|
||||||
|
height: 32px;
|
||||||
|
line-height: 28px;
|
||||||
|
padding-right: 10px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.team-active {// 选中班组
|
||||||
|
border:2px solid red
|
||||||
|
}
|
||||||
|
.class1, .class2, .class3 {
|
||||||
|
padding: 0;
|
||||||
|
font-weight: 600;
|
||||||
|
margin-bottom: 2px;
|
||||||
|
.selectDiv {
|
||||||
|
position: relative;
|
||||||
|
.toggle-icon {
|
||||||
|
position: absolute;
|
||||||
|
width: 26px;
|
||||||
|
height: 26px;
|
||||||
|
line-height: 26px;
|
||||||
|
font-size: 14px;
|
||||||
|
z-index: 1;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.toggle-icon-hide {
|
||||||
|
position: absolute;
|
||||||
|
width: 2px;
|
||||||
|
height: 28px;
|
||||||
|
z-index: 1;
|
||||||
|
}
|
||||||
|
.el-input__suffix {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.el-input--suffix .el-input__inner {
|
||||||
|
padding: 0 4px 0 28px;
|
||||||
|
}
|
||||||
|
.el-input--small .el-input__inner {
|
||||||
|
height: 28px;
|
||||||
|
border: none;
|
||||||
|
font-weight: 600;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.labelClass {
|
||||||
|
width: 100%;
|
||||||
|
height: 28px;
|
||||||
|
border: none;
|
||||||
|
padding: 0;
|
||||||
|
font-weight: 600;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.class1 {
|
||||||
|
.selectDiv {
|
||||||
|
.toggle-icon, .toggle-icon-hide {
|
||||||
|
background-color: #FACE00;
|
||||||
|
}
|
||||||
|
.el-input--small .el-input__inner {
|
||||||
|
color: #E7A200;
|
||||||
|
background-color: #FFEFC0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.labelClass {
|
||||||
|
color: #E7A200;
|
||||||
|
background-color: #FFEFC0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.class2 {
|
||||||
|
.selectDiv {
|
||||||
|
.toggle-icon, .toggle-icon-hide {
|
||||||
|
background-color: #3984FF;
|
||||||
|
}
|
||||||
|
.el-input--small .el-input__inner {
|
||||||
|
color: #2D7BFF;
|
||||||
|
background-color: #BEEAFF;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.labelClass {
|
||||||
|
color: #2D7BFF;
|
||||||
|
background-color: #BEEAFF;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.class3 {
|
||||||
|
.selectDiv {
|
||||||
|
.toggle-icon, .toggle-icon-hide {
|
||||||
|
background-color: #37D97F;
|
||||||
|
}
|
||||||
|
.el-input--small .el-input__inner {
|
||||||
|
color: #129F51;
|
||||||
|
background-color: #E0FFEE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.labelClass {
|
||||||
|
color: #129F51;
|
||||||
|
background-color: #E0FFEE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
@ -67,6 +67,7 @@ export default {
|
|||||||
rangeSeparator: '-',
|
rangeSeparator: '-',
|
||||||
startPlaceholder: '开始日期',
|
startPlaceholder: '开始日期',
|
||||||
endPlaceholder: '结束日期',
|
endPlaceholder: '结束日期',
|
||||||
|
defaultSelect: [],
|
||||||
defaultTime: ['00:00:00', '23:59:59'],
|
defaultTime: ['00:00:00', '23:59:59'],
|
||||||
param: 'timerange',
|
param: 'timerange',
|
||||||
},
|
},
|
||||||
@ -212,6 +213,14 @@ export default {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
mounted() {
|
mounted() {
|
||||||
|
if (this.$route.params.startTime && this.$route.params.endTime) {
|
||||||
|
this.searchBarFormConfig[0].defaultSelect = [this.$route.params.startTime, this.$route.params.endTime]
|
||||||
|
this.queryParams.param = {};
|
||||||
|
this.$set(this.queryParams.param, 'startTime', this.$route.params.startTime);
|
||||||
|
this.$set(this.queryParams.param, 'endTime', this.$route.params.endTime);
|
||||||
|
} else {
|
||||||
|
this.searchBarFormConfig[0].defaultSelect = []
|
||||||
|
}
|
||||||
this.getList();
|
this.getList();
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
Loading…
Reference in New Issue
Block a user