2021-06-21 11:29:26 +08:00
|
|
|
|
<template>
|
2023-05-15 10:46:12 +08:00
|
|
|
|
<div v-ele-click-outside="changeDropdown" style="position: relative;" class="date-range-box">
|
|
|
|
|
|
<div @click="showDropdown" class="date-range-text" :class="myClass" :style="style">
|
2022-07-15 18:06:50 +08:00
|
|
|
|
<div class="calendar-popover-text"><i class="cn-icon cn-icon-Data"></i></div>
|
2021-07-09 21:58:49 +08:00
|
|
|
|
<div class="calendar-popover-text" style="display: flex" v-if="isCustom">
|
2022-10-12 22:58:16 +08:00
|
|
|
|
<div class="calendar-popover-text">{{ dateFormatByAppearance(getMillisecond(startTime)) }}</div>
|
2021-07-09 21:58:49 +08:00
|
|
|
|
<div class="calendar-popover-text"> -</div>
|
2022-10-12 22:58:16 +08:00
|
|
|
|
<div class="calendar-popover-text">{{ dateFormatByAppearance(getMillisecond(endTime)) }}</div>
|
2021-07-09 21:58:49 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
<div class="calendar-popover-text" v-else>
|
|
|
|
|
|
{{ showDetail }}
|
|
|
|
|
|
</div>
|
2022-10-19 15:27:26 +08:00
|
|
|
|
<div class="calendar-popover-text calendar-popover__small">
|
|
|
|
|
|
<i class="cn-icon cn-icon-dropdown" :class="dropdownFlag ? 'cn-icon-up' : ''"></i>
|
|
|
|
|
|
</div>
|
2021-07-09 21:58:49 +08:00
|
|
|
|
</div>
|
2023-05-15 10:46:12 +08:00
|
|
|
|
<transition name="el-zoom-in-top" style="z-index: 4;">
|
2021-07-09 21:58:49 +08:00
|
|
|
|
<div v-if="dropdownFlag" class="date-range-panel">
|
|
|
|
|
|
<el-row class="date-range-panel-top" style="position: relative">
|
|
|
|
|
|
<el-col :span="16" class="date-range-panel-content date-range-panel-content-left">
|
|
|
|
|
|
<div class="date-range-title" style="padding-left: 0">Absolute time range</div>
|
2022-10-26 18:59:53 +08:00
|
|
|
|
<el-date-picker
|
|
|
|
|
|
v-model="newDateValue"
|
|
|
|
|
|
ref="newDatePicker"
|
2023-05-26 16:43:57 +08:00
|
|
|
|
popper-class="my-date-picker"
|
2022-10-26 18:59:53 +08:00
|
|
|
|
style="position: absolute;top: -53px;left: -536px;"
|
|
|
|
|
|
:clearable="false"
|
2023-02-01 16:51:45 +08:00
|
|
|
|
:default-time="defaultTime"
|
2023-07-05 14:31:34 +08:00
|
|
|
|
:unlink-panels="true"
|
2021-07-09 21:58:49 +08:00
|
|
|
|
type="datetimerange"
|
|
|
|
|
|
@change="timeArrChange"
|
|
|
|
|
|
/>
|
|
|
|
|
|
<div class="content-title">From</div>
|
|
|
|
|
|
<div @click="myDatePickerShow" tabindex="1" class="content-input">
|
2022-10-12 22:58:16 +08:00
|
|
|
|
{{ dateFormatByAppearance(getMillisecond(myStartTime)) }}
|
2021-07-09 21:58:49 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
<div class="content-title">To</div>
|
|
|
|
|
|
<div @click="myDatePickerShow" tabindex="2" class="content-input">
|
2022-10-12 22:58:16 +08:00
|
|
|
|
{{ dateFormatByAppearance(getMillisecond(myEndTime)) }}
|
2021-07-09 21:58:49 +08:00
|
|
|
|
</div>
|
2022-10-26 18:59:53 +08:00
|
|
|
|
|
2021-07-09 21:58:49 +08:00
|
|
|
|
<div class="date-range-title" style="padding-left: 0">Recently used absolute ranges</div>
|
|
|
|
|
|
<div class="date-range-history">
|
|
|
|
|
|
<div v-for="(item, index) in rangeHistoryArr" :key="index" class="date-range-history-item"
|
|
|
|
|
|
@click="historyChange(item)">
|
2022-04-28 18:11:49 +08:00
|
|
|
|
{{ dateFormatByAppearance(item.start) }}
|
2021-07-09 21:58:49 +08:00
|
|
|
|
—
|
2022-04-28 18:11:49 +08:00
|
|
|
|
{{ dateFormatByAppearance(item.end) }}
|
2021-07-09 21:58:49 +08:00
|
|
|
|
</div>
|
2021-06-21 18:41:17 +08:00
|
|
|
|
</div>
|
2021-07-09 21:58:49 +08:00
|
|
|
|
</el-col>
|
2022-10-26 18:59:53 +08:00
|
|
|
|
<el-col
|
|
|
|
|
|
:span="8"
|
|
|
|
|
|
class="date-range-panel-content date-range-panel-content-right"
|
|
|
|
|
|
style="border-left: 1px solid rgba(0,0,0,0.09);">
|
2021-07-09 21:58:49 +08:00
|
|
|
|
<div class="date-range-title">Relatime time ranges</div>
|
|
|
|
|
|
<ul class="date-range-item">
|
2022-10-26 18:59:53 +08:00
|
|
|
|
<li v-for="item in dateRangeArr"
|
|
|
|
|
|
@click="quickChange(item.value)"
|
2022-10-28 14:46:04 +08:00
|
|
|
|
:class="(item.value===dateRangeValue.value || item.value===dateRangeValue)?'active':''"
|
2021-07-09 21:58:49 +08:00
|
|
|
|
:key="item.value">
|
2022-09-07 20:17:38 +08:00
|
|
|
|
<span style="position: relative">
|
|
|
|
|
|
{{ item.name }}
|
2022-10-28 14:46:04 +08:00
|
|
|
|
<i v-if="(item.value===dateRangeValue.value || item.value===dateRangeValue)"
|
2022-09-07 20:17:38 +08:00
|
|
|
|
class="cn-icon cn-icon-check"></i>
|
|
|
|
|
|
</span>
|
2021-07-09 21:58:49 +08:00
|
|
|
|
</li>
|
|
|
|
|
|
</ul>
|
|
|
|
|
|
</el-col>
|
|
|
|
|
|
</el-row>
|
2022-10-26 18:59:53 +08:00
|
|
|
|
<el-row class="date-range-panel-bottom">
|
2021-07-09 21:58:49 +08:00
|
|
|
|
<el-col :span="12">{{ address }}</el-col>
|
|
|
|
|
|
<el-col :span="12" class="utc-str">{{ utcStr }}</el-col>
|
|
|
|
|
|
</el-row>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</transition>
|
|
|
|
|
|
</div>
|
2021-06-21 11:29:26 +08:00
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<script>
|
2022-11-09 17:23:31 +08:00
|
|
|
|
import { ref, computed, watch, reactive } from 'vue'
|
2022-04-14 15:52:07 +08:00
|
|
|
|
import { storageKey } from '@/utils/constants'
|
2023-03-13 16:48:37 +08:00
|
|
|
|
import { getMillisecond, millTimestampDiffFromTz, timestampToList } from '@/utils/date-util'
|
2022-10-19 15:27:26 +08:00
|
|
|
|
import { useStore } from 'vuex'
|
2021-07-09 21:58:49 +08:00
|
|
|
|
|
2021-06-21 11:29:26 +08:00
|
|
|
|
export default {
|
|
|
|
|
|
name: 'DateTimeRange',
|
|
|
|
|
|
props: {
|
|
|
|
|
|
startTime: {
|
|
|
|
|
|
type: Number,
|
2022-12-27 10:20:36 +08:00
|
|
|
|
default: window.$dayJs.tz().valueOf() - 60 * 60 * 1000
|
2021-06-21 11:29:26 +08:00
|
|
|
|
},
|
|
|
|
|
|
endTime: {
|
|
|
|
|
|
type: Number,
|
|
|
|
|
|
default: window.$dayJs.tz().valueOf()
|
2022-04-08 11:29:44 +08:00
|
|
|
|
},
|
|
|
|
|
|
dateRange: {
|
|
|
|
|
|
type: Number
|
2023-04-27 17:56:58 +08:00
|
|
|
|
},
|
|
|
|
|
|
class: {
|
|
|
|
|
|
type: String
|
|
|
|
|
|
},
|
|
|
|
|
|
style: {
|
|
|
|
|
|
type: String
|
2021-06-21 11:29:26 +08:00
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
emits: ['change'],
|
2021-07-14 15:40:05 +08:00
|
|
|
|
setup (props, ctx) {
|
2021-06-21 11:29:26 +08:00
|
|
|
|
// data
|
2022-10-19 15:27:26 +08:00
|
|
|
|
const store = useStore()
|
2021-06-21 11:29:26 +08:00
|
|
|
|
const myStartTime = ref(props.startTime)
|
2021-06-21 18:41:17 +08:00
|
|
|
|
const myEndTime = ref(props.endTime)
|
2023-05-15 10:46:12 +08:00
|
|
|
|
const myClass = ref(props.class)
|
2022-10-26 18:59:53 +08:00
|
|
|
|
// 时间选择器绑定的值
|
|
|
|
|
|
const newDateValue = ref([
|
|
|
|
|
|
new Date(...timestampToList(myStartTime.value)),
|
|
|
|
|
|
new Date(...timestampToList(myEndTime.value))
|
|
|
|
|
|
])
|
|
|
|
|
|
// 时区地址
|
2022-04-14 15:52:07 +08:00
|
|
|
|
const address = localStorage.getItem(storageKey.sysTimezone)
|
2022-10-26 18:59:53 +08:00
|
|
|
|
// 当前所在时区
|
2022-04-14 15:52:07 +08:00
|
|
|
|
const utc = localStorage.getItem(storageKey.timezoneOffset)
|
2022-10-26 18:59:53 +08:00
|
|
|
|
// 历史选择时间
|
2022-04-14 15:52:07 +08:00
|
|
|
|
const rangeHistory = ref(localStorage.getItem(storageKey.dataRangeHistory) ? JSON.parse(localStorage.getItem(storageKey.dataRangeHistory)) : [])
|
2022-04-08 11:29:44 +08:00
|
|
|
|
const dateRangeValue = props.dateRange ? ref(props.dateRange) : ref(60)
|
2022-09-07 20:17:38 +08:00
|
|
|
|
const isCustom = ref(dateRangeValue.value === -1)
|
2021-06-22 17:07:46 +08:00
|
|
|
|
const dateRangeArr = [
|
2023-06-06 10:49:43 +08:00
|
|
|
|
{ value: 5, name: 'last 5 mins' },
|
|
|
|
|
|
{ value: 15, name: 'last 15 mins' },
|
|
|
|
|
|
{ value: 30, name: 'last 30 mins' },
|
2022-10-26 18:59:53 +08:00
|
|
|
|
{ value: 60, name: 'last 1 hour' },
|
2023-06-06 10:49:43 +08:00
|
|
|
|
{ value: 180, name: 'last 3 hours' },
|
|
|
|
|
|
{ value: 360, name: 'last 6 hours' },
|
|
|
|
|
|
{ value: 720, name: 'last 12 hours' },
|
|
|
|
|
|
{ value: 1440, name: 'last 1 day' },
|
2022-10-26 18:59:53 +08:00
|
|
|
|
{ value: 2880, name: 'last 2 days' }
|
2021-06-22 17:07:46 +08:00
|
|
|
|
]
|
2021-06-21 11:29:26 +08:00
|
|
|
|
const dropdownFlag = ref(false)
|
2023-02-01 16:51:45 +08:00
|
|
|
|
// 默认日历选择时间,即开始时间YYYY-MM-DD 00:00:00,结束时间YYYY-MM-DD 59:59:59
|
|
|
|
|
|
const defaultTime = ref([
|
|
|
|
|
|
new Date(2023, 1, 1, 0, 0, 0),
|
|
|
|
|
|
new Date(2023, 1, 2, 23, 59, 59)
|
|
|
|
|
|
])
|
2022-10-26 18:59:53 +08:00
|
|
|
|
|
2021-06-21 18:41:17 +08:00
|
|
|
|
// computed
|
|
|
|
|
|
const utcStr = computed(() => {
|
2021-06-22 17:07:46 +08:00
|
|
|
|
let str = 'UTC '
|
2021-06-21 18:41:17 +08:00
|
|
|
|
if (utc < 0) {
|
2021-06-22 17:07:46 +08:00
|
|
|
|
str += '- '
|
2021-06-21 18:41:17 +08:00
|
|
|
|
} else {
|
2021-06-22 17:07:46 +08:00
|
|
|
|
str += '+ '
|
2021-06-21 18:41:17 +08:00
|
|
|
|
}
|
|
|
|
|
|
const abs = Math.abs(utc)
|
|
|
|
|
|
if (abs > 10) {
|
|
|
|
|
|
str += abs + ''
|
|
|
|
|
|
} else {
|
|
|
|
|
|
str += '0' + (abs + '')
|
|
|
|
|
|
}
|
2021-06-22 17:07:46 +08:00
|
|
|
|
str += ':00 '
|
2021-06-21 18:41:17 +08:00
|
|
|
|
return str
|
|
|
|
|
|
})
|
2021-06-22 17:07:46 +08:00
|
|
|
|
const showDetail = computed(() => {
|
|
|
|
|
|
let str = ''
|
|
|
|
|
|
if (dateRangeValue.value !== -1) {
|
|
|
|
|
|
str = dateRangeArr.find(item => item.value === dateRangeValue.value).name
|
|
|
|
|
|
}
|
|
|
|
|
|
return str
|
|
|
|
|
|
})
|
2022-10-26 18:59:53 +08:00
|
|
|
|
const rangeHistoryArr = rangeHistory
|
|
|
|
|
|
|
2021-06-21 18:41:17 +08:00
|
|
|
|
// refs
|
2022-10-26 18:59:53 +08:00
|
|
|
|
const newDatePicker = ref(null)
|
|
|
|
|
|
|
2022-11-09 17:23:31 +08:00
|
|
|
|
// echarts框选时间范围
|
|
|
|
|
|
const rangeEchartsData = reactive({
|
|
|
|
|
|
value: computed(() => store.state.panel.rangeEchartsData)
|
|
|
|
|
|
})
|
|
|
|
|
|
|
2023-04-27 15:47:07 +08:00
|
|
|
|
watch(() => rangeEchartsData.value, (newVal) => {
|
2022-11-09 17:23:31 +08:00
|
|
|
|
if (newVal) {
|
|
|
|
|
|
myStartTime.value = getMillisecond(newVal.startTime)
|
|
|
|
|
|
myEndTime.value = getMillisecond(newVal.endTime)
|
|
|
|
|
|
isCustom.value = true
|
|
|
|
|
|
dateRangeValue.value = -1
|
|
|
|
|
|
returnValue()
|
|
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
|
2021-06-21 11:29:26 +08:00
|
|
|
|
// methods
|
2022-10-26 18:59:53 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* 打开/关闭时间面板
|
|
|
|
|
|
*/
|
2021-06-21 11:29:26 +08:00
|
|
|
|
const showDropdown = () => {
|
|
|
|
|
|
dropdownFlag.value = !dropdownFlag.value
|
2021-06-21 18:41:17 +08:00
|
|
|
|
if (dropdownFlag.value) {
|
|
|
|
|
|
myStartTime.value = props.startTime
|
|
|
|
|
|
myEndTime.value = props.endTime
|
|
|
|
|
|
}
|
2021-06-21 11:29:26 +08:00
|
|
|
|
}
|
2022-10-26 18:59:53 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* 点击空白处隐藏时间面板
|
|
|
|
|
|
*/
|
2021-06-21 11:29:26 +08:00
|
|
|
|
const changeDropdown = () => {
|
2021-06-21 18:41:17 +08:00
|
|
|
|
if (dropdownFlag.value) {
|
2021-06-21 11:29:26 +08:00
|
|
|
|
dropdownFlag.value = false
|
|
|
|
|
|
}
|
2021-06-21 18:41:17 +08:00
|
|
|
|
if (dropdownFlag.value) {
|
|
|
|
|
|
dropdownFlag.value = false
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2022-10-26 18:59:53 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* 打开时间选择器,从时间面板的“开始时间”、“结束时间”调用
|
|
|
|
|
|
*/
|
2021-06-21 18:41:17 +08:00
|
|
|
|
const myDatePickerShow = () => {
|
2022-10-26 18:59:53 +08:00
|
|
|
|
newDateValue.value = [
|
|
|
|
|
|
new Date(...timestampToList(myStartTime.value)),
|
|
|
|
|
|
new Date(...timestampToList(myEndTime.value))
|
|
|
|
|
|
]
|
|
|
|
|
|
newDatePicker.value.focus()
|
2021-06-21 18:41:17 +08:00
|
|
|
|
}
|
2022-10-26 18:59:53 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* 时间选择器,选择时间,点击OK后的回调
|
|
|
|
|
|
* @param val,开始/结束时间数组
|
|
|
|
|
|
*/
|
2021-06-21 18:41:17 +08:00
|
|
|
|
const timeArrChange = (val) => {
|
2023-03-13 16:48:37 +08:00
|
|
|
|
// 按服务器时区修正时间戳
|
|
|
|
|
|
myStartTime.value = getMillisecond(val[0]) + millTimestampDiffFromTz()
|
|
|
|
|
|
myEndTime.value = getMillisecond(val[1]) + millTimestampDiffFromTz()
|
2021-06-21 18:41:17 +08:00
|
|
|
|
isCustom.value = true
|
2021-06-21 19:15:22 +08:00
|
|
|
|
dateRangeValue.value = -1
|
2021-06-21 18:41:17 +08:00
|
|
|
|
returnValue()
|
|
|
|
|
|
}
|
2022-10-26 18:59:53 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* 历史时间列表中点击一项,对时间进行赋值
|
|
|
|
|
|
* @param item
|
|
|
|
|
|
*/
|
2021-06-22 17:07:46 +08:00
|
|
|
|
const historyChange = (item) => {
|
|
|
|
|
|
myStartTime.value = item.start
|
|
|
|
|
|
myEndTime.value = item.end
|
|
|
|
|
|
isCustom.value = true
|
|
|
|
|
|
dateRangeValue.value = -1
|
|
|
|
|
|
returnValue()
|
|
|
|
|
|
}
|
2021-06-21 18:41:17 +08:00
|
|
|
|
const quickChange = (value) => {
|
2021-06-21 19:15:22 +08:00
|
|
|
|
dateRangeValue.value = value
|
2021-06-21 18:41:17 +08:00
|
|
|
|
isCustom.value = false
|
|
|
|
|
|
myEndTime.value = window.$dayJs.tz().valueOf()
|
|
|
|
|
|
myStartTime.value = myEndTime.value - value * 60 * 1000
|
|
|
|
|
|
returnValue()
|
|
|
|
|
|
}
|
2022-10-26 18:59:53 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* 重置时间,将时间存入缓存,并触发方法请求接口刷新界面
|
|
|
|
|
|
*/
|
2021-06-21 18:41:17 +08:00
|
|
|
|
const returnValue = () => {
|
2023-07-03 11:21:21 +08:00
|
|
|
|
store.commit('setTimeFilter', { startTime: myStartTime.value, endTime: myEndTime.value, range: dateRangeValue.value })
|
2022-10-19 15:27:26 +08:00
|
|
|
|
cancelHttp()
|
2023-09-21 11:18:35 +08:00
|
|
|
|
if (rangeHistory.value[0] && rangeHistory.value[0].start !== myStartTime.value && rangeHistory.value[0].end !== myEndTime.value) {
|
|
|
|
|
|
rangeHistory.value.unshift({
|
|
|
|
|
|
start: myStartTime.value,
|
|
|
|
|
|
end: myEndTime.value
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
if (!rangeHistory.value[0]) {
|
|
|
|
|
|
rangeHistory.value.unshift({
|
|
|
|
|
|
start: myStartTime.value,
|
|
|
|
|
|
end: myEndTime.value
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-10-26 18:59:53 +08:00
|
|
|
|
if (rangeHistory.value.length > 4) {
|
|
|
|
|
|
rangeHistory.value.splice(4, rangeHistory.value.length - 1)
|
|
|
|
|
|
}
|
2022-04-14 15:52:07 +08:00
|
|
|
|
localStorage.setItem(storageKey.dataRangeHistory, JSON.stringify(rangeHistory.value))
|
2021-06-21 18:41:17 +08:00
|
|
|
|
ctx.emit('change', myStartTime.value, myEndTime.value, dateRangeValue)
|
|
|
|
|
|
dropdownFlag.value = false
|
2021-06-21 11:29:26 +08:00
|
|
|
|
}
|
2022-10-26 18:59:53 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* 终止http请求
|
|
|
|
|
|
*/
|
2022-10-19 15:27:26 +08:00
|
|
|
|
const cancelHttp = () => {
|
|
|
|
|
|
const cancelList = store.state.panel.httpCancel
|
|
|
|
|
|
if (cancelList.length > 0) {
|
|
|
|
|
|
cancelList.forEach((cancel, index) => {
|
|
|
|
|
|
cancel()
|
|
|
|
|
|
delete cancelList[index]
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2021-06-21 11:29:26 +08:00
|
|
|
|
return {
|
|
|
|
|
|
myStartTime,
|
2021-06-21 18:41:17 +08:00
|
|
|
|
myEndTime,
|
2023-05-15 10:46:12 +08:00
|
|
|
|
myClass,
|
2021-06-21 11:29:26 +08:00
|
|
|
|
dropdownFlag,
|
2021-06-21 18:41:17 +08:00
|
|
|
|
utcStr,
|
2022-11-09 17:23:31 +08:00
|
|
|
|
rangeEchartsData,
|
2021-06-21 18:41:17 +08:00
|
|
|
|
address,
|
|
|
|
|
|
dateRangeArr,
|
2023-02-01 16:51:45 +08:00
|
|
|
|
defaultTime,
|
2021-06-21 18:41:17 +08:00
|
|
|
|
dateRangeValue,
|
|
|
|
|
|
isCustom,
|
2022-10-26 18:59:53 +08:00
|
|
|
|
newDateValue,
|
|
|
|
|
|
newDatePicker,
|
2021-06-22 17:07:46 +08:00
|
|
|
|
showDetail,
|
|
|
|
|
|
rangeHistory,
|
|
|
|
|
|
rangeHistoryArr,
|
2022-10-27 09:48:31 +08:00
|
|
|
|
getMillisecond,
|
2021-06-21 18:41:17 +08:00
|
|
|
|
myDatePickerShow,
|
2021-06-21 11:29:26 +08:00
|
|
|
|
showDropdown,
|
2021-06-21 18:41:17 +08:00
|
|
|
|
changeDropdown,
|
|
|
|
|
|
timeArrChange,
|
|
|
|
|
|
returnValue,
|
|
|
|
|
|
quickChange,
|
2021-06-22 17:07:46 +08:00
|
|
|
|
historyChange
|
2021-06-21 11:29:26 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
</script>
|