2018-03-19 02:16:27 +00:00
|
|
|
|
2018-03-08 15:02:04 +00:00
|
|
|
import PropTypes from '../_util/vue-types'
|
|
|
|
import BaseMixin from '../_util/BaseMixin'
|
2018-11-02 12:39:54 +00:00
|
|
|
import Trigger from '../vc-trigger'
|
2018-03-07 14:21:55 +00:00
|
|
|
import Panel from './Panel'
|
|
|
|
import placements from './placements'
|
|
|
|
import moment from 'moment'
|
2018-11-10 14:03:00 +00:00
|
|
|
import { initDefaultProps, hasProp, getComponentFromProp } from '../_util/props-util'
|
2018-03-07 14:21:55 +00:00
|
|
|
|
|
|
|
function noop () {
|
|
|
|
}
|
|
|
|
|
2018-03-08 15:02:04 +00:00
|
|
|
export default {
|
|
|
|
mixins: [BaseMixin],
|
2018-06-17 07:56:12 +00:00
|
|
|
name: 'VcTimePicker',
|
2018-03-08 15:02:04 +00:00
|
|
|
props: initDefaultProps({
|
2018-03-07 14:21:55 +00:00
|
|
|
prefixCls: PropTypes.string,
|
|
|
|
clearText: PropTypes.string,
|
2018-03-08 15:02:04 +00:00
|
|
|
value: PropTypes.any,
|
|
|
|
defaultOpenValue: {
|
|
|
|
type: Object,
|
|
|
|
default: () => {
|
|
|
|
return moment()
|
|
|
|
},
|
|
|
|
},
|
2018-03-07 14:21:55 +00:00
|
|
|
inputReadOnly: PropTypes.bool,
|
|
|
|
disabled: PropTypes.bool,
|
|
|
|
allowEmpty: PropTypes.bool,
|
2018-03-08 15:02:04 +00:00
|
|
|
defaultValue: PropTypes.any,
|
2018-03-07 14:21:55 +00:00
|
|
|
open: PropTypes.bool,
|
|
|
|
defaultOpen: PropTypes.bool,
|
|
|
|
align: PropTypes.object,
|
|
|
|
placement: PropTypes.any,
|
|
|
|
transitionName: PropTypes.string,
|
|
|
|
getPopupContainer: PropTypes.func,
|
|
|
|
placeholder: PropTypes.string,
|
|
|
|
format: PropTypes.string,
|
|
|
|
showHour: PropTypes.bool,
|
|
|
|
showMinute: PropTypes.bool,
|
|
|
|
showSecond: PropTypes.bool,
|
|
|
|
popupClassName: PropTypes.string,
|
|
|
|
disabledHours: PropTypes.func,
|
|
|
|
disabledMinutes: PropTypes.func,
|
|
|
|
disabledSeconds: PropTypes.func,
|
|
|
|
hideDisabledOptions: PropTypes.bool,
|
2018-03-08 15:02:04 +00:00
|
|
|
// onChange: PropTypes.func,
|
|
|
|
// onOpen: PropTypes.func,
|
|
|
|
// onClose: PropTypes.func,
|
|
|
|
// onFocus: PropTypes.func,
|
|
|
|
// onBlur: PropTypes.func,
|
2018-03-07 14:21:55 +00:00
|
|
|
name: PropTypes.string,
|
|
|
|
autoComplete: PropTypes.string,
|
|
|
|
use12Hours: PropTypes.bool,
|
|
|
|
hourStep: PropTypes.number,
|
|
|
|
minuteStep: PropTypes.number,
|
|
|
|
secondStep: PropTypes.number,
|
|
|
|
focusOnOpen: PropTypes.bool,
|
2018-03-08 15:02:04 +00:00
|
|
|
// onKeyDown: PropTypes.func,
|
2018-03-07 14:21:55 +00:00
|
|
|
autoFocus: PropTypes.bool,
|
2018-03-13 02:19:00 +00:00
|
|
|
id: PropTypes.string,
|
2018-11-10 14:03:00 +00:00
|
|
|
inputIcon: PropTypes.any,
|
|
|
|
clearIcon: PropTypes.any,
|
2018-12-09 09:34:27 +00:00
|
|
|
addon: PropTypes.func,
|
2018-03-08 15:02:04 +00:00
|
|
|
}, {
|
2018-03-07 14:21:55 +00:00
|
|
|
clearText: 'clear',
|
|
|
|
prefixCls: 'rc-time-picker',
|
|
|
|
defaultOpen: false,
|
|
|
|
inputReadOnly: false,
|
|
|
|
popupClassName: '',
|
|
|
|
align: {},
|
2018-03-13 02:19:00 +00:00
|
|
|
id: '',
|
2018-03-07 14:21:55 +00:00
|
|
|
allowEmpty: true,
|
|
|
|
showHour: true,
|
|
|
|
showMinute: true,
|
|
|
|
showSecond: true,
|
|
|
|
disabledHours: noop,
|
|
|
|
disabledMinutes: noop,
|
|
|
|
disabledSeconds: noop,
|
|
|
|
hideDisabledOptions: false,
|
|
|
|
placement: 'bottomLeft',
|
|
|
|
use12Hours: false,
|
|
|
|
focusOnOpen: false,
|
2018-03-08 15:02:04 +00:00
|
|
|
}),
|
|
|
|
data () {
|
|
|
|
const { defaultOpen, defaultValue, open = defaultOpen, value = defaultValue } = this
|
|
|
|
return {
|
|
|
|
sOpen: open,
|
|
|
|
sValue: value,
|
2018-03-07 14:21:55 +00:00
|
|
|
}
|
2018-03-08 15:02:04 +00:00
|
|
|
},
|
2018-06-17 07:56:12 +00:00
|
|
|
mounted () {
|
|
|
|
this.$nextTick(() => {
|
|
|
|
if (this.autoFocus) {
|
|
|
|
this.focus()
|
|
|
|
}
|
|
|
|
})
|
|
|
|
},
|
2018-03-07 14:21:55 +00:00
|
|
|
|
2018-03-08 15:02:04 +00:00
|
|
|
watch: {
|
|
|
|
value (val) {
|
2018-03-07 14:21:55 +00:00
|
|
|
this.setState({
|
2018-03-08 15:02:04 +00:00
|
|
|
sValue: val,
|
2018-03-07 14:21:55 +00:00
|
|
|
})
|
2018-03-08 15:02:04 +00:00
|
|
|
},
|
|
|
|
open (val) {
|
|
|
|
if (val !== undefined) {
|
|
|
|
this.setState({
|
|
|
|
sOpen: val,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
onPanelChange (value) {
|
|
|
|
this.setValue(value)
|
|
|
|
},
|
2018-03-07 14:21:55 +00:00
|
|
|
|
2018-03-08 15:02:04 +00:00
|
|
|
onPanelClear () {
|
|
|
|
this.setValue(null)
|
|
|
|
this.setOpen(false)
|
|
|
|
},
|
2018-03-07 14:21:55 +00:00
|
|
|
|
2018-03-08 15:02:04 +00:00
|
|
|
onVisibleChange (open) {
|
|
|
|
this.setOpen(open)
|
|
|
|
},
|
2018-03-07 14:21:55 +00:00
|
|
|
|
2018-03-08 15:02:04 +00:00
|
|
|
onEsc () {
|
|
|
|
this.setOpen(false)
|
|
|
|
this.focus()
|
|
|
|
},
|
2018-03-07 14:21:55 +00:00
|
|
|
|
2018-03-08 15:02:04 +00:00
|
|
|
onKeyDown (e) {
|
|
|
|
if (e.keyCode === 40) {
|
|
|
|
this.setOpen(true)
|
|
|
|
}
|
|
|
|
},
|
|
|
|
onKeyDown2 (e) {
|
|
|
|
this.__emit('keydown', e)
|
|
|
|
},
|
2018-03-07 14:21:55 +00:00
|
|
|
|
2018-03-08 15:02:04 +00:00
|
|
|
setValue (value) {
|
|
|
|
if (!hasProp(this, 'value')) {
|
|
|
|
this.setState({
|
|
|
|
sValue: value,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
this.__emit('change', value)
|
|
|
|
},
|
2018-03-07 14:21:55 +00:00
|
|
|
|
2018-03-08 15:02:04 +00:00
|
|
|
getFormat () {
|
|
|
|
const { format, showHour, showMinute, showSecond, use12Hours } = this
|
|
|
|
if (format) {
|
|
|
|
return format
|
|
|
|
}
|
2018-03-07 14:21:55 +00:00
|
|
|
|
2018-03-08 15:02:04 +00:00
|
|
|
if (use12Hours) {
|
|
|
|
const fmtString = ([
|
|
|
|
showHour ? 'h' : '',
|
|
|
|
showMinute ? 'mm' : '',
|
|
|
|
showSecond ? 'ss' : '',
|
|
|
|
].filter(item => !!item).join(':'))
|
|
|
|
|
|
|
|
return fmtString.concat(' a')
|
|
|
|
}
|
2018-03-07 14:21:55 +00:00
|
|
|
|
2018-03-08 15:02:04 +00:00
|
|
|
return [
|
|
|
|
showHour ? 'HH' : '',
|
2018-03-07 14:21:55 +00:00
|
|
|
showMinute ? 'mm' : '',
|
|
|
|
showSecond ? 'ss' : '',
|
2018-03-08 15:02:04 +00:00
|
|
|
].filter(item => !!item).join(':')
|
|
|
|
},
|
2018-03-07 14:21:55 +00:00
|
|
|
|
2018-03-08 15:02:04 +00:00
|
|
|
getPanelElement () {
|
|
|
|
const {
|
2018-12-09 09:34:27 +00:00
|
|
|
prefixCls, placeholder, disabledHours, addon,
|
2018-03-08 15:02:04 +00:00
|
|
|
disabledMinutes, disabledSeconds, hideDisabledOptions, inputReadOnly,
|
|
|
|
allowEmpty, showHour, showMinute, showSecond, defaultOpenValue, clearText,
|
|
|
|
use12Hours, focusOnOpen, onKeyDown2, hourStep, minuteStep, secondStep,
|
|
|
|
sValue,
|
|
|
|
} = this
|
2018-11-10 14:03:00 +00:00
|
|
|
const clearIcon = getComponentFromProp(this, 'clearIcon')
|
2018-03-08 15:02:04 +00:00
|
|
|
return (
|
|
|
|
<Panel
|
|
|
|
clearText={clearText}
|
|
|
|
prefixCls={`${prefixCls}-panel`}
|
|
|
|
ref='panel'
|
|
|
|
value={sValue}
|
|
|
|
inputReadOnly={inputReadOnly}
|
|
|
|
onChange={this.onPanelChange}
|
|
|
|
onClear={this.onPanelClear}
|
|
|
|
defaultOpenValue={defaultOpenValue}
|
|
|
|
showHour={showHour}
|
|
|
|
showMinute={showMinute}
|
|
|
|
showSecond={showSecond}
|
|
|
|
onEsc={this.onEsc}
|
|
|
|
allowEmpty={allowEmpty}
|
|
|
|
format={this.getFormat()}
|
|
|
|
placeholder={placeholder}
|
|
|
|
disabledHours={disabledHours}
|
|
|
|
disabledMinutes={disabledMinutes}
|
|
|
|
disabledSeconds={disabledSeconds}
|
|
|
|
hideDisabledOptions={hideDisabledOptions}
|
|
|
|
use12Hours={use12Hours}
|
|
|
|
hourStep={hourStep}
|
|
|
|
minuteStep={minuteStep}
|
|
|
|
secondStep={secondStep}
|
|
|
|
focusOnOpen={focusOnOpen}
|
2018-11-10 14:03:00 +00:00
|
|
|
onKeydown={onKeyDown2}
|
|
|
|
clearIcon={clearIcon}
|
2018-12-09 09:34:27 +00:00
|
|
|
addon={addon}
|
|
|
|
/>
|
2018-03-08 15:02:04 +00:00
|
|
|
)
|
|
|
|
},
|
2018-03-07 14:21:55 +00:00
|
|
|
|
2018-03-08 15:02:04 +00:00
|
|
|
getPopupClassName () {
|
|
|
|
const { showHour, showMinute, showSecond, use12Hours, prefixCls } = this
|
|
|
|
let popupClassName = this.popupClassName
|
|
|
|
// Keep it for old compatibility
|
|
|
|
if ((!showHour || !showMinute || !showSecond) && !use12Hours) {
|
|
|
|
popupClassName += ` ${prefixCls}-panel-narrow`
|
2018-03-07 14:21:55 +00:00
|
|
|
}
|
2018-03-08 15:02:04 +00:00
|
|
|
let selectColumnCount = 0
|
|
|
|
if (showHour) {
|
|
|
|
selectColumnCount += 1
|
2018-03-07 14:21:55 +00:00
|
|
|
}
|
2018-03-08 15:02:04 +00:00
|
|
|
if (showMinute) {
|
|
|
|
selectColumnCount += 1
|
|
|
|
}
|
|
|
|
if (showSecond) {
|
|
|
|
selectColumnCount += 1
|
|
|
|
}
|
|
|
|
if (use12Hours) {
|
|
|
|
selectColumnCount += 1
|
|
|
|
}
|
|
|
|
popupClassName += ` ${prefixCls}-panel-column-${selectColumnCount}`
|
|
|
|
return popupClassName
|
|
|
|
},
|
|
|
|
|
|
|
|
setOpen (open) {
|
|
|
|
if (this.sOpen !== open) {
|
|
|
|
if (!hasProp(this, 'open')) {
|
|
|
|
this.setState({ sOpen: open })
|
|
|
|
}
|
|
|
|
if (open) {
|
|
|
|
this.__emit('open', { open })
|
|
|
|
} else {
|
|
|
|
this.__emit('close', { open })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
2018-03-07 14:21:55 +00:00
|
|
|
|
2018-03-08 15:02:04 +00:00
|
|
|
focus () {
|
|
|
|
this.$refs.picker.focus()
|
|
|
|
},
|
2018-03-07 14:21:55 +00:00
|
|
|
|
2018-03-08 15:02:04 +00:00
|
|
|
blur () {
|
|
|
|
this.$refs.picker.blur()
|
|
|
|
},
|
|
|
|
onFocus (e) {
|
|
|
|
this.__emit('focus', e)
|
|
|
|
},
|
|
|
|
onBlur (e) {
|
|
|
|
this.__emit('blur', e)
|
|
|
|
},
|
|
|
|
},
|
2018-03-07 14:21:55 +00:00
|
|
|
|
|
|
|
render () {
|
|
|
|
const {
|
2018-03-13 02:19:00 +00:00
|
|
|
prefixCls, placeholder, placement, align, id,
|
2018-03-08 15:02:04 +00:00
|
|
|
disabled, transitionName, getPopupContainer, name, autoComplete,
|
|
|
|
autoFocus, inputReadOnly, sOpen, sValue, onFocus, onBlur,
|
|
|
|
} = this
|
2018-03-07 14:21:55 +00:00
|
|
|
const popupClassName = this.getPopupClassName()
|
2018-11-10 14:03:00 +00:00
|
|
|
const inputIcon = getComponentFromProp(this, 'inputIcon')
|
2018-03-07 14:21:55 +00:00
|
|
|
return (
|
|
|
|
<Trigger
|
|
|
|
prefixCls={`${prefixCls}-panel`}
|
|
|
|
popupClassName={popupClassName}
|
|
|
|
popupAlign={align}
|
|
|
|
builtinPlacements={placements}
|
|
|
|
popupPlacement={placement}
|
|
|
|
action={disabled ? [] : ['click']}
|
|
|
|
destroyPopupOnHide
|
|
|
|
getPopupContainer={getPopupContainer}
|
|
|
|
popupTransitionName={transitionName}
|
2018-03-08 15:02:04 +00:00
|
|
|
popupVisible={sOpen}
|
2018-03-07 14:21:55 +00:00
|
|
|
onPopupVisibleChange={this.onVisibleChange}
|
|
|
|
>
|
2018-03-08 15:02:04 +00:00
|
|
|
<template slot='popup'>
|
|
|
|
{this.getPanelElement()}
|
|
|
|
</template>
|
|
|
|
<span class={`${prefixCls}`}>
|
2018-03-07 14:21:55 +00:00
|
|
|
<input
|
2018-03-08 15:02:04 +00:00
|
|
|
class={`${prefixCls}-input`}
|
|
|
|
ref='picker'
|
2018-03-07 14:21:55 +00:00
|
|
|
type='text'
|
|
|
|
placeholder={placeholder}
|
|
|
|
name={name}
|
2018-03-08 15:02:04 +00:00
|
|
|
onKeydown={this.onKeyDown}
|
2018-03-07 14:21:55 +00:00
|
|
|
disabled={disabled}
|
2018-03-08 15:02:04 +00:00
|
|
|
value={sValue && sValue.format(this.getFormat()) || ''}
|
2018-03-07 14:21:55 +00:00
|
|
|
autoComplete={autoComplete}
|
|
|
|
onFocus={onFocus}
|
|
|
|
onBlur={onBlur}
|
|
|
|
autoFocus={autoFocus}
|
|
|
|
readOnly={!!inputReadOnly}
|
2018-03-13 02:19:00 +00:00
|
|
|
id={id}
|
2018-03-07 14:21:55 +00:00
|
|
|
/>
|
2018-11-10 14:03:00 +00:00
|
|
|
{inputIcon || <span class={`${prefixCls}-icon`}/>}
|
2018-03-07 14:21:55 +00:00
|
|
|
</span>
|
|
|
|
</Trigger>
|
|
|
|
)
|
2018-03-08 15:02:04 +00:00
|
|
|
},
|
2018-03-07 14:21:55 +00:00
|
|
|
}
|
2018-03-19 02:16:27 +00:00
|
|
|
|