2019-11-29 15:24:37 +08:00
|
|
|
# Disabled Time
|
|
|
|
```html
|
|
|
|
<n-date-picker
|
|
|
|
v-model="timestamp1"
|
|
|
|
type="date"
|
2019-12-27 22:42:04 +08:00
|
|
|
:is-date-disabled = "dateDisabled"
|
2019-11-29 15:24:37 +08:00
|
|
|
/>
|
|
|
|
<n-date-picker
|
|
|
|
v-model="timestamp2"
|
|
|
|
type="datetime"
|
2019-12-27 22:42:04 +08:00
|
|
|
:is-date-disabled = "dateDisabled"
|
|
|
|
:is-time-disabled= "timeDisabled"
|
2019-11-29 15:24:37 +08:00
|
|
|
/>
|
2019-12-30 20:38:43 +08:00
|
|
|
<n-date-picker
|
2019-11-29 15:24:37 +08:00
|
|
|
v-model="timestamp3"
|
|
|
|
type="daterange"
|
2019-12-30 20:38:43 +08:00
|
|
|
:is-date-disabled = "isRangeDateDisabled"
|
2019-11-29 15:24:37 +08:00
|
|
|
/>
|
|
|
|
<n-date-picker
|
|
|
|
v-model="timestamp4"
|
|
|
|
type="datetimerange"
|
2019-12-30 20:38:43 +08:00
|
|
|
:is-date-disabled = "isRangeDateDisabled"
|
|
|
|
:is-time-disabled= "isRangeTimeDisabled"
|
|
|
|
/>
|
2019-11-29 15:24:37 +08:00
|
|
|
```
|
|
|
|
```js
|
|
|
|
export default {
|
|
|
|
data () {
|
|
|
|
return {
|
2019-12-30 20:38:43 +08:00
|
|
|
timestamp1: 1576239200000,
|
|
|
|
timestamp2: 1576234000000,
|
|
|
|
timestamp3: [1576439200000, 1576739200000],
|
|
|
|
timestamp4: [1576234000000, 1576934000000],
|
2019-11-29 15:24:37 +08:00
|
|
|
}
|
|
|
|
},
|
|
|
|
methods: {
|
2019-12-04 11:05:05 +08:00
|
|
|
dateDisabled (current) {
|
2019-12-27 22:42:04 +08:00
|
|
|
const month = (new Date(current)).getMonth()
|
|
|
|
const date = (new Date(current)).getDate()
|
|
|
|
return month === 11 && date < 15
|
2019-12-04 11:05:05 +08:00
|
|
|
},
|
|
|
|
timeDisabled (current) {
|
2019-12-27 22:42:04 +08:00
|
|
|
const month = (new Date(current)).getMonth()
|
2019-12-04 11:05:05 +08:00
|
|
|
return {
|
2019-12-27 22:42:04 +08:00
|
|
|
isHourDisabled: (hour) => {
|
|
|
|
if (month === 11) {
|
2019-12-04 11:05:05 +08:00
|
|
|
return hour > 1 && hour <= 19
|
|
|
|
} else {
|
2019-12-16 18:21:29 +08:00
|
|
|
return false
|
2019-12-04 11:05:05 +08:00
|
|
|
}
|
|
|
|
},
|
2019-12-27 22:42:04 +08:00
|
|
|
isMinuteDisabled: (minute, selectedHour) => {
|
|
|
|
if (month === 11 && selectedHour === 22) {
|
2019-12-23 17:20:13 +08:00
|
|
|
return minute >= 20 && minute <= 30
|
2019-12-16 18:21:29 +08:00
|
|
|
} else {
|
2019-12-04 11:05:05 +08:00
|
|
|
return false
|
|
|
|
}
|
|
|
|
},
|
2019-12-27 22:42:04 +08:00
|
|
|
isSecondDisabled: (second, selectedMinute, selectedHour) => {
|
|
|
|
if (month === 11 && selectedHour === 12 && selectedMinute >= 40 && selectedMinute <= 50) {
|
2019-12-23 17:20:13 +08:00
|
|
|
return second >= 20 && second <= 30
|
|
|
|
} else {
|
2019-12-04 11:05:05 +08:00
|
|
|
return false
|
|
|
|
}
|
2019-12-27 22:42:04 +08:00
|
|
|
}
|
2019-12-04 11:05:05 +08:00
|
|
|
}
|
|
|
|
},
|
2019-12-30 20:38:43 +08:00
|
|
|
isRangeDateDisabled (current, type, range) {
|
|
|
|
const currentDate = new Date(current)
|
2019-12-04 11:05:05 +08:00
|
|
|
if (type === 'start') {
|
2019-12-30 20:38:43 +08:00
|
|
|
if (currentDate.getMonth() === 11) {
|
|
|
|
return currentDate.getDate() > 15
|
|
|
|
}
|
|
|
|
} else if (type === 'end') {
|
|
|
|
if (range) {
|
|
|
|
const [start, end] = range
|
|
|
|
return currentDate < start
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
isRangeTimeDisabled (current, type, range) {
|
|
|
|
const month = (new Date(current)).getMonth()
|
|
|
|
return {
|
|
|
|
isHourDisabled: (hour) => {
|
|
|
|
if (month === 11) {
|
|
|
|
return hour > 1 && hour <= 19
|
|
|
|
} else {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
isMinuteDisabled: (minute, selectedHour) => {
|
|
|
|
// debugger
|
|
|
|
if (month === 11 && selectedHour === 22) {
|
|
|
|
return minute >= 20 && minute <= 30
|
|
|
|
} else {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
isSecondDisabled: (second, selectedMinute, selectedHour) => {
|
|
|
|
if (month === 11 && selectedHour === 12 && selectedMinute >= 40 && selectedMinute <= 50) {
|
|
|
|
return second >= 20 && second <= 30
|
|
|
|
} else {
|
|
|
|
return false
|
|
|
|
}
|
2019-12-04 11:05:05 +08:00
|
|
|
}
|
|
|
|
}
|
2019-12-23 17:20:13 +08:00
|
|
|
},
|
|
|
|
},
|
2019-11-29 15:24:37 +08:00
|
|
|
}
|
|
|
|
```
|
|
|
|
```css
|
|
|
|
.n-date-picker {
|
|
|
|
margin: 0 12px 8px 0;
|
|
|
|
}
|
|
|
|
```
|