From 327cbbd9bcf77774f0ff0477950843a520cfee4f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tu=C4=9F=C3=A7e=20K=C3=BC=C3=A7=C3=BCko=C4=9Flu?= Date: Fri, 5 May 2023 09:40:09 +0300 Subject: [PATCH] Refactor #3922 - For AutoComplete --- api-generator/components/autocomplete.js | 6 + components/lib/autocomplete/AutoComplete.d.ts | 108 +++++++++++++++++- components/lib/autocomplete/AutoComplete.vue | 54 ++++++--- components/lib/config/PrimeVue.d.ts | 2 + 4 files changed, 152 insertions(+), 18 deletions(-) diff --git a/api-generator/components/autocomplete.js b/api-generator/components/autocomplete.js index 14412ab63..e012096b8 100644 --- a/api-generator/components/autocomplete.js +++ b/api-generator/components/autocomplete.js @@ -250,6 +250,12 @@ const AutoCompleteProps = [ type: 'string', default: 'null', description: 'Identifier of the underlying input element.' + }, + { + name: 'pt', + type: 'any', + default: 'null', + description: 'Uses to pass attributes to DOM elements inside the component.' } ]; diff --git a/components/lib/autocomplete/AutoComplete.d.ts b/components/lib/autocomplete/AutoComplete.d.ts index ddfd2caea..1c2bd0edb 100755 --- a/components/lib/autocomplete/AutoComplete.d.ts +++ b/components/lib/autocomplete/AutoComplete.d.ts @@ -8,8 +8,19 @@ * */ import { HTMLAttributes, InputHTMLAttributes, VNode } from 'vue'; +import { ButtonPassThroughOptionType } from '../button'; import { ClassComponent, GlobalComponentConstructor } from '../ts-helpers'; -import { VirtualScrollerItemOptions, VirtualScrollerProps } from '../virtualscroller'; +import { VirtualScrollerItemOptions, VirtualScrollerPassThroughOptionType, VirtualScrollerProps } from '../virtualscroller'; + +export declare type AutoCompletePassThroughOptionType = AutoCompletePassThroughAttributes | ((options: AutoCompletePassThroughMethodOptions) => AutoCompletePassThroughAttributes) | null | undefined; + +/** + * Custom passthrough(pt) option method. + */ +export interface AutoCompletePassThroughMethodOptions { + props: AutoCompleteProps; + state: AutoCompleteState; +} /** * Custom change event. @@ -78,6 +89,96 @@ export interface AutoCompleteCompleteEvent { query: string; } +/** + * Custom passthrough(pt) options. + * @see {@link AutoCompleteProps.pt} + */ +export interface AutoCompletePassThroughOptions { + /** + * Uses to pass attributes to the root's DOM element. + */ + root?: AutoCompletePassThroughOptionType; + /** + * Uses to pass attributes to the input's DOM element. + */ + input?: AutoCompletePassThroughOptionType; + /** + * Uses to pass attributes to the container's DOM element. + */ + container?: AutoCompletePassThroughOptionType; + /** + * Uses to pass attributes to the token' DOM element. + */ + token?: AutoCompletePassThroughOptionType; + /** + * Uses to pass attributes to the token label's DOM element. + */ + tokenLabel?: AutoCompletePassThroughOptionType; + /** + * Uses to pass attributes to the remove token icon's DOM element. + */ + removeTokenIcon?: AutoCompletePassThroughOptionType; + /** + * Uses to pass attributes to the loading icon's DOM element. + */ + loadingIcon?: AutoCompletePassThroughOptionType; + /** + * Uses to pass attributes to the Button component. + */ + dropdownButton?: ButtonPassThroughOptionType; + /** + * Uses to pass attributes to the search result message's DOM element. + */ + searchResultMessage?: AutoCompletePassThroughOptionType; + /** + * Uses to pass attributes to the panel's DOM element. + */ + panel?: AutoCompletePassThroughOptionType; + /** + * Uses to pass attributes to the VirtualScroller component. + * @see {@link VirtualScrollerPassThroughOptionType} + */ + virtualScroller?: VirtualScrollerPassThroughOptionType; + /** + * Uses to pass attributes to the list's DOM element. + */ + list?: AutoCompletePassThroughOptionType; + /** + * Uses to pass attributes to the item group's DOM element. + */ + itemGroup?: AutoCompletePassThroughOptionType; + /** + * Uses to pass attributes to the item's DOM element. + */ + item?: AutoCompletePassThroughOptionType; + /** + * Uses to pass attributes to the empty message's DOM element. + */ + emptyMessage?: AutoCompletePassThroughOptionType; + /** + * Uses to pass attributes to the selected message's DOM element. + */ + selectedMessage?: AutoCompletePassThroughOptionType; +} + +/** + * Custom passthrough attributes for each DOM elements + */ +export interface AutoCompletePassThroughAttributes { + [key: string]: any; +} + +/** + * Defines current inline state in AutoComplete component. + */ +export interface AutoCompleteState { + /** + * Current collapsed state as a boolean. + * @defaultValue false + */ + d_collapsed: boolean; +} + /** * Defines valid properties in AutoComplete component. */ @@ -274,6 +375,11 @@ export interface AutoCompleteProps { * Identifier of the underlying input element. */ 'aria-labelledby'?: string | undefined; + /** + * Uses to pass attributes to DOM elements inside the component. + * @type {AutoCompletePassThroughOptions} + */ + pt?: AutoCompletePassThroughOptions; } /** diff --git a/components/lib/autocomplete/AutoComplete.vue b/components/lib/autocomplete/AutoComplete.vue index 7768cd7c6..bbb1f8a5b 100755 --- a/components/lib/autocomplete/AutoComplete.vue +++ b/components/lib/autocomplete/AutoComplete.vue @@ -1,5 +1,5 @@