From 365879a41c19795be727a6a6a1580ddb47786fe4 Mon Sep 17 00:00:00 2001 From: tugcekucukoglu Date: Thu, 18 Apr 2024 17:18:40 +0300 Subject: [PATCH] Refactor #5612 - Chips / InputChips --- components/lib/chips/Chips.d.ts | 275 +-------------- components/lib/chips/Chips.vue | 264 +------------- components/lib/chips/style/ChipsStyle.d.ts | 4 +- components/lib/chips/style/ChipsStyle.js | 26 +- .../BaseInputChips.vue} | 6 +- components/lib/inputchips/InputChips.d.ts | 331 ++++++++++++++++++ .../InputChips.spec.js} | 20 +- components/lib/inputchips/InputChips.vue | 269 ++++++++++++++ components/lib/inputchips/package.json | 9 + .../lib/inputchips/style/InputChipsStyle.d.ts | 3 + .../lib/inputchips/style/InputChipsStyle.js | 29 ++ components/lib/inputchips/style/package.json | 6 + .../base/{chips => inputchips}/index.js | 28 +- .../base/{chips => inputchips}/package.json | 0 .../aura/{chips => inputchips}/index.js | 0 .../aura/{chips => inputchips}/package.json | 0 16 files changed, 696 insertions(+), 574 deletions(-) rename components/lib/{chips/BaseChips.vue => inputchips/BaseInputChips.vue} (93%) create mode 100755 components/lib/inputchips/InputChips.d.ts rename components/lib/{chips/Chips.spec.js => inputchips/InputChips.spec.js} (52%) create mode 100755 components/lib/inputchips/InputChips.vue create mode 100644 components/lib/inputchips/package.json create mode 100644 components/lib/inputchips/style/InputChipsStyle.d.ts create mode 100644 components/lib/inputchips/style/InputChipsStyle.js create mode 100644 components/lib/inputchips/style/package.json rename components/lib/themes/primeone/base/{chips => inputchips}/index.js (65%) rename components/lib/themes/primeone/base/{chips => inputchips}/package.json (100%) rename components/lib/themes/primeone/presets/aura/{chips => inputchips}/index.js (100%) rename components/lib/themes/primeone/presets/aura/{chips => inputchips}/package.json (100%) diff --git a/components/lib/chips/Chips.d.ts b/components/lib/chips/Chips.d.ts index af5d242bd3..3cbd733580 100755 --- a/components/lib/chips/Chips.d.ts +++ b/components/lib/chips/Chips.d.ts @@ -2,77 +2,30 @@ * * Chips groups a collection of contents in tabs. * - * [Live Demo](https://www.primevue.org/chips/) + * [Live Demo](https://www.primevue.org/inputchips/) * * @module chips * */ -import { InputHTMLAttributes, VNode } from 'vue'; -import { ComponentHooks } from '../basecomponent'; -import { ChipPassThroughOptions } from '../chip'; -import { PassThroughOptions } from '../passthrough'; -import { ClassComponent, DesignToken, GlobalComponentConstructor, PassThrough } from '../ts-helpers'; - -export declare type ChipsPassThroughOptionType = ChipsPassThroughAttributes | ((options: ChipsPassThroughMethodOptions) => ChipsPassThroughAttributes | string) | string | null | undefined; +import 'vue'; +import * as InputChips from '../inputchips'; +import { ClassComponent, GlobalComponentConstructor } from '../ts-helpers'; /** * Custom passthrough(pt) option method. */ -export interface ChipsPassThroughMethodOptions { - /** - * Defines instance. - */ - instance: any; - /** - * Defines valid properties. - */ - props: ChipsProps; - /** - * Defines current inline state. - */ - state: ChipsState; - /** - * Defines valid attributes. - */ - attrs: any; - /** - * Defines parent options. - */ - parent: any; - /** - * Defines passthrough(pt) options in global config. - */ - global: object | undefined; -} +export interface ChipsPassThroughMethodOptions extends InputChips.InputChipsPassThroughMethodOptions {} /** * Custom shared passthrough(pt) option method. */ -export interface ChipsSharedPassThroughMethodOptions { - /** - * Defines valid properties. - */ - props: ChipsProps; - /** - * Defines current inline state. - */ - state: ChipsState; -} +export interface ChipsSharedPassThroughMethodOptions extends InputChips.InputChipsSharedPassThroughMethodOptions {} /** * Custom add event. * @see {@link ChipsEmits.add} */ -export interface ChipsAddEvent { - /** - * Browser event. - */ - originalEvent: Event; - /** - * Added/Removed item value. - */ - value: any; -} +export interface ChipsAddEvent extends InputChips.InputChipsAddEvent {} /** * Custom remove event. @@ -85,235 +38,39 @@ export interface ChipsRemoveEvent extends ChipsAddEvent {} * Custom passthrough(pt) options. * @see {@link ChipsProps.pt} */ -export interface ChipsPassThroughOptions { - /** - * Used to pass attributes to the root's DOM element. - */ - root?: ChipsPassThroughOptionType; - /** - * Used to pass attributes to the container's DOM element. - */ - container?: ChipsPassThroughOptionType; - /** - * Used to pass attributes to the token's DOM element. - */ - token?: ChipsPassThroughOptionType; - /** - * Used to pass attributes to the Chip component. - * @see {@link ChipPassThroughOptions} - */ - label?: ChipPassThroughOptions; - /** - * Used to pass attributes to the remove token icon's DOM element. - */ - removeTokenIcon?: ChipsPassThroughOptionType; - /** - * Used to pass attributes to the input token's DOM element. - */ - inputToken?: ChipsPassThroughOptionType; - /** - * Used to pass attributes to the input's DOM element. - */ - input?: ChipsPassThroughOptionType; - /** - * Used to manage all lifecycle hooks. - * @see {@link BaseComponent.ComponentHooks} - */ - hooks?: ComponentHooks; -} +export interface ChipsPassThroughOptions extends InputChips.InputChipsPassThroughOptions {} /** * Custom passthrough attributes for each DOM elements */ -export interface ChipsPassThroughAttributes { - [key: string]: any; -} +export interface ChipsPassThroughAttributes extends InputChips.InputChipsPassThroughAttributes {} /** * Defines current inline state in Chips component. */ -export interface ChipsState { - /** - * Current id state as a string. - */ - id: string; - /** - * Current input value as a string. - */ - inputValue: string; - /** - * Current focused state as a boolean. - * @defaultValue false - */ - focused: boolean; - /** - * Current focused item index state as a number. - */ - focusedIndex: number; -} +export interface ChipsState extends InputChips.InputChipsState {} /** * Defines valid properties in Chips component. */ -export interface ChipsProps { - /** - * Value of the component. - */ - modelValue?: any[]; - /** - * Maximum number of entries allowed. - */ - max?: number | undefined; - /** - * Whether to add an item when the input loses focus. - * @defaultValue false - */ - addOnBlur?: boolean | undefined; - /** - * Whether to allow duplicate values or not. - * @defaultValue true - */ - allowDuplicate?: boolean | undefined; - /** - * Separator char to add an item when pressed in addition to the enter key. - */ - separator?: string | any; - /** - * Identifier of the focus input to match a label defined for the chips. - */ - inputId?: string | undefined; - /** - * Style class of the input field. - */ - inputClass?: string | object | undefined; - /** - * Inline style of the input field. - */ - inputStyle?: object | undefined; - /** - * Used to pass all properties of the HTMLInputElement to the focusable input element inside the component. - * @deprecated since v3.26.0. Use 'pt' property instead. - */ - inputProps?: InputHTMLAttributes | undefined; - /** - * Icon to display in chip remove action. - * @deprecated since v3.27.0. Use 'removetokenicon' slot. - */ - removeTokenIcon?: string | undefined; - /** - * When present, it specifies that the component should have invalid state style. - * @defaultValue false - */ - invalid?: boolean | undefined; - /** - * When present, it specifies that the element should be disabled. - * @defaultValue false - */ - disabled?: boolean | undefined; - /** - * Specifies the input variant of the component. - * @defaultValue outlined - */ - variant?: 'outlined' | 'filled' | undefined; - /** - * Placeholder text for the input. - */ - placeholder?: string | undefined; - /** - * Establishes relationships between the component and label(s) where its value should be one or more element IDs. - */ - ariaLabelledby?: string | undefined; - /** - * Establishes a string value that labels the component. - */ - ariaLabel?: string | undefined; - /** - * It generates scoped CSS variables using design tokens for the component. - */ - dt?: DesignToken; - /** - * Used to pass attributes to DOM elements inside the component. - * @type {ChipsPassThroughOptions} - */ - pt?: PassThrough; - /** - * Used to configure passthrough(pt) options of the component. - * @type {PassThroughOptions} - */ - ptOptions?: PassThroughOptions; - /** - * When enabled, it removes component related styles in the core. - * @defaultValue false - */ - unstyled?: boolean; -} +export interface ChipsProps extends InputChips.InputChipsProps {} /** * Defines valid slots in Chips slots. */ -export interface ChipsSlots { - /** - * Custom chip template. - * @param {Object} scope - chip slot's params. - */ - chip(scope: { - /** - * Value of the component - */ - value: any; - }): VNode[]; - /** - * Custom remove token icon template. - * @param {Object} scope - remove token icon slot's params. - */ - removetokenicon(scope: { - /** - * Style class of the icon. - */ - class: string; - /** - * Index of the token. - */ - index: number; - /** - * Remove token icon function. - * @param {Event} event - Browser event - * @deprecated since v3.39.0. Use 'removeCallback' property instead. - */ - onClick: (event: Event, index: number) => void; - /** - * Remove token icon function. - * @param {Event} event - Browser event - */ - removeCallback: (event: Event, index: number) => void; - }): VNode[]; -} +export interface ChipsSlots extends InputChips.InputChipsSlots {} /** * Defines valid emits in Chips component. */ -export interface ChipsEmits { - /** - * Emitted when the value changes. - * @param {*} value - New value. - */ - 'update:modelValue'(value: any[]): void; - /** - * Callback to invoke when a chip is added. - * @param {ChipsAddEvent} event - Custom add event. - */ - add(event: ChipsAddEvent): void; - /** - * Callback to invoke when a chip is removed. - * @param {ChipsRemoveEvent} event - Custom remove event. - */ - remove(event: ChipsRemoveEvent): void; -} +export interface ChipsEmits extends InputChips.InputChipsEmits {} /** + * @deprecated Deprecated since v4. Use InputChips component instead. + * * **PrimeVue - Chips** * * _Chips is used to enter multiple values on an input field._ * - * [Live Demo](https://www.primevue.org/chips/) + * [Live Demo](https://www.primevue.org/inputchips/) * --- --- * ![PrimeVue](https://primefaces.org/cdn/primevue/images/logo-100.png) * diff --git a/components/lib/chips/Chips.vue b/components/lib/chips/Chips.vue index 371a03a8a5..d1fd091b69 100755 --- a/components/lib/chips/Chips.vue +++ b/components/lib/chips/Chips.vue @@ -1,269 +1,11 @@ - - diff --git a/components/lib/chips/style/ChipsStyle.d.ts b/components/lib/chips/style/ChipsStyle.d.ts index 7de62c8691..094576a62b 100644 --- a/components/lib/chips/style/ChipsStyle.d.ts +++ b/components/lib/chips/style/ChipsStyle.d.ts @@ -1,3 +1,3 @@ -import { BaseStyle } from '../../base/style'; +import { InputChipsStyle } from '../../inputchips/style/InputChipsStyle'; -export interface ChipsStyle extends BaseStyle {} +export interface ChipsStyle extends InputChipsStyle {} diff --git a/components/lib/chips/style/ChipsStyle.js b/components/lib/chips/style/ChipsStyle.js index 0ffba8386d..179ecae0c8 100644 --- a/components/lib/chips/style/ChipsStyle.js +++ b/components/lib/chips/style/ChipsStyle.js @@ -1,29 +1,5 @@ import BaseStyle from 'primevue/base/style'; -const classes = { - root: ({ instance, props }) => [ - 'p-inputchips p-component p-inputwrapper', - { - 'p-disabled': props.disabled, - 'p-invalid': props.invalid, - 'p-focus': instance.focused, - 'p-inputwrapper-filled': (props.modelValue && props.modelValue.length) || (instance.inputValue && instance.inputValue.length), - 'p-inputwrapper-focus': instance.focused - } - ], - container: ({ props, instance }) => [ - 'p-inputchips-input', - { - 'p-variant-filled': props.variant ? props.variant === 'filled' : instance.$primevue.config.inputStyle === 'filled' - } - ], - token: ({ state, index }) => ['p-inputchips-chip', { 'p-focus': state.focusedIndex === index }], - label: 'p-inputchips-chip-label', - removeTokenIcon: 'p-inputchips-chip-icon', - inputToken: 'p-inputchips-input-item' -}; - export default BaseStyle.extend({ - name: 'chips', - classes + name: 'chips' }); diff --git a/components/lib/chips/BaseChips.vue b/components/lib/inputchips/BaseInputChips.vue similarity index 93% rename from components/lib/chips/BaseChips.vue rename to components/lib/inputchips/BaseInputChips.vue index ca92eb6522..3a9ac4cc8a 100644 --- a/components/lib/chips/BaseChips.vue +++ b/components/lib/inputchips/BaseInputChips.vue @@ -1,9 +1,9 @@ diff --git a/components/lib/inputchips/package.json b/components/lib/inputchips/package.json new file mode 100644 index 0000000000..38fabd074f --- /dev/null +++ b/components/lib/inputchips/package.json @@ -0,0 +1,9 @@ +{ + "main": "./inputchips.cjs.js", + "module": "./inputchips.esm.js", + "unpkg": "./inputchips.min.js", + "types": "./InputChips.d.ts", + "browser": { + "./sfc": "./InputChips.vue" + } +} diff --git a/components/lib/inputchips/style/InputChipsStyle.d.ts b/components/lib/inputchips/style/InputChipsStyle.d.ts new file mode 100644 index 0000000000..de9b4afc02 --- /dev/null +++ b/components/lib/inputchips/style/InputChipsStyle.d.ts @@ -0,0 +1,3 @@ +import { BaseStyle } from '../../base/style'; + +export interface InputChipsStyle extends BaseStyle {} diff --git a/components/lib/inputchips/style/InputChipsStyle.js b/components/lib/inputchips/style/InputChipsStyle.js new file mode 100644 index 0000000000..17fabe1e81 --- /dev/null +++ b/components/lib/inputchips/style/InputChipsStyle.js @@ -0,0 +1,29 @@ +import BaseStyle from 'primevue/base/style'; + +const classes = { + root: ({ instance, props }) => [ + 'p-inputchips p-component p-inputwrapper', + { + 'p-disabled': props.disabled, + 'p-invalid': props.invalid, + 'p-focus': instance.focused, + 'p-inputwrapper-filled': (props.modelValue && props.modelValue.length) || (instance.inputValue && instance.inputValue.length), + 'p-inputwrapper-focus': instance.focused + } + ], + container: ({ props, instance }) => [ + 'p-inputchips-input', + { + 'p-variant-filled': props.variant ? props.variant === 'filled' : instance.$primevue.config.inputStyle === 'filled' + } + ], + token: ({ state, index }) => ['p-inputchips-chip', { 'p-focus': state.focusedIndex === index }], + label: 'p-inputchips-chip-label', + removeTokenIcon: 'p-inputchips-chip-icon', + inputToken: 'p-inputchips-input-item' +}; + +export default BaseStyle.extend({ + name: 'inputchips', + classes +}); diff --git a/components/lib/inputchips/style/package.json b/components/lib/inputchips/style/package.json new file mode 100644 index 0000000000..499046902d --- /dev/null +++ b/components/lib/inputchips/style/package.json @@ -0,0 +1,6 @@ +{ + "main": "./inputchipsstyle.cjs.js", + "module": "./inputchipsstyle.esm.js", + "unpkg": "./inputchipsstyle.min.js", + "types": "./InputChipsStyle.d.ts" +} diff --git a/components/lib/themes/primeone/base/chips/index.js b/components/lib/themes/primeone/base/inputchips/index.js similarity index 65% rename from components/lib/themes/primeone/base/chips/index.js rename to components/lib/themes/primeone/base/inputchips/index.js index c8fcdc56ca..17f55d31d3 100644 --- a/components/lib/themes/primeone/base/chips/index.js +++ b/components/lib/themes/primeone/base/inputchips/index.js @@ -15,41 +15,41 @@ export default { flex-wrap: wrap; padding: 0.25rem 0.25rem; gap: 0.25rem; - color: ${dt('chips.color')}; - background: ${dt('chips.background')}; - border: 1px solid ${dt('chips.border.color')}; + color: ${dt('inputchips.color')}; + background: ${dt('inputchips.background')}; + border: 1px solid ${dt('inputchips.border.color')}; border-radius: ${dt('rounded.base')}; width: 100%; transition: background-color ${dt('transition.duration')}, color ${dt('transition.duration')}, border-color ${dt('transition.duration')}, outline-color ${dt('transition.duration')}; outline-color: transparent; - box-shadow: ${dt('chips.box.shadow')}; + box-shadow: ${dt('inputchips.box.shadow')}; } .p-inputchips:not(.p-disabled):hover .p-inputchips-input { - border-color: ${dt('chips.hover.border.color')}; + border-color: ${dt('inputchips.hover.border.color')}; } .p-inputchips:not(.p-disabled).p-focus .p-inputchips-input { - border-color: ${dt('chips.focus.border.color')}; + border-color: ${dt('inputchips.focus.border.color')}; outline: 0 none; } -.p-inputchips.p-invalid .p-inputchips-input { - border-color: ${dt('chips.invalid.border.color')}; +.p-inputinputchips.p-invalid .p-inputchips-input { + border-color: ${dt('inputchips.invalid.border.color')}; } .p-variant-filled.p-inputchips-input { - background: ${dt('chips.filled.background')}; + background: ${dt('inputchips.filled.background')}; } .p-inputchips:not(.p-disabled).p-focus .p-variant-filled.p-inputchips-input { - background: ${dt('chips.filled.focus.background')}; + background: ${dt('inputchips.filled.focus.background')}; } -.p-inputchips.p-disabled .p-inputchips-input { +.p-inputinputchips.p-disabled .p-inputchips-input { opacity: 1; - background: ${dt('chips.disabled.background')}; - color: ${dt('chips.disabled.color')}; + background: ${dt('inputchips.disabled.background')}; + color: ${dt('inputchips.disabled.color')}; } .p-inputchips-input-item { @@ -75,7 +75,7 @@ export default { } .p-inputchips-input-item input::placeholder { - color: ${dt('chips.placeholder.color')}; + color: ${dt('inputchips.placeholder.color')}; } .p-fluid .p-inputchips { diff --git a/components/lib/themes/primeone/base/chips/package.json b/components/lib/themes/primeone/base/inputchips/package.json similarity index 100% rename from components/lib/themes/primeone/base/chips/package.json rename to components/lib/themes/primeone/base/inputchips/package.json diff --git a/components/lib/themes/primeone/presets/aura/chips/index.js b/components/lib/themes/primeone/presets/aura/inputchips/index.js similarity index 100% rename from components/lib/themes/primeone/presets/aura/chips/index.js rename to components/lib/themes/primeone/presets/aura/inputchips/index.js diff --git a/components/lib/themes/primeone/presets/aura/chips/package.json b/components/lib/themes/primeone/presets/aura/inputchips/package.json similarity index 100% rename from components/lib/themes/primeone/presets/aura/chips/package.json rename to components/lib/themes/primeone/presets/aura/inputchips/package.json