203 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			203 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | ||
| 	<el-form size='small'>
 | ||
| 		<el-form-item>
 | ||
| 			<el-radio v-model='radioValue' :label="1">
 | ||
| 				周,允许的通配符[, - * ? / L #]
 | ||
| 			</el-radio>
 | ||
| 		</el-form-item>
 | ||
| 
 | ||
| 		<el-form-item>
 | ||
| 			<el-radio v-model='radioValue' :label="2">
 | ||
| 				不指定
 | ||
| 			</el-radio>
 | ||
| 		</el-form-item>
 | ||
| 
 | ||
| 		<el-form-item>
 | ||
| 			<el-radio v-model='radioValue' :label="3">
 | ||
| 				周期从星期
 | ||
| 				<el-select clearable v-model="cycle01">
 | ||
| 					<el-option
 | ||
| 						v-for="(item,index) of weekList"
 | ||
| 						:key="index"
 | ||
| 						:label="item.value"
 | ||
| 						:value="item.key"
 | ||
| 						:disabled="item.key === 1"
 | ||
| 					>{{item.value}}</el-option>
 | ||
| 				</el-select>
 | ||
| 				-
 | ||
| 				<el-select clearable v-model="cycle02">
 | ||
| 					<el-option
 | ||
| 						v-for="(item,index) of weekList"
 | ||
| 						:key="index"
 | ||
| 						:label="item.value"
 | ||
| 						:value="item.key"
 | ||
| 						:disabled="item.key < cycle01 && item.key !== 1"
 | ||
| 					>{{item.value}}</el-option>
 | ||
| 				</el-select>
 | ||
| 			</el-radio>
 | ||
| 		</el-form-item>
 | ||
| 
 | ||
| 		<el-form-item>
 | ||
| 			<el-radio v-model='radioValue' :label="4">
 | ||
| 				第
 | ||
| 				<el-input-number v-model='average01' :min="1" :max="4" /> 周的星期
 | ||
| 				<el-select clearable v-model="average02">
 | ||
| 					<el-option v-for="(item,index) of weekList" :key="index" :label="item.value" :value="item.key">{{item.value}}</el-option>
 | ||
| 				</el-select>
 | ||
| 			</el-radio>
 | ||
| 		</el-form-item>
 | ||
| 
 | ||
| 		<el-form-item>
 | ||
| 			<el-radio v-model='radioValue' :label="5">
 | ||
| 				本月最后一个星期
 | ||
| 				<el-select clearable v-model="weekday">
 | ||
| 					<el-option v-for="(item,index) of weekList" :key="index" :label="item.value" :value="item.key">{{item.value}}</el-option>
 | ||
| 				</el-select>
 | ||
| 			</el-radio>
 | ||
| 		</el-form-item>
 | ||
| 
 | ||
| 		<el-form-item>
 | ||
| 			<el-radio v-model='radioValue' :label="6">
 | ||
| 				指定
 | ||
| 				<el-select clearable v-model="checkboxList" placeholder="可多选" multiple style="width:100%">
 | ||
| 					<el-option v-for="(item,index) of weekList" :key="index" :label="item.value" :value="item.key">{{item.value}}</el-option>
 | ||
| 				</el-select>
 | ||
| 			</el-radio>
 | ||
| 		</el-form-item>
 | ||
| 
 | ||
| 	</el-form>
 | ||
| </template>
 | ||
| 
 | ||
| <script>
 | ||
| export default {
 | ||
| 	data() {
 | ||
| 		return {
 | ||
| 			radioValue: 2,
 | ||
| 			weekday: 2,
 | ||
| 			cycle01: 2,
 | ||
| 			cycle02: 3,
 | ||
| 			average01: 1,
 | ||
| 			average02: 2,
 | ||
| 			checkboxList: [],
 | ||
| 			weekList: [
 | ||
| 				{
 | ||
| 					key: 2,
 | ||
| 					value: '星期一'
 | ||
| 				},
 | ||
| 				{
 | ||
| 					key: 3,
 | ||
| 					value: '星期二'
 | ||
| 				},
 | ||
| 				{
 | ||
| 					key: 4,
 | ||
| 					value: '星期三'
 | ||
| 				},
 | ||
| 				{
 | ||
| 					key: 5,
 | ||
| 					value: '星期四'
 | ||
| 				},
 | ||
| 				{
 | ||
| 					key: 6,
 | ||
| 					value: '星期五'
 | ||
| 				},
 | ||
| 				{
 | ||
| 					key: 7,
 | ||
| 					value: '星期六'
 | ||
| 				},
 | ||
| 				{
 | ||
| 					key: 1,
 | ||
| 					value: '星期日'
 | ||
| 				}
 | ||
| 			],
 | ||
| 			checkNum: this.$options.propsData.check
 | ||
| 		}
 | ||
| 	},
 | ||
| 	name: 'crontab-week',
 | ||
| 	props: ['check', 'cron'],
 | ||
| 	methods: {
 | ||
| 		// 单选按钮值变化时
 | ||
| 		radioChange() {
 | ||
| 			if (this.radioValue !== 2 && this.cron.day !== '?') {
 | ||
| 				this.$emit('update', 'day', '?', 'week');
 | ||
| 			}
 | ||
| 			switch (this.radioValue) {
 | ||
| 				case 1:
 | ||
| 					this.$emit('update', 'week', '*');
 | ||
| 					break;
 | ||
| 				case 2:
 | ||
| 					this.$emit('update', 'week', '?');
 | ||
| 					break;
 | ||
| 				case 3:
 | ||
| 					this.$emit('update', 'week', this.cycleTotal);
 | ||
| 					break;
 | ||
| 				case 4:
 | ||
| 					this.$emit('update', 'week', this.averageTotal);
 | ||
| 					break;
 | ||
| 				case 5:
 | ||
| 					this.$emit('update', 'week', this.weekdayCheck + 'L');
 | ||
| 					break;
 | ||
| 				case 6:
 | ||
| 					this.$emit('update', 'week', this.checkboxString);
 | ||
| 					break;
 | ||
| 			}
 | ||
| 		},
 | ||
| 
 | ||
| 		// 周期两个值变化时
 | ||
| 		cycleChange() {
 | ||
| 			if (this.radioValue == '3') {
 | ||
| 				this.$emit('update', 'week', this.cycleTotal);
 | ||
| 			}
 | ||
| 		},
 | ||
| 		// 平均两个值变化时
 | ||
| 		averageChange() {
 | ||
| 			if (this.radioValue == '4') {
 | ||
| 				this.$emit('update', 'week', this.averageTotal);
 | ||
| 			}
 | ||
| 		},
 | ||
| 		// 最近工作日值变化时
 | ||
| 		weekdayChange() {
 | ||
| 			if (this.radioValue == '5') {
 | ||
| 				this.$emit('update', 'week', this.weekday + 'L');
 | ||
| 			}
 | ||
| 		},
 | ||
| 		// checkbox值变化时
 | ||
| 		checkboxChange() {
 | ||
| 			if (this.radioValue == '6') {
 | ||
| 				this.$emit('update', 'week', this.checkboxString);
 | ||
| 			}
 | ||
| 		},
 | ||
| 	},
 | ||
| 	watch: {
 | ||
| 		'radioValue': 'radioChange',
 | ||
| 		'cycleTotal': 'cycleChange',
 | ||
| 		'averageTotal': 'averageChange',
 | ||
| 		'weekdayCheck': 'weekdayChange',
 | ||
| 		'checkboxString': 'checkboxChange',
 | ||
| 	},
 | ||
| 	computed: {
 | ||
| 		// 计算两个周期值
 | ||
| 		cycleTotal: function () {
 | ||
| 			this.cycle01 = this.checkNum(this.cycle01, 1, 7)
 | ||
| 			this.cycle02 = this.checkNum(this.cycle02, 1, 7)
 | ||
| 			return this.cycle01 + '-' + this.cycle02;
 | ||
| 		},
 | ||
| 		// 计算平均用到的值
 | ||
| 		averageTotal: function () {
 | ||
| 			this.average01 = this.checkNum(this.average01, 1, 4)
 | ||
| 			this.average02 = this.checkNum(this.average02, 1, 7)
 | ||
| 			return this.average02 + '#' + this.average01;
 | ||
| 		},
 | ||
| 		// 最近的工作日(格式)
 | ||
| 		weekdayCheck: function () {
 | ||
| 			this.weekday = this.checkNum(this.weekday, 1, 7)
 | ||
| 			return this.weekday;
 | ||
| 		},
 | ||
| 		// 计算勾选的checkbox值合集
 | ||
| 		checkboxString: function () {
 | ||
| 			let str = this.checkboxList.join();
 | ||
| 			return str == '' ? '*' : str;
 | ||
| 		}
 | ||
| 	}
 | ||
| }
 | ||
| </script>
 | 
