1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015 |
- <script lang="ts" setup>
- import { ElMessage } from 'element-plus'
- import { PropType } from 'vue'
- defineOptions({ name: 'Crontab' })
- interface shortcutsType {
- text: string
- value: string
- }
- const props = defineProps({
- modelValue: {
- type: String,
- default: '* * * * * ?'
- },
- shortcuts: { type: Array as PropType<shortcutsType[]>, default: () => [] }
- })
- const defaultValue = ref('')
- const dialogVisible = ref(false)
- const getYear = () => {
- let v: number[] = []
- let y = new Date().getFullYear()
- for (let i = 0; i < 11; i++) {
- v.push(y + i)
- }
- return v
- }
- const cronValue = reactive({
- second: {
- type: '0',
- range: {
- start: 1,
- end: 2
- },
- loop: {
- start: 0,
- end: 1
- },
- appoint: [] as string[]
- },
- minute: {
- type: '0',
- range: {
- start: 1,
- end: 2
- },
- loop: {
- start: 0,
- end: 1
- },
- appoint: [] as string[]
- },
- hour: {
- type: '0',
- range: {
- start: 1,
- end: 2
- },
- loop: {
- start: 0,
- end: 1
- },
- appoint: [] as string[]
- },
- day: {
- type: '0',
- range: {
- start: 1,
- end: 2
- },
- loop: {
- start: 1,
- end: 1
- },
- appoint: [] as string[]
- },
- month: {
- type: '0',
- range: {
- start: 1,
- end: 2
- },
- loop: {
- start: 1,
- end: 1
- },
- appoint: [] as string[]
- },
- week: {
- type: '5',
- range: {
- start: '2',
- end: '3'
- },
- loop: {
- start: 0,
- end: '2'
- },
- last: '2',
- appoint: [] as string[]
- },
- year: {
- type: '-1',
- range: {
- start: getYear()[0],
- end: getYear()[1]
- },
- loop: {
- start: getYear()[0],
- end: 1
- },
- appoint: [] as string[]
- }
- })
- const data = reactive({
- 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: getYear()
- })
- const value_second = computed(() => {
- let v = cronValue.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 '*'
- }
- })
- const value_minute = computed(() => {
- let v = cronValue.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 '*'
- }
- })
- const value_hour = computed(() => {
- let v = cronValue.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 '*'
- }
- })
- const value_day = computed(() => {
- let v = cronValue.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 '*'
- }
- })
- const value_month = computed(() => {
- let v = cronValue.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 '*'
- }
- })
- const value_week = computed(() => {
- let v = cronValue.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 '*'
- }
- })
- const value_year = computed(() => {
- let v = cronValue.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 ''
- }
- })
- watch(
- () => cronValue.week.type,
- (val) => {
- if (val != '5') {
- cronValue.day.type = '5'
- }
- }
- )
- watch(
- () => cronValue.day.type,
- (val) => {
- if (val != '5') {
- cronValue.week.type = '5'
- }
- }
- )
- watch(
- () => props.modelValue,
- () => {
- defaultValue.value = props.modelValue
- }
- )
- onMounted(() => {
- defaultValue.value = props.modelValue
- })
- const emit = defineEmits(['update:modelValue'])
- const select = ref()
- watch(
- () => select.value,
- () => {
- if (select.value == 'custom') {
- open()
- } else {
- defaultValue.value = select.value
- emit('update:modelValue', defaultValue.value)
- }
- }
- )
- const open = () => {
- set()
- dialogVisible.value = true
- }
- const set = () => {
- defaultValue.value = props.modelValue
- let arr = (props.modelValue || '* * * * * ?').split(' ')
- //简单检查
- if (arr.length < 6) {
- ElMessage.warning('cron表达式错误,已转换为默认表达式')
- arr = '* * * * * ?'.split(' ')
- }
- //秒
- if (arr[0] == '*') {
- cronValue.second.type = '0'
- } else if (arr[0].includes('-')) {
- cronValue.second.type = '1'
- cronValue.second.range.start = Number(arr[0].split('-')[0])
- cronValue.second.range.end = Number(arr[0].split('-')[1])
- } else if (arr[0].includes('/')) {
- cronValue.second.type = '2'
- cronValue.second.loop.start = Number(arr[0].split('/')[0])
- cronValue.second.loop.end = Number(arr[0].split('/')[1])
- } else {
- cronValue.second.type = '3'
- cronValue.second.appoint = arr[0].split(',')
- }
- //分
- if (arr[1] == '*') {
- cronValue.minute.type = '0'
- } else if (arr[1].includes('-')) {
- cronValue.minute.type = '1'
- cronValue.minute.range.start = Number(arr[1].split('-')[0])
- cronValue.minute.range.end = Number(arr[1].split('-')[1])
- } else if (arr[1].includes('/')) {
- cronValue.minute.type = '2'
- cronValue.minute.loop.start = Number(arr[1].split('/')[0])
- cronValue.minute.loop.end = Number(arr[1].split('/')[1])
- } else {
- cronValue.minute.type = '3'
- cronValue.minute.appoint = arr[1].split(',')
- }
- //小时
- if (arr[2] == '*') {
- cronValue.hour.type = '0'
- } else if (arr[2].includes('-')) {
- cronValue.hour.type = '1'
- cronValue.hour.range.start = Number(arr[2].split('-')[0])
- cronValue.hour.range.end = Number(arr[2].split('-')[1])
- } else if (arr[2].includes('/')) {
- cronValue.hour.type = '2'
- cronValue.hour.loop.start = Number(arr[2].split('/')[0])
- cronValue.hour.loop.end = Number(arr[2].split('/')[1])
- } else {
- cronValue.hour.type = '3'
- cronValue.hour.appoint = arr[2].split(',')
- }
- //日
- if (arr[3] == '*') {
- cronValue.day.type = '0'
- } else if (arr[3] == 'L') {
- cronValue.day.type = '4'
- } else if (arr[3] == '?') {
- cronValue.day.type = '5'
- } else if (arr[3].includes('-')) {
- cronValue.day.type = '1'
- cronValue.day.range.start = Number(arr[3].split('-')[0])
- cronValue.day.range.end = Number(arr[3].split('-')[1])
- } else if (arr[3].includes('/')) {
- cronValue.day.type = '2'
- cronValue.day.loop.start = Number(arr[3].split('/')[0])
- cronValue.day.loop.end = Number(arr[3].split('/')[1])
- } else {
- cronValue.day.type = '3'
- cronValue.day.appoint = arr[3].split(',')
- }
- //月
- if (arr[4] == '*') {
- cronValue.month.type = '0'
- } else if (arr[4].includes('-')) {
- cronValue.month.type = '1'
- cronValue.month.range.start = Number(arr[4].split('-')[0])
- cronValue.month.range.end = Number(arr[4].split('-')[1])
- } else if (arr[4].includes('/')) {
- cronValue.month.type = '2'
- cronValue.month.loop.start = Number(arr[4].split('/')[0])
- cronValue.month.loop.end = Number(arr[4].split('/')[1])
- } else {
- cronValue.month.type = '3'
- cronValue.month.appoint = arr[4].split(',')
- }
- //周
- if (arr[5] == '*') {
- cronValue.week.type = '0'
- } else if (arr[5] == '?') {
- cronValue.week.type = '5'
- } else if (arr[5].includes('-')) {
- cronValue.week.type = '1'
- cronValue.week.range.start = arr[5].split('-')[0]
- cronValue.week.range.end = arr[5].split('-')[1]
- } else if (arr[5].includes('#')) {
- cronValue.week.type = '2'
- cronValue.week.loop.start = Number(arr[5].split('#')[1])
- cronValue.week.loop.end = arr[5].split('#')[0]
- } else if (arr[5].includes('L')) {
- cronValue.week.type = '4'
- cronValue.week.last = arr[5].split('L')[0]
- } else {
- cronValue.week.type = '3'
- cronValue.week.appoint = arr[5].split(',')
- }
- //年
- if (!arr[6]) {
- cronValue.year.type = '-1'
- } else if (arr[6] == '*') {
- cronValue.year.type = '0'
- } else if (arr[6].includes('-')) {
- cronValue.year.type = '1'
- cronValue.year.range.start = Number(arr[6].split('-')[0])
- cronValue.year.range.end = Number(arr[6].split('-')[1])
- } else if (arr[6].includes('/')) {
- cronValue.year.type = '2'
- cronValue.year.loop.start = Number(arr[6].split('/')[1])
- cronValue.year.loop.end = Number(arr[6].split('/')[0])
- } else {
- cronValue.year.type = '3'
- cronValue.year.appoint = arr[6].split(',')
- }
- }
- const submit = () => {
- let year = value_year.value ? ' ' + value_year.value : ''
- defaultValue.value =
- value_second.value +
- ' ' +
- value_minute.value +
- ' ' +
- value_hour.value +
- ' ' +
- value_day.value +
- ' ' +
- value_month.value +
- ' ' +
- value_week.value +
- year
- emit('update:modelValue', defaultValue.value)
- dialogVisible.value = false
- }
- const inputChange = () => {
- emit('update:modelValue', defaultValue.value)
- }
- </script>
- <template>
- <el-input v-model="defaultValue" class="input-with-select" v-bind="$attrs" @input="inputChange">
- <template #append>
- <el-select v-model="select" placeholder="生成器" style="width: 115px">
- <el-option label="每分钟" value="0 * * * * ?" />
- <el-option label="每小时" value="0 0 * * * ?" />
- <el-option label="每天零点" value="0 0 0 * * ?" />
- <el-option label="每月一号零点" value="0 0 0 1 * ?" />
- <el-option label="每月最后一天零点" value="0 0 0 L * ?" />
- <el-option label="每周星期日零点" value="0 0 0 ? * 1" />
- <el-option
- v-for="(item, index) in shortcuts"
- :key="index"
- :label="item.text"
- :value="item.value"
- />
- <el-option label="自定义" value="custom" />
- </el-select>
- </template>
- </el-input>
- <el-dialog
- v-model="dialogVisible"
- :width="580"
- append-to-body
- destroy-on-close
- title="cron规则生成器"
- >
- <div class="sc-cron">
- <el-tabs>
- <el-tab-pane>
- <template #label>
- <div class="sc-cron-num">
- <h2>秒</h2>
- <h4>{{ value_second }}</h4>
- </div>
- </template>
- <el-form>
- <el-form-item label="类型">
- <el-radio-group v-model="cronValue.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 v-if="cronValue.second.type == '1'" label="范围">
- <el-input-number
- v-model="cronValue.second.range.start"
- :max="59"
- :min="0"
- controls-position="right"
- />
- <span style="padding: 0 15px">-</span>
- <el-input-number
- v-model="cronValue.second.range.end"
- :max="59"
- :min="0"
- controls-position="right"
- />
- </el-form-item>
- <el-form-item v-if="cronValue.second.type == '2'" label="间隔">
- <el-input-number
- v-model="cronValue.second.loop.start"
- :max="59"
- :min="0"
- controls-position="right"
- />
- 秒开始,每
- <el-input-number
- v-model="cronValue.second.loop.end"
- :max="59"
- :min="0"
- controls-position="right"
- />
- 秒执行一次
- </el-form-item>
- <el-form-item v-if="cronValue.second.type == '3'" label="指定">
- <el-select v-model="cronValue.second.appoint" multiple style="width: 100%">
- <el-option
- v-for="(item, index) in data.second"
- :key="index"
- :label="item"
- :value="item"
- />
- </el-select>
- </el-form-item>
- </el-form>
- </el-tab-pane>
- <el-tab-pane>
- <template #label>
- <div class="sc-cron-num">
- <h2>分钟</h2>
- <h4>{{ value_minute }}</h4>
- </div>
- </template>
- <el-form>
- <el-form-item label="类型">
- <el-radio-group v-model="cronValue.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 v-if="cronValue.minute.type == '1'" label="范围">
- <el-input-number
- v-model="cronValue.minute.range.start"
- :max="59"
- :min="0"
- controls-position="right"
- />
- <span style="padding: 0 15px">-</span>
- <el-input-number
- v-model="cronValue.minute.range.end"
- :max="59"
- :min="0"
- controls-position="right"
- />
- </el-form-item>
- <el-form-item v-if="cronValue.minute.type == '2'" label="间隔">
- <el-input-number
- v-model="cronValue.minute.loop.start"
- :max="59"
- :min="0"
- controls-position="right"
- />
- 分钟开始,每
- <el-input-number
- v-model="cronValue.minute.loop.end"
- :max="59"
- :min="0"
- controls-position="right"
- />
- 分钟执行一次
- </el-form-item>
- <el-form-item v-if="cronValue.minute.type == '3'" label="指定">
- <el-select v-model="cronValue.minute.appoint" multiple style="width: 100%">
- <el-option
- v-for="(item, index) in data.minute"
- :key="index"
- :label="item"
- :value="item"
- />
- </el-select>
- </el-form-item>
- </el-form>
- </el-tab-pane>
- <el-tab-pane>
- <template #label>
- <div class="sc-cron-num">
- <h2>小时</h2>
- <h4>{{ value_hour }}</h4>
- </div>
- </template>
- <el-form>
- <el-form-item label="类型">
- <el-radio-group v-model="cronValue.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 v-if="cronValue.hour.type == '1'" label="范围">
- <el-input-number
- v-model="cronValue.hour.range.start"
- :max="23"
- :min="0"
- controls-position="right"
- />
- <span style="padding: 0 15px">-</span>
- <el-input-number
- v-model="cronValue.hour.range.end"
- :max="23"
- :min="0"
- controls-position="right"
- />
- </el-form-item>
- <el-form-item v-if="cronValue.hour.type == '2'" label="间隔">
- <el-input-number
- v-model="cronValue.hour.loop.start"
- :max="23"
- :min="0"
- controls-position="right"
- />
- 小时开始,每
- <el-input-number
- v-model="cronValue.hour.loop.end"
- :max="23"
- :min="0"
- controls-position="right"
- />
- 小时执行一次
- </el-form-item>
- <el-form-item v-if="cronValue.hour.type == '3'" label="指定">
- <el-select v-model="cronValue.hour.appoint" multiple style="width: 100%">
- <el-option
- v-for="(item, index) in data.hour"
- :key="index"
- :label="item"
- :value="item"
- />
- </el-select>
- </el-form-item>
- </el-form>
- </el-tab-pane>
- <el-tab-pane>
- <template #label>
- <div class="sc-cron-num">
- <h2>日</h2>
- <h4>{{ value_day }}</h4>
- </div>
- </template>
- <el-form>
- <el-form-item label="类型">
- <el-radio-group v-model="cronValue.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 v-if="cronValue.day.type == '1'" label="范围">
- <el-input-number
- v-model="cronValue.day.range.start"
- :max="31"
- :min="1"
- controls-position="right"
- />
- <span style="padding: 0 15px">-</span>
- <el-input-number
- v-model="cronValue.day.range.end"
- :max="31"
- :min="1"
- controls-position="right"
- />
- </el-form-item>
- <el-form-item v-if="cronValue.day.type == '2'" label="间隔">
- <el-input-number
- v-model="cronValue.day.loop.start"
- :max="31"
- :min="1"
- controls-position="right"
- />
- 号开始,每
- <el-input-number
- v-model="cronValue.day.loop.end"
- :max="31"
- :min="1"
- controls-position="right"
- />
- 天执行一次
- </el-form-item>
- <el-form-item v-if="cronValue.day.type == '3'" label="指定">
- <el-select v-model="cronValue.day.appoint" multiple style="width: 100%">
- <el-option
- v-for="(item, index) in data.day"
- :key="index"
- :label="item"
- :value="item"
- />
- </el-select>
- </el-form-item>
- </el-form>
- </el-tab-pane>
- <el-tab-pane>
- <template #label>
- <div class="sc-cron-num">
- <h2>月</h2>
- <h4>{{ value_month }}</h4>
- </div>
- </template>
- <el-form>
- <el-form-item label="类型">
- <el-radio-group v-model="cronValue.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 v-if="cronValue.month.type == '1'" label="范围">
- <el-input-number
- v-model="cronValue.month.range.start"
- :max="12"
- :min="1"
- controls-position="right"
- />
- <span style="padding: 0 15px">-</span>
- <el-input-number
- v-model="cronValue.month.range.end"
- :max="12"
- :min="1"
- controls-position="right"
- />
- </el-form-item>
- <el-form-item v-if="cronValue.month.type == '2'" label="间隔">
- <el-input-number
- v-model="cronValue.month.loop.start"
- :max="12"
- :min="1"
- controls-position="right"
- />
- 月开始,每
- <el-input-number
- v-model="cronValue.month.loop.end"
- :max="12"
- :min="1"
- controls-position="right"
- />
- 月执行一次
- </el-form-item>
- <el-form-item v-if="cronValue.month.type == '3'" label="指定">
- <el-select v-model="cronValue.month.appoint" multiple style="width: 100%">
- <el-option
- v-for="(item, index) in data.month"
- :key="index"
- :label="item"
- :value="item"
- />
- </el-select>
- </el-form-item>
- </el-form>
- </el-tab-pane>
- <el-tab-pane>
- <template #label>
- <div class="sc-cron-num">
- <h2>周</h2>
- <h4>{{ value_week }}</h4>
- </div>
- </template>
- <el-form>
- <el-form>
- <el-form-item label="类型">
- <el-radio-group v-model="cronValue.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 v-if="cronValue.week.type == '1'" label="范围">
- <el-select v-model="cronValue.week.range.start">
- <el-option
- v-for="(item, index) in data.week"
- :key="index"
- :label="item.label"
- :value="item.value"
- />
- </el-select>
- <span style="padding: 0 15px">-</span>
- <el-select v-model="cronValue.week.range.end">
- <el-option
- v-for="(item, index) in data.week"
- :key="index"
- :label="item.label"
- :value="item.value"
- />
- </el-select>
- </el-form-item>
- <el-form-item v-if="cronValue.week.type == '2'" label="间隔">
- 第
- <el-input-number
- v-model="cronValue.week.loop.start"
- :max="4"
- :min="1"
- controls-position="right"
- />
- 周的星期
- <el-select v-model="cronValue.week.loop.end">
- <el-option
- v-for="(item, index) in data.week"
- :key="index"
- :label="item.label"
- :value="item.value"
- />
- </el-select>
- 执行一次
- </el-form-item>
- <el-form-item v-if="cronValue.week.type == '3'" label="指定">
- <el-select v-model="cronValue.week.appoint" multiple style="width: 100%">
- <el-option
- v-for="(item, index) in data.week"
- :key="index"
- :label="item.label"
- :value="item.value"
- />
- </el-select>
- </el-form-item>
- <el-form-item v-if="cronValue.week.type == '4'" label="最后一周">
- <el-select v-model="cronValue.week.last">
- <el-option
- v-for="(item, index) in data.week"
- :key="index"
- :label="item.label"
- :value="item.value"
- />
- </el-select>
- </el-form-item>
- </el-form>
- </el-form>
- </el-tab-pane>
- <el-tab-pane>
- <template #label>
- <div class="sc-cron-num">
- <h2>年</h2>
- <h4>{{ value_year }}</h4>
- </div>
- </template>
- <el-form>
- <el-form-item label="类型">
- <el-radio-group v-model="cronValue.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 v-if="cronValue.year.type == '1'" label="范围">
- <el-input-number v-model="cronValue.year.range.start" controls-position="right" />
- <span style="padding: 0 15px">-</span>
- <el-input-number v-model="cronValue.year.range.end" controls-position="right" />
- </el-form-item>
- <el-form-item v-if="cronValue.year.type == '2'" label="间隔">
- <el-input-number v-model="cronValue.year.loop.start" controls-position="right" />
- 年开始,每
- <el-input-number
- v-model="cronValue.year.loop.end"
- :min="1"
- controls-position="right"
- />
- 年执行一次
- </el-form-item>
- <el-form-item v-if="cronValue.year.type == '3'" label="指定">
- <el-select v-model="cronValue.year.appoint" multiple style="width: 100%">
- <el-option
- v-for="(item, index) in data.year"
- :key="index"
- :label="item"
- :value="item"
- />
- </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>
- <style scoped>
- .sc-cron:deep(.el-tabs__item) {
- height: auto;
- padding: 0 7px;
- line-height: 1;
- vertical-align: bottom;
- }
- .sc-cron-num {
- width: 100%;
- margin-bottom: 15px;
- text-align: center;
- }
- .sc-cron-num h2 {
- margin-bottom: 15px;
- font-size: 12px;
- font-weight: normal;
- }
- .sc-cron-num h4 {
- display: block;
- width: 100%;
- height: 32px;
- padding: 0 15px;
- font-size: 12px;
- line-height: 30px;
- background: var(--el-color-primary-light-9);
- border-radius: 4px;
- }
- .sc-cron:deep(.el-tabs__item.is-active) .sc-cron-num h4 {
- color: #fff;
- background: var(--el-color-primary);
- }
- [data-theme='dark'] .sc-cron-num h4 {
- background: var(--el-color-white);
- }
- .input-with-select .el-input-group__prepend {
- background-color: var(--el-fill-color-blank);
- }
- </style>
|