mirror of
https://gitee.com/ant-design-vue/ant-design-vue.git
synced 2024-12-16 01:41:15 +08:00
e13f4c566e
Fixed the issue where the component lost focus after selecting the date. Fixed the issue that cause Safari to unresponsive. Fixed the issue where WeekPicker's date selection box was not aligned with the input box. add da_DK he_IL hu_HU id_ID
203 lines
5.1 KiB
Vue
203 lines
5.1 KiB
Vue
|
|
import * as moment from 'moment'
|
|
import Calendar from '../vc-calendar'
|
|
import VcDatePicker from '../vc-calendar/src/Picker'
|
|
import Icon from '../icon'
|
|
import { hasProp, getOptionProps, initDefaultProps, getComponentFromProp, isValidElement } from '../_util/props-util'
|
|
import BaseMixin from '../_util/BaseMixin'
|
|
import { WeekPickerProps } from './interface'
|
|
import interopDefault from '../_util/interopDefault'
|
|
import { cloneElement } from '../_util/vnode'
|
|
|
|
function formatValue (value, format) {
|
|
return (value && value.format(format)) || ''
|
|
}
|
|
function noop () {}
|
|
|
|
export default {
|
|
// static defaultProps = {
|
|
// format: 'YYYY-wo',
|
|
// allowClear: true,
|
|
// };
|
|
|
|
// private input: any;
|
|
props: initDefaultProps(WeekPickerProps(), {
|
|
format: 'gggg-wo',
|
|
allowClear: true,
|
|
}),
|
|
name: 'AWeekPicker',
|
|
mixins: [BaseMixin],
|
|
model: {
|
|
prop: 'value',
|
|
event: 'change',
|
|
},
|
|
data () {
|
|
const value = this.value || this.defaultValue
|
|
if (value && !interopDefault(moment).isMoment(value)) {
|
|
throw new Error(
|
|
'The value/defaultValue of DatePicker or MonthPicker must be ' +
|
|
'a moment object',
|
|
)
|
|
}
|
|
return {
|
|
_value: value,
|
|
_open: this.open,
|
|
}
|
|
},
|
|
watch: {
|
|
value (val) {
|
|
this.setState({ _value: val })
|
|
},
|
|
open (val) {
|
|
this.setState({ _open: val })
|
|
},
|
|
},
|
|
|
|
methods: {
|
|
weekDateRender (current) {
|
|
const selectedValue = this.$data._value
|
|
const { prefixCls } = this
|
|
if (selectedValue &&
|
|
current.year() === selectedValue.year() &&
|
|
current.week() === selectedValue.week()) {
|
|
return (
|
|
<div class={`${prefixCls}-selected-day`}>
|
|
<div class={`${prefixCls}-date`}>
|
|
{current.date()}
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|
|
return (
|
|
<div class={`${prefixCls}-date`}>
|
|
{current.date()}
|
|
</div>
|
|
)
|
|
},
|
|
handleChange (value) {
|
|
if (!hasProp(this, 'value')) {
|
|
this.setState({ _value: value })
|
|
}
|
|
this.$emit('change', value, formatValue(value, this.format))
|
|
},
|
|
handleOpenChange (open) {
|
|
if (!hasProp(this, 'open')) {
|
|
this.setState({ _open: open })
|
|
}
|
|
this.$emit('openChange', open)
|
|
|
|
if (!open) {
|
|
this.focus()
|
|
}
|
|
},
|
|
clearSelection (e) {
|
|
e.preventDefault()
|
|
e.stopPropagation()
|
|
this.handleChange(null)
|
|
},
|
|
|
|
focus () {
|
|
this.$refs.input.focus()
|
|
},
|
|
|
|
blur () {
|
|
this.$refs.input.blur()
|
|
},
|
|
},
|
|
|
|
render () {
|
|
const props = getOptionProps(this)
|
|
let suffixIcon = getComponentFromProp(this, 'suffixIcon')
|
|
suffixIcon = Array.isArray(suffixIcon) ? suffixIcon[0] : suffixIcon
|
|
const {
|
|
prefixCls, disabled, pickerClass, popupStyle,
|
|
pickerInputClass, format, allowClear, locale, localeCode, disabledDate,
|
|
$data, $listeners, $scopedSlots,
|
|
} = this
|
|
const { _value: pickerValue, _open: open } = $data
|
|
const { focus = noop, blur = noop } = $listeners
|
|
|
|
if (pickerValue && localeCode) {
|
|
pickerValue.locale(localeCode)
|
|
}
|
|
|
|
const placeholder = hasProp(this, 'placeholder') ? this.placeholder : locale.lang.placeholder
|
|
const weekDateRender = this.dateRender || $scopedSlots.dateRender || this.weekDateRender
|
|
const calendar = (
|
|
<Calendar
|
|
showWeekNumber
|
|
dateRender={weekDateRender}
|
|
prefixCls={prefixCls}
|
|
format={format}
|
|
locale={locale.lang}
|
|
showDateInput={false}
|
|
showToday={false}
|
|
disabledDate={disabledDate}
|
|
/>
|
|
)
|
|
const clearIcon = (!disabled && allowClear && $data._value) ? (
|
|
<Icon
|
|
type='close-circle'
|
|
class={`${prefixCls}-picker-clear`}
|
|
onClick={this.clearSelection}
|
|
theme='filled'
|
|
/>
|
|
) : null
|
|
|
|
const inputIcon = suffixIcon && (
|
|
isValidElement(suffixIcon)
|
|
? cloneElement(
|
|
suffixIcon,
|
|
{
|
|
class: `${prefixCls}-picker-icon`,
|
|
},
|
|
) : <span class={`${prefixCls}-picker-icon`}>{suffixIcon}</span>) || (
|
|
<Icon type='calendar' class={`${prefixCls}-picker-icon`} />
|
|
)
|
|
|
|
const input = ({ value }) => {
|
|
return (
|
|
<span style={{ display: 'inline-block', width: '100%' }}>
|
|
<input
|
|
ref='input'
|
|
disabled={disabled}
|
|
readOnly
|
|
value={(value && value.format(format)) || ''}
|
|
placeholder={placeholder}
|
|
class={pickerInputClass}
|
|
onFocus={focus}
|
|
onBlur={blur}
|
|
/>
|
|
{clearIcon}
|
|
{inputIcon}
|
|
</span>
|
|
)
|
|
}
|
|
const vcDatePickerProps = {
|
|
props: {
|
|
...props,
|
|
calendar,
|
|
prefixCls: `${prefixCls}-picker-container`,
|
|
value: pickerValue,
|
|
open,
|
|
},
|
|
on: {
|
|
...$listeners,
|
|
change: this.handleChange,
|
|
openChange: this.handleOpenChange,
|
|
},
|
|
style: popupStyle,
|
|
}
|
|
return (
|
|
<span class={pickerClass}>
|
|
<VcDatePicker
|
|
{...vcDatePickerProps}
|
|
>
|
|
{input}
|
|
</VcDatePicker>
|
|
</span>
|
|
)
|
|
},
|
|
}
|
|
|