Refactor #4209 - For InputMask

pull/4224/head
Tuğçe Küçükoğlu 2023-07-26 10:58:30 +03:00
parent 38bd2712e9
commit ea6bd0fb3a
2 changed files with 38 additions and 2 deletions

View File

@ -10,7 +10,16 @@
import { ComponentHooks } from '../basecomponent'; import { ComponentHooks } from '../basecomponent';
import { ClassComponent, GlobalComponentConstructor } from '../ts-helpers'; import { ClassComponent, GlobalComponentConstructor } from '../ts-helpers';
export declare type InputMaskPassThroughOptionType = InputMaskPassThroughAttributes | null | undefined; export declare type InputMaskPassThroughOptionType = InputMaskPassThroughAttributes | ((options: InputMaskPassThroughMethodOptions) => InputMaskPassThroughAttributes | string) | string | null | undefined;
/**
* Custom passthrough(pt) option method.
*/
export interface InputMaskPassThroughMethodOptions {
instance: any;
props: InputMaskProps;
context: InputMaskContext;
}
/** /**
* Custom passthrough(pt) options. * Custom passthrough(pt) options.
@ -35,6 +44,22 @@ export interface InputMaskPassThroughAttributes {
[key: string]: any; [key: string]: any;
} }
/**
* Defines current options in InputMask component.
*/
export interface InputMaskContext {
/**
* Current filled state of the component as a boolean.
* @defaultValue false
*/
filled: boolean;
/**
* Current disabled state of the component as a boolean.
* @defaultValue false
*/
disabled: boolean;
}
/** /**
* Defines valid properties in InputMask component. * Defines valid properties in InputMask component.
*/ */
@ -79,6 +104,9 @@ export interface InputMaskProps {
unstyled?: boolean; unstyled?: boolean;
} }
/**
* Defines valid slots in InputMask component.
*/
export interface InputMaskSlots {} export interface InputMaskSlots {}
/** /**

View File

@ -1,5 +1,5 @@
<template> <template>
<input :class="cx('root')" :readonly="readonly" @input="onInput" @focus="onFocus" @blur="onBlur" @keydown="onKeyDown" @keypress="onKeyPress" @paste="onPaste" v-bind="ptm('root')" data-pc-name="inputmask" /> <input :class="cx('root')" :readonly="readonly" @input="onInput" @focus="onFocus" @blur="onBlur" @keydown="onKeyDown" @keypress="onKeyPress" @paste="onPaste" v-bind="ptm('root', ptmParams)" data-pc-name="inputmask" />
</template> </template>
<script> <script>
@ -496,6 +496,14 @@ export default {
computed: { computed: {
filled() { filled() {
return this.modelValue != null && this.modelValue.toString().length > 0; return this.modelValue != null && this.modelValue.toString().length > 0;
},
ptmParams() {
return {
context: {
filled: this.filled,
disabled: this.$attrs.disabled || this.$attrs.disabled === ''
}
};
} }
} }
}; };