feat(components): [date/time-picker] add id attribute to the inputs (#4972)

* feat(components): [date/time-picker] add id attribute to the inputs

* docs(components): [date/time-picker] add id to attributes
This commit is contained in:
Delyan Haralanov 2021-12-27 10:04:39 +02:00 committed by GitHub
parent f85621d209
commit 542ea5ee7e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 33 additions and 24 deletions

View File

@ -199,6 +199,7 @@ Note, date time locale (month name, first day of the week ...) are also configur
| default-value | optional, default date of the calendar | Date | anything accepted by `new Date()` | — | | default-value | optional, default date of the calendar | Date | anything accepted by `new Date()` | — |
| default-time | optional, the time value to use when selecting date range | Date[] | Array with length 2, each item is a Date. The first item for the start date and then second item for the end date | — | | default-time | optional, the time value to use when selecting date range | Date[] | Array with length 2, each item is a Date. The first item for the start date and then second item for the end date | — |
| value-format | optional, format of binding value. If not specified, the binding value will be a Date object | string | see [date formats](/en-US/component/date-picker#date-formats) | — | | value-format | optional, format of binding value. If not specified, the binding value will be a Date object | string | see [date formats](/en-US/component/date-picker#date-formats) | — |
| id | same as `id` in native input | string / array(string) | String `id="my-date"` or array `:id="['my-range-start', 'my-range-end']"` for date range | - |
| name | same as `name` in native input | string | — | — | | name | same as `name` in native input | string | — | — |
| unlink-panels | unlink two date-panels in range-picker | boolean | — | false | | unlink-panels | unlink two date-panels in range-picker | boolean | — | false |
| prefix-icon | custom prefix icon component | string / Component | — | Date | | prefix-icon | custom prefix icon component | string / Component | — | Date |

View File

@ -78,6 +78,7 @@ datetime-picker/default-time
| range-separator | range separator | string | - | '-' | | range-separator | range separator | string | - | '-' |
| default-value | optional, default date of the calendar | Date | anything accepted by `new Date()` | — | | default-value | optional, default date of the calendar | Date | anything accepted by `new Date()` | — |
| default-time | the default time value after picking a date | non-range: Date / range: Date[] | non-range: a Date object, range: array of two Date objects, and the first item is for the start date and second for the end date. Time `00:00:00` will be used if not specified | — | | default-time | the default time value after picking a date | non-range: Date / range: Date[] | non-range: a Date object, range: array of two Date objects, and the first item is for the start date and second for the end date. Time `00:00:00` will be used if not specified | — |
| id | same as `id` in native input | string / array(string) | String `id="my-datetime"` or array `:id="['my-range-start', 'my-range-end']"` for date range | - |
| name | same as `name` in native input | string | — | — | | name | same as `name` in native input | string | — | — |
| unlink-panels | unllink two date-panels in range-picker | boolean | — | false | | unlink-panels | unllink two date-panels in range-picker | boolean | — | false |
| prefix-icon | Custom prefix icon component | string | — | Date | | prefix-icon | Custom prefix icon component | string | — | Date |

View File

@ -30,7 +30,7 @@ time-picker/range
## Attributes ## Attributes
| Attribute | Description | Type | Accepted Values | Default | | Attribute | Description | Type | Accepted Values | Default |
| --------------------- | ------------------------------------------------------- | ------------------------------------------ | --------------------------------------------------------------------------------- | ----------- | | --------------------- | ------------------------------------------------------- | ------------------------------------------ | ----------------------------------------------------------------------------------- | ----------- |
| model-value / v-model | binding value | Date | — | — | | model-value / v-model | binding value | Date | — | — |
| readonly | whether TimePicker is read only | boolean | — | false | | readonly | whether TimePicker is read only | boolean | — | false |
| disabled | whether TimePicker is disabled | boolean | — | false | | disabled | whether TimePicker is disabled | boolean | — | false |
@ -47,6 +47,7 @@ time-picker/range
| range-separator | range separator | string | — | '-' | | range-separator | range separator | string | — | '-' |
| format | format of the displayed value in the input box | string | see [date formats](/en-US/component/date-picker#date-formats) | HH:mm:ss | | format | format of the displayed value in the input box | string | see [date formats](/en-US/component/date-picker#date-formats) | HH:mm:ss |
| default-value | optional, default date of the calendar | Date for TimePicker, string for TimeSelect | anything accepted by `new Date()` for TimePicker, selectable value for TimeSelect | — | | default-value | optional, default date of the calendar | Date for TimePicker, string for TimeSelect | anything accepted by `new Date()` for TimePicker, selectable value for TimeSelect | — |
| id | same as `id` in native input | string / array(string) | String `id="my-time"` or array `:id="['my-range-start', 'my-range-end']"` for range | - |
| name | same as `name` in native input | string | — | — | | name | same as `name` in native input | string | — | — |
| prefix-icon | Custom prefix icon component | string / Component | — | Clock | | prefix-icon | Custom prefix icon component | string / Component | — | Clock |
| clear-icon | Custom clear icon component | string / Component | — | CircleClose | | clear-icon | Custom clear icon component | string / Component | — | CircleClose |

View File

@ -20,6 +20,7 @@
<template #trigger> <template #trigger>
<el-input <el-input
v-if="!isRangeInput" v-if="!isRangeInput"
:id="id"
v-clickoutside:[popperPaneRef]="onClickOutside" v-clickoutside:[popperPaneRef]="onClickOutside"
:model-value="displayValue" :model-value="displayValue"
:name="name" :name="name"
@ -78,6 +79,7 @@
<component :is="triggerIcon"></component> <component :is="triggerIcon"></component>
</el-icon> </el-icon>
<input <input
:id="id && id[0]"
autocomplete="off" autocomplete="off"
:name="name && name[0]" :name="name && name[0]"
:placeholder="startPlaceholder" :placeholder="startPlaceholder"
@ -93,6 +95,7 @@
<span class="el-range-separator">{{ rangeSeparator }}</span> <span class="el-range-separator">{{ rangeSeparator }}</span>
</slot> </slot>
<input <input
:id="id && id[1]"
autocomplete="off" autocomplete="off"
:name="name && name[1]" :name="name && name[1]"
:placeholder="endPlaceholder" :placeholder="endPlaceholder"

View File

@ -6,6 +6,9 @@ import type { Options } from '@popperjs/core'
import type { ComponentSize } from '@element-plus/utils/types' import type { ComponentSize } from '@element-plus/utils/types'
export const timePickerDefaultProps = { export const timePickerDefaultProps = {
id: {
type: [Array, String],
},
name: { name: {
type: [Array, String], type: [Array, String],
default: '', default: '',