729 lines
25 KiB
Vue
729 lines
25 KiB
Vue
<!--
|
||
* @Descripttion: cron规则生成器
|
||
-->
|
||
|
||
<template>
|
||
<el-input v-model="defaultValue" v-bind="$attrs">
|
||
<template #append>
|
||
<el-dropdown size="medium" @command="handleShortcuts">
|
||
<el-button icon="el-icon-arrow-down"></el-button>
|
||
<template #dropdown>
|
||
<el-dropdown-menu>
|
||
<el-dropdown-item command="* * * * *">每分钟</el-dropdown-item>
|
||
<el-dropdown-item command="0 * * * *">每小时</el-dropdown-item>
|
||
<el-dropdown-item command="0 0 * * *">每天零点</el-dropdown-item>
|
||
<el-dropdown-item command="0 0 1 * *">每月一号零点</el-dropdown-item>
|
||
<el-dropdown-item command="0 0 L * *">每月最后一天零点</el-dropdown-item>
|
||
<el-dropdown-item command="0 0 * * 1">每周星期日零点</el-dropdown-item>
|
||
<el-dropdown-item v-for="(item, index) in shortcuts" :key="item.value" :divided="index==0" :command="item.value">{{item.text}}</el-dropdown-item>
|
||
<el-dropdown-item icon="el-icon-plus" divided command="custom">自定义</el-dropdown-item>
|
||
</el-dropdown-menu>
|
||
</template>
|
||
</el-dropdown>
|
||
</template>
|
||
</el-input>
|
||
|
||
<el-dialog title="cron规则生成器" v-model="dialogVisible" :width="580" destroy-on-close append-to-body>
|
||
<div class="x-cron">
|
||
<el-tabs>
|
||
<!-- <el-tab-pane>
|
||
<template #label>
|
||
<div class="x-cron-num">
|
||
<h2>秒</h2>
|
||
<h4>{{value_second}}</h4>
|
||
</div>
|
||
</template>
|
||
<el-form>
|
||
<el-form-item label="类型">
|
||
<el-radio-group v-model="value.second.type">
|
||
<el-radio-button label="0">任意值</el-radio-button>
|
||
<el-radio-button label="1">范围</el-radio-button>
|
||
<el-radio-button label="2">间隔</el-radio-button>
|
||
<el-radio-button label="3">指定</el-radio-button>
|
||
</el-radio-group>
|
||
</el-form-item>
|
||
<el-form-item label="范围" v-if="value.second.type==1">
|
||
<el-input-number v-model="value.second.range.start" :min="0" :max="59" controls-position="right"></el-input-number>
|
||
<span style="padding:0 15px;">-</span>
|
||
<el-input-number v-model="value.second.range.end" :min="0" :max="59" controls-position="right"></el-input-number>
|
||
</el-form-item>
|
||
<el-form-item label="间隔" v-if="value.second.type==2">
|
||
<el-input-number v-model="value.second.loop.start" :min="0" :max="59" controls-position="right"></el-input-number>
|
||
<span style="padding: 0 6px;">秒开始,每</span>
|
||
<el-input-number v-model="value.second.loop.end" :min="0" :max="59" controls-position="right"></el-input-number>
|
||
<span style="padding: 0 6px;">秒执行一次</span>
|
||
</el-form-item>
|
||
<el-form-item label="指定" v-if="value.second.type==3">
|
||
<el-select v-model="value.second.appoint" multiple style="width: 100%;">
|
||
<el-option v-for="(item, index) in data.second" :key="index" :label="item" :value="item"></el-option>
|
||
</el-select>
|
||
</el-form-item>
|
||
</el-form>
|
||
</el-tab-pane> -->
|
||
<el-tab-pane>
|
||
<template #label>
|
||
<div class="x-cron-num">
|
||
<h2>分钟</h2>
|
||
<h4>{{value_minute}}</h4>
|
||
</div>
|
||
</template>
|
||
<el-form>
|
||
<el-form-item label="类型">
|
||
<el-radio-group v-model="value.minute.type">
|
||
<el-radio-button label="0">任意值</el-radio-button>
|
||
<el-radio-button label="1">范围</el-radio-button>
|
||
<el-radio-button label="2">间隔</el-radio-button>
|
||
<el-radio-button label="3">指定</el-radio-button>
|
||
</el-radio-group>
|
||
</el-form-item>
|
||
<el-form-item label="范围" v-if="value.minute.type==1">
|
||
<el-input-number v-model="value.minute.range.start" :min="0" :max="59" controls-position="right"></el-input-number>
|
||
<span style="padding:0 15px;">-</span>
|
||
<el-input-number v-model="value.minute.range.end" :min="0" :max="59" controls-position="right"></el-input-number>
|
||
</el-form-item>
|
||
<el-form-item label="间隔" v-if="value.minute.type==2">
|
||
<el-input-number v-model="value.minute.loop.start" :min="0" :max="59" controls-position="right"></el-input-number>
|
||
<span style="padding: 0 6px;">分钟开始,每</span>
|
||
<el-input-number v-model="value.minute.loop.end" :min="0" :max="59" controls-position="right"></el-input-number>
|
||
<span style="padding: 0 6px;">分钟执行一次</span>
|
||
</el-form-item>
|
||
<el-form-item label="指定" v-if="value.minute.type==3">
|
||
<el-select v-model="value.minute.appoint" multiple style="width: 100%;">
|
||
<el-option v-for="(item, index) in data.minute" :key="index" :label="item" :value="item"></el-option>
|
||
</el-select>
|
||
</el-form-item>
|
||
</el-form>
|
||
</el-tab-pane>
|
||
<el-tab-pane>
|
||
<template #label>
|
||
<div class="x-cron-num">
|
||
<h2>小时</h2>
|
||
<h4>{{value_hour}}</h4>
|
||
</div>
|
||
</template>
|
||
<el-form>
|
||
<el-form-item label="类型">
|
||
<el-radio-group v-model="value.hour.type">
|
||
<el-radio-button label="0">任意值</el-radio-button>
|
||
<el-radio-button label="1">范围</el-radio-button>
|
||
<el-radio-button label="2">间隔</el-radio-button>
|
||
<el-radio-button label="3">指定</el-radio-button>
|
||
</el-radio-group>
|
||
</el-form-item>
|
||
<el-form-item label="范围" v-if="value.hour.type==1">
|
||
<el-input-number v-model="value.hour.range.start" :min="0" :max="23" controls-position="right"></el-input-number>
|
||
<span style="padding:0 15px;">-</span>
|
||
<el-input-number v-model="value.hour.range.end" :min="0" :max="23" controls-position="right"></el-input-number>
|
||
</el-form-item>
|
||
<el-form-item label="间隔" v-if="value.hour.type==2">
|
||
<el-input-number v-model="value.hour.loop.start" :min="0" :max="23" controls-position="right"></el-input-number>
|
||
<span style="padding: 0 6px;">小时开始,每</span>
|
||
<el-input-number v-model="value.hour.loop.end" :min="0" :max="23" controls-position="right"></el-input-number>
|
||
<span style="padding: 0 6px;">小时执行一次</span>
|
||
</el-form-item>
|
||
<el-form-item label="指定" v-if="value.hour.type==3">
|
||
<el-select v-model="value.hour.appoint" multiple style="width: 100%;">
|
||
<el-option v-for="(item, index) in data.hour" :key="index" :label="item" :value="item"></el-option>
|
||
</el-select>
|
||
</el-form-item>
|
||
</el-form>
|
||
</el-tab-pane>
|
||
<el-tab-pane>
|
||
<template #label>
|
||
<div class="x-cron-num">
|
||
<h2>日</h2>
|
||
<h4>{{value_day}}</h4>
|
||
</div>
|
||
</template>
|
||
<el-form>
|
||
<el-form-item label="类型">
|
||
<el-radio-group v-model="value.day.type">
|
||
<el-radio-button label="0">任意值</el-radio-button>
|
||
<el-radio-button label="1">范围</el-radio-button>
|
||
<el-radio-button label="2">间隔</el-radio-button>
|
||
<el-radio-button label="3">指定</el-radio-button>
|
||
<el-radio-button label="4">本月最后一天</el-radio-button>
|
||
<!-- <el-radio-button label="5">不指定</el-radio-button> -->
|
||
</el-radio-group>
|
||
</el-form-item>
|
||
<el-form-item label="范围" v-if="value.day.type==1">
|
||
<el-input-number v-model="value.day.range.start" :min="1" :max="31" controls-position="right"></el-input-number>
|
||
<span style="padding:0 15px;">-</span>
|
||
<el-input-number v-model="value.day.range.end" :min="1" :max="31" controls-position="right"></el-input-number>
|
||
</el-form-item>
|
||
<el-form-item label="间隔" v-if="value.day.type==2">
|
||
<el-input-number v-model="value.day.loop.start" :min="1" :max="31" controls-position="right"></el-input-number>
|
||
<span style="padding: 0 6px;">号开始,每</span>
|
||
<el-input-number v-model="value.day.loop.end" :min="1" :max="31" controls-position="right"></el-input-number>
|
||
<span style="padding: 0 6px;">天执行一次</span>
|
||
</el-form-item>
|
||
<el-form-item label="指定" v-if="value.day.type==3">
|
||
<el-select v-model="value.day.appoint" multiple style="width: 100%;">
|
||
<el-option v-for="(item, index) in data.day" :key="index" :label="item" :value="item"></el-option>
|
||
</el-select>
|
||
</el-form-item>
|
||
</el-form>
|
||
</el-tab-pane>
|
||
<el-tab-pane>
|
||
<template #label>
|
||
<div class="x-cron-num">
|
||
<h2>月</h2>
|
||
<h4>{{value_month}}</h4>
|
||
</div>
|
||
</template>
|
||
<el-form>
|
||
<el-form-item label="类型">
|
||
<el-radio-group v-model="value.month.type">
|
||
<el-radio-button label="0">任意值</el-radio-button>
|
||
<el-radio-button label="1">范围</el-radio-button>
|
||
<el-radio-button label="2">间隔</el-radio-button>
|
||
<el-radio-button label="3">指定</el-radio-button>
|
||
</el-radio-group>
|
||
</el-form-item>
|
||
<el-form-item label="范围" v-if="value.month.type==1">
|
||
<el-input-number v-model="value.month.range.start" :min="1" :max="12" controls-position="right"></el-input-number>
|
||
<span style="padding:0 15px;">-</span>
|
||
<el-input-number v-model="value.month.range.end" :min="1" :max="12" controls-position="right"></el-input-number>
|
||
</el-form-item>
|
||
<el-form-item label="间隔" v-if="value.month.type==2">
|
||
<el-input-number v-model="value.month.loop.start" :min="1" :max="12" controls-position="right"></el-input-number>
|
||
<span style="padding: 0 6px;">月开始,每</span>
|
||
<el-input-number v-model="value.month.loop.end" :min="1" :max="12" controls-position="right"></el-input-number>
|
||
<span style="padding: 0 6px;">月执行一次</span>
|
||
</el-form-item>
|
||
<el-form-item label="指定" v-if="value.month.type==3">
|
||
<el-select v-model="value.month.appoint" multiple style="width: 100%;">
|
||
<el-option v-for="(item, index) in data.month" :key="index" :label="item" :value="item"></el-option>
|
||
</el-select>
|
||
</el-form-item>
|
||
</el-form>
|
||
</el-tab-pane>
|
||
<el-tab-pane>
|
||
<template #label>
|
||
<div class="x-cron-num">
|
||
<h2>周</h2>
|
||
<h4>{{value_week}}</h4>
|
||
</div>
|
||
</template>
|
||
<el-form>
|
||
<el-form>
|
||
<el-form-item label="类型">
|
||
<el-radio-group v-model="value.week.type">
|
||
<el-radio-button label="0">任意值</el-radio-button>
|
||
<el-radio-button label="1">范围</el-radio-button>
|
||
<el-radio-button label="2">间隔</el-radio-button>
|
||
<el-radio-button label="3">指定</el-radio-button>
|
||
<el-radio-button label="4">本月最后一周</el-radio-button>
|
||
<!-- <el-radio-button label="5">不指定</el-radio-button> -->
|
||
</el-radio-group>
|
||
</el-form-item>
|
||
<el-form-item label="范围" v-if="value.week.type==1">
|
||
<el-select v-model="value.week.range.start">
|
||
<el-option v-for="(item, index) in data.week" :key="index" :label="item.label" :value="item.value"></el-option>
|
||
</el-select>
|
||
<span style="padding:0 15px;">-</span>
|
||
<el-select v-model="value.week.range.end">
|
||
<el-option v-for="(item, index) in data.week" :key="index" :label="item.label" :value="item.value"></el-option>
|
||
</el-select>
|
||
</el-form-item>
|
||
<el-form-item label="间隔" v-if="value.week.type==2">
|
||
第
|
||
<el-input-number v-model="value.week.loop.start" :min="1" :max="4" controls-position="right"></el-input-number>
|
||
<span style="padding: 0 6px;">周的星期</span>
|
||
<el-select v-model="value.week.loop.end">
|
||
<el-option v-for="(item, index) in data.week" :key="index" :label="item.label" :value="item.value"></el-option>
|
||
</el-select>
|
||
<span style="padding: 0 6px;">执行一次</span>
|
||
</el-form-item>
|
||
<el-form-item label="指定" v-if="value.week.type==3">
|
||
<el-select v-model="value.week.appoint" multiple style="width: 100%;">
|
||
<el-option v-for="(item, index) in data.week" :key="index" :label="item.label" :value="item.value"></el-option>
|
||
</el-select>
|
||
</el-form-item>
|
||
<el-form-item label="最后一周" v-if="value.week.type==4">
|
||
<el-select v-model="value.week.last">
|
||
<el-option v-for="(item, index) in data.week" :key="index" :label="item.label" :value="item.value"></el-option>
|
||
</el-select>
|
||
</el-form-item>
|
||
</el-form>
|
||
</el-form>
|
||
</el-tab-pane>
|
||
<el-tab-pane>
|
||
<template #label>
|
||
<div class="x-cron-num">
|
||
<h2>年</h2>
|
||
<h4>{{value_year}}</h4>
|
||
</div>
|
||
</template>
|
||
<el-form>
|
||
<el-form-item label="类型">
|
||
<el-radio-group v-model="value.year.type">
|
||
<el-radio-button label="-1">忽略</el-radio-button>
|
||
<el-radio-button label="0">任意值</el-radio-button>
|
||
<el-radio-button label="1">范围</el-radio-button>
|
||
<el-radio-button label="2">间隔</el-radio-button>
|
||
<el-radio-button label="3">指定</el-radio-button>
|
||
</el-radio-group>
|
||
</el-form-item>
|
||
<el-form-item label="范围" v-if="value.year.type==1">
|
||
<el-input-number v-model="value.year.range.start" controls-position="right"></el-input-number>
|
||
<span style="padding:0 15px;">-</span>
|
||
<el-input-number v-model="value.year.range.end" controls-position="right"></el-input-number>
|
||
</el-form-item>
|
||
<el-form-item label="间隔" v-if="value.year.type==2">
|
||
<el-input-number v-model="value.year.loop.start" controls-position="right"></el-input-number>
|
||
<span style="padding: 0 6px;">年开始,每</span>
|
||
<el-input-number v-model="value.year.loop.end" :min="1" controls-position="right"></el-input-number>
|
||
<span style="padding: 0 6px;">年执行一次</span>
|
||
</el-form-item>
|
||
<el-form-item label="指定" v-if="value.year.type==3">
|
||
<el-select v-model="value.year.appoint" multiple style="width: 100%;">
|
||
<el-option v-for="(item, index) in data.year" :key="index" :label="item" :value="item"></el-option>
|
||
</el-select>
|
||
</el-form-item>
|
||
</el-form>
|
||
</el-tab-pane>
|
||
</el-tabs>
|
||
</div>
|
||
|
||
<template #footer>
|
||
<el-button @click="dialogVisible=false" >取 消</el-button>
|
||
<el-button type="primary" @click="submit()">确 认</el-button>
|
||
</template>
|
||
</el-dialog>
|
||
</template>
|
||
|
||
<script>
|
||
export default {
|
||
props: {
|
||
modelValue: { type: String, default: "* * * * *" },
|
||
shortcuts: { type: Array, default: () => [] }
|
||
},
|
||
data() {
|
||
return {
|
||
type: '0',
|
||
defaultValue: '',
|
||
dialogVisible: false,
|
||
|
||
value:{
|
||
// second: {
|
||
// type: '0',
|
||
// range: {
|
||
// start: 1,
|
||
// end: 2
|
||
// },
|
||
// loop: {
|
||
// start: 0,
|
||
// end: 1
|
||
// },
|
||
// appoint: []
|
||
// },
|
||
minute: {
|
||
type: '0',
|
||
range: {
|
||
start: 1,
|
||
end: 2
|
||
},
|
||
loop: {
|
||
start: 0,
|
||
end: 1
|
||
},
|
||
appoint: []
|
||
},
|
||
hour: {
|
||
type: '0',
|
||
range: {
|
||
start: 1,
|
||
end: 2
|
||
},
|
||
loop: {
|
||
start: 0,
|
||
end: 1
|
||
},
|
||
appoint: []
|
||
},
|
||
day: {
|
||
type: '0',
|
||
range: {
|
||
start: 1,
|
||
end: 2
|
||
},
|
||
loop: {
|
||
start: 1,
|
||
end: 1
|
||
},
|
||
appoint: []
|
||
},
|
||
month: {
|
||
type: '0',
|
||
range: {
|
||
start: 1,
|
||
end: 2
|
||
},
|
||
loop: {
|
||
start: 1,
|
||
end: 1
|
||
},
|
||
appoint: []
|
||
},
|
||
week: {
|
||
type: '5',
|
||
range: {
|
||
start: '2',
|
||
end: '3'
|
||
},
|
||
loop: {
|
||
start: 0,
|
||
end: '2'
|
||
},
|
||
last: '2',
|
||
appoint: []
|
||
},
|
||
year: {
|
||
type: '-1',
|
||
range: {
|
||
start: this.getYear()[0],
|
||
end: this.getYear()[1]
|
||
},
|
||
loop: {
|
||
start: this.getYear()[0],
|
||
end: 1
|
||
},
|
||
appoint: []
|
||
}
|
||
},
|
||
data: {
|
||
// second: ['0','5','15','20','25','30','35','40','45','50','55','59'],
|
||
minute: ['0','5','15','20','25','30','35','40','45','50','55','59'],
|
||
hour: ['0','1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16','17','18','19','20','21','22','23'],
|
||
day: ['1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16','17','18','19','20','21','22','23','24','25','26','27','28','29','30','31'],
|
||
month: ['1','2','3','4','5','6','7','8','9','10','11','12'],
|
||
week: [
|
||
{
|
||
value: '1',
|
||
label: '周日'
|
||
},
|
||
{
|
||
value: '2',
|
||
label: '周一'
|
||
},
|
||
{
|
||
value: '3',
|
||
label: '周二'
|
||
},
|
||
{
|
||
value: '4',
|
||
label: '周三'
|
||
},
|
||
{
|
||
value: '5',
|
||
label: '周四'
|
||
},
|
||
{
|
||
value: '6',
|
||
label: '周五'
|
||
},
|
||
{
|
||
value: '7',
|
||
label: '周六'
|
||
}
|
||
],
|
||
year: this.getYear()
|
||
}
|
||
}
|
||
},
|
||
watch: {
|
||
'value.week.type'(val){
|
||
if(val != '0'){
|
||
this.value.day.type = '0'
|
||
}
|
||
},
|
||
'value.day.type'(val){
|
||
if(val != '0'){
|
||
this.value.week.type = '0'
|
||
}
|
||
},
|
||
modelValue() {
|
||
this.defaultValue = this.modelValue
|
||
}
|
||
},
|
||
computed: {
|
||
// value_second(){
|
||
// let v = this.value.second
|
||
// if(v.type == 0){
|
||
// return '*'
|
||
// }else if(v.type==1){
|
||
// return v.range.start + '-' +v.range.end
|
||
// }else if(v.type==2){
|
||
// return v.loop.start + '/' + v.loop.end
|
||
// }else if(v.type==3){
|
||
// return v.appoint.length>0 ? v.appoint.join(',') : '*'
|
||
// }else{
|
||
// return '*'
|
||
// }
|
||
// },
|
||
value_minute(){
|
||
let v = this.value.minute
|
||
if(v.type == 0){
|
||
return '*'
|
||
}else if(v.type==1){
|
||
return v.range.start + '-' +v.range.end
|
||
}else if(v.type==2){
|
||
return v.loop.start + '/' + v.loop.end
|
||
}else if(v.type==3){
|
||
return v.appoint.length>0 ? v.appoint.join(',') : '*'
|
||
}else{
|
||
return '*'
|
||
}
|
||
},
|
||
value_hour(){
|
||
let v = this.value.hour
|
||
if(v.type == 0){
|
||
return '*'
|
||
}else if(v.type==1){
|
||
return v.range.start + '-' +v.range.end
|
||
}else if(v.type==2){
|
||
return v.loop.start + '/' + v.loop.end
|
||
}else if(v.type==3){
|
||
return v.appoint.length>0 ? v.appoint.join(',') : '*'
|
||
}else{
|
||
return '*'
|
||
}
|
||
},
|
||
value_day(){
|
||
let v = this.value.day
|
||
if(v.type == 0){
|
||
return '*'
|
||
}else if(v.type==1){
|
||
return v.range.start + '-' +v.range.end
|
||
}else if(v.type==2){
|
||
return v.loop.start + '/' + v.loop.end
|
||
}else if(v.type==3){
|
||
return v.appoint.length>0 ? v.appoint.join(',') : '*'
|
||
}else if(v.type==4){
|
||
return 'L'
|
||
}else if(v.type==5){
|
||
return '?'
|
||
}else{
|
||
return '*'
|
||
}
|
||
},
|
||
value_month(){
|
||
let v = this.value.month
|
||
if(v.type == 0){
|
||
return '*'
|
||
}else if(v.type==1){
|
||
return v.range.start + '-' +v.range.end
|
||
}else if(v.type==2){
|
||
return v.loop.start + '/' + v.loop.end
|
||
}else if(v.type==3){
|
||
return v.appoint.length>0 ? v.appoint.join(',') : '*'
|
||
}else{
|
||
return '*'
|
||
}
|
||
},
|
||
value_week(){
|
||
let v = this.value.week
|
||
if(v.type == 0){
|
||
return '*'
|
||
}else if(v.type==1){
|
||
return v.range.start + '-' +v.range.end
|
||
}else if(v.type==2){
|
||
return v.loop.end + '#' + v.loop.start
|
||
}else if(v.type==3){
|
||
return v.appoint.length>0 ? v.appoint.join(',') : '*'
|
||
}else if(v.type==4){
|
||
return v.last + 'L'
|
||
}else if(v.type==5){
|
||
return '?'
|
||
}else{
|
||
return '*'
|
||
}
|
||
},
|
||
value_year(){
|
||
let v = this.value.year
|
||
if(v.type == -1){
|
||
return ''
|
||
}else if(v.type==0){
|
||
return '*'
|
||
}else if(v.type==1){
|
||
return v.range.start + '-' +v.range.end
|
||
}else if(v.type==2){
|
||
return v.loop.start + '/' + v.loop.end
|
||
}else if(v.type==3){
|
||
return v.appoint.length>0 ? v.appoint.join(',') : ''
|
||
}else{
|
||
return ''
|
||
}
|
||
},
|
||
},
|
||
mounted() {
|
||
this.defaultValue = this.modelValue
|
||
},
|
||
methods: {
|
||
handleShortcuts(command){
|
||
if(command == 'custom'){
|
||
this.open()
|
||
}else{
|
||
this.defaultValue = command
|
||
this.$emit('update:modelValue', this.defaultValue)
|
||
}
|
||
},
|
||
open(){
|
||
this.set()
|
||
this.dialogVisible = true
|
||
},
|
||
set(){
|
||
this.defaultValue = this.modelValue
|
||
let arr = (this.modelValue || "* * * * *").split(" ")
|
||
//简单检查
|
||
if(arr.length < 5){
|
||
this.$message.warning("cron表达式错误,已转换为默认表达式")
|
||
arr = "* * * * *".split(" ")
|
||
}
|
||
|
||
//秒
|
||
// if(arr[0]=='*'){
|
||
// this.value.second.type = '0'
|
||
// }else if(arr[0].includes('-')){
|
||
// this.value.second.type = '1'
|
||
// this.value.second.range.start = Number(arr[0].split("-")[0])
|
||
// this.value.second.range.end = Number(arr[0].split("-")[1])
|
||
// }else if(arr[0].includes('/')){
|
||
// this.value.second.type = '2'
|
||
// this.value.second.loop.start = Number(arr[0].split("/")[0])
|
||
// this.value.second.loop.end = Number(arr[0].split("/")[1])
|
||
// }else{
|
||
// this.value.second.type = '3'
|
||
// this.value.second.appoint = arr[0].split(",")
|
||
// }
|
||
//分
|
||
if(arr[0]=='*'){
|
||
this.value.minute.type = '0'
|
||
}else if(arr[0].includes('-')){
|
||
this.value.minute.type = '1'
|
||
this.value.minute.range.start = Number(arr[0].split("-")[0])
|
||
this.value.minute.range.end = Number(arr[0].split("-")[1])
|
||
}else if(arr[0].includes('/')){
|
||
this.value.minute.type = '2'
|
||
this.value.minute.loop.start = Number(arr[0].split("/")[0])
|
||
this.value.minute.loop.end = Number(arr[0].split("/")[1])
|
||
}else{
|
||
this.value.minute.type = '3'
|
||
this.value.minute.appoint = arr[0].split(",")
|
||
}
|
||
//小时
|
||
if(arr[1]=='*'){
|
||
this.value.hour.type = '0'
|
||
}else if(arr[1].includes('-')){
|
||
this.value.hour.type = '1'
|
||
this.value.hour.range.start = Number(arr[1].split("-")[0])
|
||
this.value.hour.range.end = Number(arr[1].split("-")[1])
|
||
}else if(arr[1].includes('/')){
|
||
this.value.hour.type = '2'
|
||
this.value.hour.loop.start = Number(arr[1].split("/")[0])
|
||
this.value.hour.loop.end = Number(arr[1].split("/")[1])
|
||
}else{
|
||
this.value.hour.type = '3'
|
||
this.value.hour.appoint = arr[1].split(",")
|
||
}
|
||
//日
|
||
if(arr[2]=='*'){
|
||
this.value.day.type = '0'
|
||
}else if(arr[2]=='L'){
|
||
this.value.day.type = '4'
|
||
}else if(arr[2]=='?'){
|
||
this.value.day.type = '5'
|
||
}else if(arr[2].includes('-')){
|
||
this.value.day.type = '1'
|
||
this.value.day.range.start = Number(arr[2].split("-")[0])
|
||
this.value.day.range.end = Number(arr[2].split("-")[1])
|
||
}else if(arr[2].includes('/')){
|
||
this.value.day.type = '2'
|
||
this.value.day.loop.start = Number(arr[2].split("/")[0])
|
||
this.value.day.loop.end = Number(arr[2].split("/")[1])
|
||
}else{
|
||
this.value.day.type = '3'
|
||
this.value.day.appoint = arr[2].split(",")
|
||
}
|
||
//月
|
||
if(arr[3]=='*'){
|
||
this.value.month.type = '0'
|
||
}else if(arr[3].includes('-')){
|
||
this.value.month.type = '1'
|
||
this.value.month.range.start = Number(arr[3].split("-")[0])
|
||
this.value.month.range.end = Number(arr[3].split("-")[1])
|
||
}else if(arr[3].includes('/')){
|
||
this.value.month.type = '2'
|
||
this.value.month.loop.start = Number(arr[3].split("/")[0])
|
||
this.value.month.loop.end = Number(arr[3].split("/")[1])
|
||
}else{
|
||
this.value.month.type = '3'
|
||
this.value.month.appoint = arr[3].split(",")
|
||
}
|
||
//周
|
||
if(arr[4]=='*'){
|
||
this.value.week.type = '0'
|
||
}else if(arr[4]=='?'){
|
||
this.value.week.type = '5'
|
||
}else if(arr[4].includes('-')){
|
||
this.value.week.type = '1'
|
||
this.value.week.range.start = arr[4].split("-")[0]
|
||
this.value.week.range.end = arr[4].split("-")[1]
|
||
}else if(arr[4].includes('#')){
|
||
this.value.week.type = '2'
|
||
this.value.week.loop.start = Number(arr[4].split("#")[1])
|
||
this.value.week.loop.end = arr[4].split("#")[0]
|
||
}else if(arr[4].includes('L')){
|
||
this.value.week.type = '4'
|
||
this.value.week.last = arr[4].split("L")[0]
|
||
}else{
|
||
this.value.week.type = '3'
|
||
this.value.week.appoint = arr[4].split(",")
|
||
}
|
||
//年
|
||
if(!arr[5]){
|
||
this.value.year.type = '-1'
|
||
}else if(arr[5]=='*'){
|
||
this.value.year.type = '0'
|
||
}else if(arr[5].includes('-')){
|
||
this.value.year.type = '1'
|
||
this.value.year.range.start = Number(arr[5].split("-")[0])
|
||
this.value.year.range.end = Number(arr[5].split("-")[1])
|
||
}else if(arr[5].includes('/')){
|
||
this.value.year.type = '2'
|
||
this.value.year.loop.start = Number(arr[5].split("/")[1])
|
||
this.value.year.loop.end = Number(arr[5].split("/")[0])
|
||
}else{
|
||
this.value.year.type = '3'
|
||
this.value.year.appoint = arr[5].split(",")
|
||
}
|
||
},
|
||
getYear(){
|
||
let v = []
|
||
let y = new Date().getFullYear()
|
||
for (let i = 0; i < 11; i++) {
|
||
v.push(y+i)
|
||
}
|
||
return v
|
||
},
|
||
submit(){
|
||
let year = this.value_year ? ' '+this.value_year : ''
|
||
this.defaultValue = this.value_minute + ' ' + this.value_hour + ' ' + this.value_day + ' ' + this.value_month + ' ' + this.value_week + year
|
||
this.$emit('update:modelValue', this.defaultValue)
|
||
this.dialogVisible = false
|
||
}
|
||
}
|
||
}
|
||
</script>
|
||
|
||
<style scoped>
|
||
.x-cron:deep(.el-tabs__item) {height: auto;line-height: 1;padding:0 7px;vertical-align: bottom;}
|
||
.x-cron-num {text-align: center;margin-bottom: 15px;width: 100%;}
|
||
.x-cron-num h2 {font-size: 12px;margin-bottom: 15px;font-weight: normal;}
|
||
.x-cron-num h4 {display: block;height: 32px;line-height: 30px;width: 100%;font-size: 12px;padding:0 15px;background: var(--el-color-primary-light-9);border-radius:4px;}
|
||
.x-cron:deep(.el-tabs__item.is-active) .x-cron-num h4 {background: var(--el-color-primary);color: #fff;}
|
||
|
||
[data-theme='dark'] .x-cron-num h4 {background: var(--el-color-white);}
|
||
</style>
|