|
|
|
@ -33,82 +33,91 @@
|
|
|
|
|
</el-form>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
|
export default {
|
|
|
|
|
data() {
|
|
|
|
|
return {
|
|
|
|
|
radioValue: 1,
|
|
|
|
|
cycle01: 0,
|
|
|
|
|
cycle02: 1,
|
|
|
|
|
average01: 0,
|
|
|
|
|
average02: 1,
|
|
|
|
|
checkboxList: [],
|
|
|
|
|
checkNum: this.$options.propsData.check
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
name: 'crontab-hour',
|
|
|
|
|
props: ['check', 'cron'],
|
|
|
|
|
methods: {
|
|
|
|
|
// 单选按钮值变化时
|
|
|
|
|
radioChange() {
|
|
|
|
|
switch (this.radioValue) {
|
|
|
|
|
case 1:
|
|
|
|
|
this.$emit('update', 'hour', '*')
|
|
|
|
|
break;
|
|
|
|
|
case 2:
|
|
|
|
|
this.$emit('update', 'hour', this.cycleTotal);
|
|
|
|
|
break;
|
|
|
|
|
case 3:
|
|
|
|
|
this.$emit('update', 'hour', this.averageTotal);
|
|
|
|
|
break;
|
|
|
|
|
case 4:
|
|
|
|
|
this.$emit('update', 'hour', this.checkboxString);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
// 周期两个值变化时
|
|
|
|
|
cycleChange() {
|
|
|
|
|
if (this.radioValue == '2') {
|
|
|
|
|
this.$emit('update', 'hour', this.cycleTotal);
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
// 平均两个值变化时
|
|
|
|
|
averageChange() {
|
|
|
|
|
if (this.radioValue == '3') {
|
|
|
|
|
this.$emit('update', 'hour', this.averageTotal);
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
// checkbox值变化时
|
|
|
|
|
checkboxChange() {
|
|
|
|
|
if (this.radioValue == '4') {
|
|
|
|
|
this.$emit('update', 'hour', this.checkboxString);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
watch: {
|
|
|
|
|
'radioValue': 'radioChange',
|
|
|
|
|
'cycleTotal': 'cycleChange',
|
|
|
|
|
'averageTotal': 'averageChange',
|
|
|
|
|
'checkboxString': 'checkboxChange'
|
|
|
|
|
<script setup lang="ts" name="CrontabHour">
|
|
|
|
|
import { ref, computed, watch, defineProps, defineEmits } from 'vue';
|
|
|
|
|
|
|
|
|
|
const props = defineProps({
|
|
|
|
|
check: {
|
|
|
|
|
type: Function,
|
|
|
|
|
required: true
|
|
|
|
|
},
|
|
|
|
|
computed: {
|
|
|
|
|
// 计算两个周期值
|
|
|
|
|
cycleTotal: function () {
|
|
|
|
|
const cycle01 = this.checkNum(this.cycle01, 0, 22)
|
|
|
|
|
const cycle02 = this.checkNum(this.cycle02, cycle01 ? cycle01 + 1 : 1, 23)
|
|
|
|
|
return cycle01 + '-' + cycle02;
|
|
|
|
|
},
|
|
|
|
|
// 计算平均用到的值
|
|
|
|
|
averageTotal: function () {
|
|
|
|
|
const average01 = this.checkNum(this.average01, 0, 22)
|
|
|
|
|
const average02 = this.checkNum(this.average02, 1, 23 - average01 || 0)
|
|
|
|
|
return average01 + '/' + average02;
|
|
|
|
|
},
|
|
|
|
|
// 计算勾选的checkbox值合集
|
|
|
|
|
checkboxString: function () {
|
|
|
|
|
let str = this.checkboxList.join();
|
|
|
|
|
return str == '' ? '*' : str;
|
|
|
|
|
}
|
|
|
|
|
cron: {
|
|
|
|
|
type: Object,
|
|
|
|
|
default: () => ({})
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
const emit = defineEmits(['update']);
|
|
|
|
|
|
|
|
|
|
const radioValue = ref(1);
|
|
|
|
|
const cycle01 = ref(0);
|
|
|
|
|
const cycle02 = ref(1);
|
|
|
|
|
const average01 = ref(0);
|
|
|
|
|
const average02 = ref(1);
|
|
|
|
|
const checkboxList = ref([]);
|
|
|
|
|
|
|
|
|
|
// 计算两个周期值
|
|
|
|
|
const cycleTotal = computed(() => {
|
|
|
|
|
const cycleVal01 = props.check(cycle01.value, 0, 22);
|
|
|
|
|
const cycleVal02 = props.check(cycle02.value, cycleVal01 ? cycleVal01 + 1 : 1, 23);
|
|
|
|
|
return `${cycleVal01}-${cycleVal02}`;
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// 计算平均用到的值
|
|
|
|
|
const averageTotal = computed(() => {
|
|
|
|
|
const averageVal01 = props.check(average01.value, 0, 22);
|
|
|
|
|
const averageVal02 = props.check(average02.value, 1, 23 - averageVal01 || 0);
|
|
|
|
|
return `${averageVal01}/${averageVal02}`;
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// 计算勾选的checkbox值合集
|
|
|
|
|
const checkboxString = computed(() => {
|
|
|
|
|
let str = checkboxList.value.join();
|
|
|
|
|
return str === '' ? '*' : str;
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// 单选按钮值变化时
|
|
|
|
|
const radioChange = () => {
|
|
|
|
|
switch (radioValue.value) {
|
|
|
|
|
case 1:
|
|
|
|
|
emit('update', 'hour', '*');
|
|
|
|
|
break;
|
|
|
|
|
case 2:
|
|
|
|
|
emit('update', 'hour', cycleTotal.value);
|
|
|
|
|
break;
|
|
|
|
|
case 3:
|
|
|
|
|
emit('update', 'hour', averageTotal.value);
|
|
|
|
|
break;
|
|
|
|
|
case 4:
|
|
|
|
|
emit('update', 'hour', checkboxString.value);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// 周期两个值变化时
|
|
|
|
|
const cycleChange = () => {
|
|
|
|
|
if (radioValue.value === 2) {
|
|
|
|
|
emit('update', 'hour', cycleTotal.value);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// 平均两个值变化时
|
|
|
|
|
const averageChange = () => {
|
|
|
|
|
if (radioValue.value === 3) {
|
|
|
|
|
emit('update', 'hour', averageTotal.value);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// checkbox值变化时
|
|
|
|
|
const checkboxChange = () => {
|
|
|
|
|
if (radioValue.value === 4) {
|
|
|
|
|
emit('update', 'hour', checkboxString.value);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// 监听变化
|
|
|
|
|
watch(() => radioValue.value, radioChange);
|
|
|
|
|
watch(() => cycleTotal.value, cycleChange);
|
|
|
|
|
watch(() => averageTotal.value, averageChange);
|
|
|
|
|
watch(() => checkboxString.value, checkboxChange);
|
|
|
|
|
</script>
|
|
|
|
|