UNPKG

ng-select

Version:
376 lines 24.5 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Option } from './option'; import { Diacritics } from './diacritics'; export class OptionList { /** * @param {?} options */ constructor(options) { /* Consider using these for performance improvement. */ // private _selection: Array<Option>; // private _filtered: Array<Option>; // private _value: Array<string>; this._highlightedOption = null; if (typeof options === 'undefined' || options === null) { options = []; } this._options = options.map((/** * @param {?} option * @return {?} */ (option) => { /** @type {?} */ let o = new Option(option); if (option.disabled) { o.disabled = true; } return o; })); this._hasShown = this._options.length > 0; this.highlight(); } /** * @return {?} */ get hasShown() { return this._hasShown; } /** * @return {?} */ get hasSelected() { return this._hasSelected; } /** * Options. * * @return {?} */ get options() { return this._options; } /** * @param {?} value * @return {?} */ getOptionsByValue(value) { return this.options.filter((/** * @param {?} option * @return {?} */ (option) => { return option.value === value; })); } /** * Value. * * @return {?} */ get value() { return this.selection.map((/** * @param {?} option * @return {?} */ option => option.value)); } /** * @param {?} v * @return {?} */ set value(v) { v = typeof v === 'undefined' || v === null ? [] : v; this.options.forEach((/** * @param {?} option * @return {?} */ (option) => { option.selected = v.indexOf(option.value) > -1; })); this.updateHasSelected(); } /** * Selection. * * @return {?} */ get selection() { return this.options.filter((/** * @param {?} option * @return {?} */ option => option.selected)); } /** * @param {?} option * @param {?} multiple * @return {?} */ select(option, multiple) { if (!multiple) { this.clearSelection(); } option.selected = true; this.updateHasSelected(); } /** * @param {?} option * @return {?} */ deselect(option) { option.selected = false; this.updateHasSelected(); } /** * @return {?} */ clearSelection() { this.options.forEach((/** * @param {?} option * @return {?} */ (option) => { option.selected = false; })); this._hasSelected = false; } /** * @private * @return {?} */ updateHasSelected() { this._hasSelected = this.options.some((/** * @param {?} option * @return {?} */ option => option.selected)); } /** * Filter. * * @return {?} */ get filtered() { return this.options.filter((/** * @param {?} option * @return {?} */ option => option.shown)); } /** * @return {?} */ get filteredEnabled() { return this.options.filter((/** * @param {?} option * @return {?} */ option => option.shown && !option.disabled)); } /** * @param {?} term * @return {?} */ filter(term) { /** @type {?} */ let anyShown = false; if (term.trim() === '') { this.resetFilter(); anyShown = this.options.length > 0; } else { this.options.forEach((/** * @param {?} option * @return {?} */ (option) => { /** @type {?} */ let l = Diacritics.strip(option.label).toUpperCase(); /** @type {?} */ let t = Diacritics.strip(term).toUpperCase(); option.shown = l.indexOf(t) > -1; if (option.shown) { anyShown = true; } })); } this.highlight(); this._hasShown = anyShown; return anyShown; } /** * @private * @return {?} */ resetFilter() { this.options.forEach((/** * @param {?} option * @return {?} */ (option) => { option.shown = true; })); } /** * Highlight. * * @return {?} */ get highlightedOption() { return this._highlightedOption; } /** * @return {?} */ highlight() { /** @type {?} */ let option = this.hasShownSelected() ? this.getFirstShownSelected() : this.getFirstShown(); this.highlightOption(option); } /** * @param {?} option * @return {?} */ highlightOption(option) { this.clearHighlightedOption(); if (option !== null) { option.highlighted = true; this._highlightedOption = option; } } /** * @return {?} */ highlightNextOption() { /** @type {?} */ let shownEnabledOptions = this.filteredEnabled; /** @type {?} */ let index = this.getHighlightedIndexFromList(shownEnabledOptions); if (index > -1 && index < shownEnabledOptions.length - 1) { this.highlightOption(shownEnabledOptions[index + 1]); } } /** * @return {?} */ highlightPreviousOption() { /** @type {?} */ let shownEnabledOptions = this.filteredEnabled; /** @type {?} */ let index = this.getHighlightedIndexFromList(shownEnabledOptions); if (index > 0) { this.highlightOption(shownEnabledOptions[index - 1]); } } /** * @private * @return {?} */ clearHighlightedOption() { if (this.highlightedOption !== null) { this.highlightedOption.highlighted = false; this._highlightedOption = null; } } /** * @private * @param {?} options * @return {?} */ getHighlightedIndexFromList(options) { for (let i = 0; i < options.length; i++) { if (options[i].highlighted) { return i; } } return -1; } /** * @return {?} */ getHighlightedIndex() { return this.getHighlightedIndexFromList(this.filtered); } /** * Util. * * @return {?} */ hasShownSelected() { return this.options.some((/** * @param {?} option * @return {?} */ (option) => { return option.shown && option.selected; })); } /** * @private * @return {?} */ getFirstShown() { for (let option of this.options) { if (option.shown) { return option; } } return null; } /** * @private * @return {?} */ getFirstShownSelected() { for (let option of this.options) { if (option.shown && option.selected) { return option; } } return null; } // v0 and v1 are assumed not to be undefined or null. /** * @param {?} v0 * @param {?} v1 * @return {?} */ static equalValues(v0, v1) { if (v0.length !== v1.length) { return false; } /** @type {?} */ let a = v0.slice().sort(); /** @type {?} */ let b = v1.slice().sort(); return a.every((/** * @param {?} v * @param {?} i * @return {?} */ (v, i) => { return v === b[i]; })); } } if (false) { /** * @type {?} * @private */ OptionList.prototype._options; /** * @type {?} * @private */ OptionList.prototype._highlightedOption; /** * @type {?} * @private */ OptionList.prototype._hasShown; /** * @type {?} * @private */ OptionList.prototype._hasSelected; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"option-list.js","sourceRoot":"ng://ng-select/","sources":["lib/option-list.ts"],"names":[],"mappings":"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","sourcesContent":["import {Option} from './option';\nimport {IOption} from './option.interface';\nimport {Diacritics} from './diacritics';\n\nexport class OptionList {\n\n    private _options: Array<Option>;\n\n    /* Consider using these for performance improvement. */\n    // private _selection: Array<Option>;\n    // private _filtered: Array<Option>;\n    // private _value: Array<string>;\n\n    private _highlightedOption: Option = null;\n    private _hasShown: boolean;\n    private _hasSelected: boolean;\n\n    get hasShown(): boolean {\n        return this._hasShown;\n    }\n    get hasSelected(): boolean {\n        return this._hasSelected;\n    }\n\n    constructor(options: Array<IOption>) {\n\n        if (typeof options === 'undefined' || options === null) {\n            options = [];\n        }\n\n        this._options = options.map((option) => {\n            let o: Option = new Option(option);\n            if (option.disabled) {\n                o.disabled = true;\n            }\n            return o;\n        });\n\n        this._hasShown = this._options.length > 0;\n        this.highlight();\n    }\n\n    /** Options. **/\n\n    get options(): Array<Option> {\n        return this._options;\n    }\n\n    getOptionsByValue(value: string): Array<Option> {\n        return this.options.filter((option) => {\n            return option.value === value;\n        });\n    }\n\n    /** Value. **/\n\n    get value(): Array<string> {\n        return this.selection.map(option => option.value);\n    }\n\n    set value(v: Array<string>) {\n        v = typeof v === 'undefined' || v === null ? [] : v;\n\n        this.options.forEach((option) => {\n            option.selected = v.indexOf(option.value) > -1;\n        });\n        this.updateHasSelected();\n    }\n\n    /** Selection. **/\n\n    get selection(): Array<Option> {\n        return this.options.filter(option => option.selected);\n    }\n\n    select(option: Option, multiple: boolean) {\n        if (!multiple) {\n            this.clearSelection();\n        }\n        option.selected = true;\n        this.updateHasSelected();\n    }\n\n    deselect(option: Option) {\n        option.selected = false;\n        this.updateHasSelected();\n    }\n\n    clearSelection() {\n        this.options.forEach((option) => {\n            option.selected = false;\n        });\n        this._hasSelected = false;\n    }\n\n    private updateHasSelected() {\n        this._hasSelected = this.options.some(option => option.selected);\n    }\n\n    /** Filter. **/\n\n    get filtered(): Array<Option> {\n        return this.options.filter(option => option.shown);\n    }\n\n    get filteredEnabled(): Array<Option> {\n        return this.options.filter(option => option.shown && !option.disabled);\n    }\n\n    filter(term: string): boolean {\n        let anyShown: boolean = false;\n\n        if (term.trim() === '') {\n            this.resetFilter();\n            anyShown = this.options.length > 0;\n        }\n        else {\n            this.options.forEach((option) => {\n                let l: string = Diacritics.strip(option.label).toUpperCase();\n                let t: string = Diacritics.strip(term).toUpperCase();\n                option.shown = l.indexOf(t) > -1;\n\n                if (option.shown) {\n                    anyShown = true;\n                }\n            });\n\n        }\n\n        this.highlight();\n        this._hasShown = anyShown;\n\n        return anyShown;\n    }\n\n    private resetFilter() {\n        this.options.forEach((option) => {\n            option.shown = true;\n        });\n    }\n\n    /** Highlight. **/\n\n    get highlightedOption(): Option {\n        return this._highlightedOption;\n    }\n\n    highlight() {\n        let option: Option = this.hasShownSelected() ?\n            this.getFirstShownSelected() : this.getFirstShown();\n        this.highlightOption(option);\n    }\n\n    highlightOption(option: Option) {\n        this.clearHighlightedOption();\n\n        if (option !== null) {\n            option.highlighted = true;\n            this._highlightedOption = option;\n        }\n    }\n\n    highlightNextOption() {\n        let shownEnabledOptions = this.filteredEnabled;\n        let index = this.getHighlightedIndexFromList(shownEnabledOptions);\n\n        if (index > -1 && index < shownEnabledOptions.length - 1) {\n            this.highlightOption(shownEnabledOptions[index + 1]);\n        }\n    }\n\n    highlightPreviousOption() {\n        let shownEnabledOptions = this.filteredEnabled;\n        let index = this.getHighlightedIndexFromList(shownEnabledOptions);\n\n        if (index > 0) {\n            this.highlightOption(shownEnabledOptions[index - 1]);\n        }\n    }\n\n    private clearHighlightedOption() {\n        if (this.highlightedOption !== null) {\n            this.highlightedOption.highlighted = false;\n            this._highlightedOption = null;\n        }\n    }\n\n    private getHighlightedIndexFromList(options: Array<Option>) {\n        for (let i = 0; i < options.length; i++) {\n            if (options[i].highlighted) {\n                return i;\n            }\n        }\n        return -1;\n    }\n\n    getHighlightedIndex() {\n        return this.getHighlightedIndexFromList(this.filtered);\n    }\n\n    /** Util. **/\n\n    hasShownSelected() {\n        return this.options.some((option) => {\n            return option.shown && option.selected;\n        });\n    }\n\n    private getFirstShown(): Option {\n        for (let option of this.options) {\n            if (option.shown) {\n                return option;\n            }\n        }\n        return null;\n    }\n\n    private getFirstShownSelected(): Option {\n        for (let option of this.options) {\n            if (option.shown && option.selected) {\n                return option;\n            }\n        }\n        return null;\n    }\n\n    // v0 and v1 are assumed not to be undefined or null.\n    static equalValues(v0: Array<string>, v1: Array<string>): boolean {\n\n        if (v0.length !== v1.length) {\n            return false;\n        }\n\n        let a: Array<string> = v0.slice().sort();\n        let b: Array<string> = v1.slice().sort();\n\n        return a.every((v, i) => {\n            return v === b[i];\n        });\n    }\n}\n"]}