UNPKG

smart-webcomponents

Version:

Web Components & Custom Elements for Professional Web Applications

257 lines (252 loc) 11.1 kB
import {BaseElement, Animation} from "./smart.element" export interface InputProperties { /** * Determines the delay before the drop down opens to show the matches from the auto complete operation. The delay is measured in miliseconds. * Default value: 100 */ autoCompleteDelay?: number; /** * Determines the data source that will be loaded to the Input. The dataSource can be an array of strings/numbers or objects where the attributes represent the properties of a List Item. For example label, value. It can also be a callback that returns an Array of items as previously described. The data source item object may have the following fields: 'label' - string, 'value' - string or number, 'selected' - boolean, 'prefix' - string, 'suffix' - string, 'title' - string. The 'prefix' and 'suffix' add html before and after the label. * Default value: null */ dataSource?: any; /** * Enables or disables the element. * Default value: false */ disabled?: boolean; /** * Sets additional class names to the Input drop down. * Default value: */ dropDownClassList?: any; /** * Determines the position of the drop down button. * Default value: none */ dropDownButtonPosition?: DropDownButtonPosition | string; /** * Determines the position of the drop down when opened. * Default value: auto */ dropDownOpenPosition?: DropDownOpenPosition | string; /** * Sets the height of the drop down. By default it's set to an empty string. In this case the height of the drop down is controlled by a CSS variable. * Default value: */ dropDownHeight?: string | number; /** * Sets the width of the drop down. By default it's set to an empty string. In this case the width of the drop down is controlled by a CSS variable. * Default value: */ dropDownWidth?: string | number; /** * Sets the purpose of the input and what, if any, permission the user agent has to provide automated assistance in filling out the element's input when in a form, as well as guidance to the browser as to the type of information expected in the element. This value corresponds to the standard HTML autocomplete attribute and can be set to values such as 'on', 'name', 'organization', 'street-address', etc. * Default value: "off" */ inputPurpose?: string; /** * Determines the maximum number of matched items that should be visible inside the drop down as a result of a new autoComplete query. By default the maximum number of 8 items can be displayed inside the drop down. * Default value: 8 */ items?: number; /** * Sets or gets the unlockKey which unlocks the product. * Default value: "" */ unlockKey?: string; /** * Sets or gets the language. Used in conjunction with the property messages. * Default value: "en" */ locale?: string; /** * Callback used to customize the format of the messages that are returned from the Localization Module. * Default value: null */ localizeFormatFunction?: any; /** * Sets or gets an object specifying strings used in the widget that can be localized. Used in conjunction with the property locale. * Default value: * { * "en": { * "propertyUnknownType": "'' property is with undefined 'type' member!", * "propertyInvalidValue": "Invalid '!", * "propertyInvalidValueType": "Invalid '!", * "elementNotInDOM": "Element does not exist in DOM! Please, add the element to the DOM, before invoking a method.", * "moduleUndefined": "Module is undefined.", * "missingReference": ".", * "htmlTemplateNotSuported": ": Browser doesn't support HTMLTemplate elements.", * "invalidTemplate": "' property accepts a string that must match the id of an HTMLTemplate element from the DOM.", * "invalidNode": "." * } * } */ messages?: any; /** * Determines the minimum number of characters inside the input in order to trigger the autocomplete functionality that will open the drop down and show the matched items. * Default value: 1 */ minLength?: number; /** * Sets or gets the name attribute for the element. Name is used when submiting data inside an HTML form. * Default value: "" */ name?: string; /** * Determines whether the drop down is opened or not. * Default value: false */ opened?: boolean; /** * Determines the placeholder of the input. * Default value: "" */ placeholder?: string; /** * Sets or gets the query that is used to filter the items. Query is used by the autoComplete operation. Empty string means that all items from the data source will be displayed and no filter query is applied. * Default value: */ query?: string | number; /** * Determines the auto complete query mode. This property also determines the matching algorithm for the autocomplete operation. * Default value: containsIgnoreCase */ queryMode?: InputQueryMode | string; /** * Determines whether ot not the user can enter text inside the input. if dropDownButtonPosition is set to 'left' or 'right' then readonly determines whether the element acts as a ComboBox or a DropDownList if a dataSource is provided. * Default value: false */ readonly?: boolean; /** * Sets or gets the value indicating whether the element is aligned to support locales using right-to-left fonts. * Default value: false */ rightToLeft?: boolean; /** * Determines whether the items are sorted alphabetically or not * Default value: false */ sorted?: boolean; /** * Determines the sorting algorithm - ascending(asc) or descending(desc) if sort is enabled. * Default value: "asc" */ sortDirection?: string; /** * Determines the selected index. * Default value: -1 */ selectedIndex?: number; /** * Determines the selected value. * Default value: */ selectedValue?: string | number; /** * Determines the theme for the element. Themes define the look of the elements. * Default value: "" */ theme?: string; /** * Determines the input type. Input type determines what input can be entered. * Default value: "" */ type?: string; /** * If is set to true, the element cannot be focused. * Default value: false */ unfocusable?: boolean; /** * Sets or gets the value of the element. * Default value: "" */ value?: string; } /** Input specifies an input field where the user can enter data. Auto-complete options are displayed for easier input. */ export interface Input extends BaseElement, InputProperties { /* Get a member by its name */ [name: string]: any; /** * This event is triggered when the selection is changed. * @param event. The custom event. Custom data event was created with: ev.detail(label, oldLabel, oldValue, value) * label - The label of the new selected item. * oldLabel - The label of the item that was previously selected before the event was triggered. * oldValue - The value of the item that was previously selected before the event was triggered. * value - The value of the new selected item. */ onChange: ((this: any, ev: Event) => any) | null; /** * This event is triggered on each key up event of the Input, if the value is changed. * @param event. The custom event. Custom data event was created with: ev.detail(oldValue, value) * oldValue - The previous value before it was changed. * value - The new value. */ onChanging?: ((this: any, ev: Event) => any) | ((this: any, ev: CustomEvent<any>) => any) | null; /** * This event is triggered when the popup is opened. * @param event. The custom event. */ onOpen?: ((this: any, ev: Event) => any) | ((this: any, ev: CustomEvent<any>) => any) | null; /** * This event is triggered when the popup is closed. * @param event. The custom event. */ onClose: ((this: any, ev: Event) => any) | null; /** * This event is triggered when the user clicks on an item from the popup list. * @param event. The custom event. Custom data event was created with: ev.detail(item, label, value) * item - The item that was clicked. * label - The label of the item that was clicked. * value - The value of the item that was clicked. */ onItemClick?: ((this: any, ev: Event) => any) | ((this: any, ev: CustomEvent<any>) => any) | null; /** * Closes the drop down. */ close(): void; /** * Ensures that the active ( selected ) item is always visible. */ ensureVisible(): void; /** * Opens the drop down. */ open(): void; /** * Focuses and selects the text inside the input or if it is <b>readonly</b> then the element is focused. */ select(): void; /** * Selects an item by value. For example, if your data source is ['Item 1', 'Item 2', 'Item 3'], you can use 'Item 1' as an argument. If your data source is an object with label and value, pass the value when you call selectItem. * @param {string | number} value. The item's value when the item is an object or string when the item is a string item. */ selectItem(value: string | number): void; /** * Gets an item by value. For example, if your data source is ['Item 1', 'Item 2', 'Item 3'], you can use 'Item 1' as an argument. If your data source is an object with label and value, pass the value when you call selectItem. * @param {string | number} value. The item's value when the item is an object or string when the item is a string item. * @returns {any} */ getItem(value: string | number): any; /** * Gets the selected item. For example, if your data source is ['Item 1', 'Item 2', 'Item 3'] and the user selected the second item, the method returns 'Item 2'. If your data source is an object with label and value, the returned value would be the 'value'. * @param {string | number} value. The item's value when the item is an object or string when the item is a string item. * @returns {any} */ getSelectedItem(value: string | number): any; } declare global { interface Document { createElement(tagName: "smart-input"): Input; querySelector(selectors: "smart-input"): Input | null; querySelectorAll(selectors: "smart-input"): NodeListOf<Input>; getElementsByTagName(qualifiedName: "smart-input"): HTMLCollectionOf<Input>; getElementsByName(elementName: "smart-input"): NodeListOf<Input>; } } /**Determines the position of the drop down button. */ export declare type DropDownButtonPosition = 'none' | 'left' | 'right'; /**Determines the position of the drop down when opened. */ export declare type DropDownOpenPosition = 'auto' | 'top' | 'bottom'; /**Determines the auto complete query mode. This property also determines the matching algorithm for the autocomplete operation. */ export declare type InputQueryMode = 'contains' | 'containsIgnoreCase' | 'doesNotContain' | 'doesNotContainIgnoreCase' | 'equals' | 'equalsIgnoreCase' | 'startsWith' | 'startsWithIgnoreCase' | 'endsWith' | 'endsWithIgnoreCase';