element-plus
Version:
A Component Library for Vue 3
238 lines (237 loc) • 5.31 kB
JavaScript
import { UPDATE_MODEL_EVENT } from "../../../constants/event.mjs";
import { isString } from "../../../utils/types.mjs";
import { buildProps, definePropType } from "../../../utils/vue/props/runtime.mjs";
import { iconPropType } from "../../../utils/vue/icon.mjs";
import { mutable } from "../../../utils/typescript.mjs";
import { useSizeProp } from "../../../hooks/use-size/index.mjs";
import { useAriaProps } from "../../../hooks/use-aria/index.mjs";
import { CircleClose } from "@element-plus/icons-vue";
import { markRaw } from "vue";
//#region ../../packages/components/input/src/input.ts
/**
* @deprecated Removed after 3.0.0, Use `InputProps` instead.
*/
const inputProps = buildProps({
/**
* @description native input id
*/
id: {
type: String,
default: void 0
},
/**
* @description input box size
*/
size: useSizeProp,
/**
* @description whether to disable
*/
disabled: {
type: Boolean,
default: void 0
},
/**
* @description binding value
*/
modelValue: {
type: definePropType([
String,
Number,
Object
]),
default: ""
},
/**
* @description v-model modifiers, reference [Vue modifiers](https://vuejs.org/guide/essentials/forms.html#modifiers)
*/
modelModifiers: {
type: definePropType(Object),
default: () => ({})
},
/**
* @description same as `maxlength` in native input
*/
maxlength: { type: [String, Number] },
/**
* @description same as `minlength` in native input
*/
minlength: { type: [String, Number] },
/**
* @description type of input, see more in [MDN](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Form_%3Cinput%3E_types)
*/
type: {
type: definePropType(String),
default: "text"
},
/**
* @description control the resizability
*/
resize: {
type: String,
values: [
"none",
"both",
"horizontal",
"vertical"
]
},
/**
* @description whether textarea has an adaptive height
*/
autosize: {
type: definePropType([Boolean, Object]),
default: false
},
/**
* @description native input autocomplete
*/
autocomplete: {
type: definePropType(String),
default: "off"
},
/**
* @description format content
*/
formatter: { type: Function },
/**
* @description parse content
*/
parser: { type: Function },
/**
* @description placeholder
*/
placeholder: { type: String },
/**
* @description native input form
*/
form: { type: String },
/**
* @description native input readonly
*/
readonly: Boolean,
/**
* @description whether to show clear button
*/
clearable: Boolean,
/**
* @description custom clear icon component
*/
clearIcon: {
type: iconPropType,
default: CircleClose
},
/**
* @description toggleable password input
*/
showPassword: Boolean,
/**
* @description word count
*/
showWordLimit: Boolean,
/**
* @description word count position, valid when `show-word-limit` is true
*/
wordLimitPosition: {
type: String,
values: ["inside", "outside"],
default: "inside"
},
/**
* @description suffix icon
*/
suffixIcon: { type: iconPropType },
/**
* @description prefix icon
*/
prefixIcon: { type: iconPropType },
/**
* @description container role, internal properties provided for use by the picker component
*/
containerRole: {
type: String,
default: void 0
},
/**
* @description input tabindex
*/
tabindex: {
type: [String, Number],
default: 0
},
/**
* @description whether to trigger form validation
*/
validateEvent: {
type: Boolean,
default: true
},
/**
* @description input or textarea element style
*/
inputStyle: {
type: definePropType([
Object,
Array,
String,
Boolean
]),
default: () => mutable({})
},
/**
* @description Count graphemes of input value. If it's set, native maxlength and minlength won't be used.
*/
countGraphemes: { type: definePropType(Function) },
/**
* @description native input autofocus
*/
autofocus: Boolean,
rows: {
type: Number,
default: 2
},
...useAriaProps(["ariaLabel"]),
/**
* @description native input mode for virtual keyboards
*/
inputmode: {
type: definePropType(String),
default: void 0
},
/**
* @description same as `name` in native input
*/
name: String
});
const inputEmits = {
[UPDATE_MODEL_EVENT]: (value) => isString(value),
input: (value) => isString(value),
change: (value, evt) => isString(value) && (evt instanceof Event || evt === void 0),
focus: (evt) => evt instanceof FocusEvent,
blur: (evt) => evt instanceof FocusEvent,
clear: (evt) => evt === void 0 || evt instanceof MouseEvent,
mouseleave: (evt) => evt instanceof MouseEvent,
mouseenter: (evt) => evt instanceof MouseEvent,
keydown: (evt) => evt instanceof Event,
compositionstart: (evt) => evt instanceof CompositionEvent,
compositionupdate: (evt) => evt instanceof CompositionEvent,
compositionend: (evt) => evt instanceof CompositionEvent
};
/**
* @description default values for InputProps, used in components that extend InputProps like Autocomplete
*/
const inputPropsDefaults = {
disabled: void 0,
modelValue: "",
modelModifiers: () => ({}),
type: "text",
autocomplete: "off",
clearIcon: markRaw(CircleClose),
wordLimitPosition: "inside",
tabindex: 0,
validateEvent: true,
inputStyle: () => ({}),
rows: 2
};
//#endregion
export { inputEmits, inputProps, inputPropsDefaults };
//# sourceMappingURL=input.mjs.map