ornamentum
Version:
Angular Toolkit
207 lines • 22.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component } from '@angular/core';
import { get } from '../../../utility/services/object-utility.class';
import { DropdownDataStateService } from '../../services/dropdown-data-state.service';
import { DropdownConfigService } from '../../services/dropdown-config.service';
import { DropdownEventStateService } from '../../services/dropdown-event-state.service';
/**
* Dropdown options list component.
*/
var DropdownOptionsComponent = /** @class */ (function () {
function DropdownOptionsComponent(config, dataStateService, eventStateService) {
this.config = config;
this.dataStateService = dataStateService;
this.eventStateService = eventStateService;
}
/**
* Unique data row tracking callback.
* @param index Current index.
* @param option Dropdown option reference.
*/
/**
* Unique data row tracking callback.
* @param {?} index Current index.
* @param {?} option Dropdown option reference.
* @return {?}
*/
DropdownOptionsComponent.prototype.optionTrackBy = /**
* Unique data row tracking callback.
* @param {?} index Current index.
* @param {?} option Dropdown option reference.
* @return {?}
*/
function (index, option) {
return option.index;
};
/**
* Get selected state by option identifier.
* @param id Option select track by identifier.
*/
/**
* Get selected state by option identifier.
* @param {?} id Option select track by identifier.
* @return {?}
*/
DropdownOptionsComponent.prototype.getSelectedState = /**
* Get selected state by option identifier.
* @param {?} id Option select track by identifier.
* @return {?}
*/
function (id) {
var _this = this;
if (this.config.selectMode === 'multi') {
return this.dataStateService.selectedOptions.some((/**
* @param {?} option
* @return {?}
*/
function (option) {
return get(option, _this.config.selectTrackBy) === id;
}));
}
return get(this.dataStateService.selectedOption, this.config.selectTrackBy) === id;
};
/**
* Option click event handler.
* @param option Option object reference.
* @param event Click event arguments object.
*/
/**
* Option click event handler.
* @param {?} option Option object reference.
* @param {?} event Click event arguments object.
* @return {?}
*/
DropdownOptionsComponent.prototype.onOptionClick = /**
* Option click event handler.
* @param {?} option Option object reference.
* @param {?} event Click event arguments object.
* @return {?}
*/
function (option, event) {
/** @type {?} */
var target = (/** @type {?} */ (event.target));
if (target && target.classList && target.classList.contains('ng-ignore-propagation')) {
return;
}
this.toggleOptionSelectedState(option);
};
/**
* Option checkbox click event handler.
* @param option Option object reference.
* @param event Click event arguments object.
*/
/**
* Option checkbox click event handler.
* @param {?} option Option object reference.
* @param {?} event Click event arguments object.
* @return {?}
*/
DropdownOptionsComponent.prototype.onOptionCheckboxClick = /**
* Option checkbox click event handler.
* @param {?} option Option object reference.
* @param {?} event Click event arguments object.
* @return {?}
*/
function (option, event) {
// Prevent single mode checkbox getting unchecked on tapping already selected.
if (this.config.selectMode === 'single') {
/** @type {?} */
var selectedId = get(this.dataStateService.selectedOption, this.config.selectTrackBy);
/** @type {?} */
var id = get(option.option, this.config.selectTrackBy);
if (selectedId === id) {
event.preventDefault();
}
}
};
/**
* Toggle option select state and update selected items depending on select mode.
* @param option Option object reference.
*/
/**
* Toggle option select state and update selected items depending on select mode.
* @param {?} option Option object reference.
* @return {?}
*/
DropdownOptionsComponent.prototype.toggleOptionSelectedState = /**
* Toggle option select state and update selected items depending on select mode.
* @param {?} option Option object reference.
* @return {?}
*/
function (option) {
var _this = this;
/** @type {?} */
var id = get(option.option, this.config.selectTrackBy);
switch (this.config.selectMode) {
case 'multi': {
/** @type {?} */
var selectedIndex = this.dataStateService.selectedOptions.findIndex((/**
* @param {?} value
* @return {?}
*/
function (value) {
return get(value, _this.config.selectTrackBy) === id;
}));
if (selectedIndex < 0) {
this.dataStateService.selectedOptions.push(option.option);
}
else {
this.dataStateService.selectedOptions.splice(selectedIndex, 1);
}
this.eventStateService.selectChangeStream.emit(this.dataStateService.selectedOptions);
break;
}
case 'single-toggle': {
if (get(this.dataStateService.selectedOption, this.config.selectTrackBy) === id) {
this.dataStateService.selectedOption = undefined;
}
else {
this.dataStateService.selectedOption = option.option;
}
this.eventStateService.selectChangeStream.emit(this.dataStateService.selectedOption);
break;
}
case 'single': {
/** @type {?} */
var selectedId = get(this.dataStateService.selectedOption, this.config.selectTrackBy);
this.dataStateService.selectedOption = option.option;
if (selectedId !== id) {
this.eventStateService.selectChangeStream.emit(this.dataStateService.selectedOption);
}
break;
}
}
if (this.config.closeMenuOnSelect) {
this.dataStateService.componentLoaderRef.hide();
}
};
DropdownOptionsComponent.decorators = [
{ type: Component, args: [{
selector: 'ng-dropdown-options',
template: "<ul class=\"ng-dropdown-option-container\" [class.ng-milti-selectable]=\"config.selectMode === 'multi'\">\n <ng-container *ngIf=\"config.groupByField\">\n <ng-container *ngFor=\"let groupedOption of dataStateService.dropdownOptionGroups\">\n <li *ngIf=\"!dataStateService.dropdownOptionGroupHeaderTemplate\" class=\"ng-dropdown-group-heading\">\n {{ groupedOption.groupName }}\n </li>\n <ng-container\n *ngIf=\"dataStateService.dropdownOptionGroupHeaderTemplate\"\n [ngTemplateOutlet]=\"dataStateService.dropdownOptionGroupHeaderTemplate\"\n [ngTemplateOutletContext]=\"{ groupedOption: groupedOption }\"\n >\n </ng-container>\n <ng-container *ngFor=\"let option of groupedOption.options; trackBy: optionTrackBy; let i = index;\">\n <li (click)=\"onOptionClick(option, $event)\" [class.disabled]=\"option.disabled\" [class.ng-option-selected]=\"getSelectedState(option.id)\">\n <ng-container *ngIf=\"!dataStateService.dropdownOptionTemplate\">\n <a class=\"ng-dropdown-checkbox-container\" *ngIf=\"config.showOptionSelectCheckbox\">\n <input type=\"checkbox\" class=\"ng-dropdown-checkbox-input ng-ignore-propagation\"\n [id]=\"dataStateService.getUniqueId('gop', i)\"\n [checked]=\"getSelectedState(option.id)\"\n [disabled]=\"option.disabled\"\n (change)=\"toggleOptionSelectedState(option)\"\n (click)=\"onOptionCheckboxClick(option, $event)\"\n />\n <label class=\"ng-ignore-propagation\" [for]=\"dataStateService.getUniqueId('gop', i)\">\n <span class=\"ng-ignore-propagation\" [title]=\"option.text\">{{ option.text }}</span>\n </label>\n </a>\n <span *ngIf=\"!config.showOptionSelectCheckbox\" [title]=\"option.text\">\n <span *ngIf=\"config.showOptionIndex\">{{option.index}} -</span>\n <span *ngIf=\"config.showOptionTrackBy\">{{option.id}} - </span>{{ option.text }}\n </span>\n </ng-container>\n <ng-container\n *ngIf=\"dataStateService.dropdownOptionTemplate\"\n [ngTemplateOutlet]=\"dataStateService.dropdownOptionTemplate\"\n [ngTemplateOutletContext]=\"{ option: option, selected: getSelectedState(option.id) }\"\n >\n </ng-container>\n </li>\n </ng-container>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"!config.groupByField\">\n <ng-container *ngFor=\"let option of dataStateService.dropdownOptions; trackBy: optionTrackBy; index as i;\">\n <li (click)=\"onOptionClick(option, $event)\" [class.disabled]=\"option.disabled\" [class.ng-option-selected]=\"getSelectedState(option.id)\">\n <ng-container *ngIf=\"!dataStateService.dropdownOptionTemplate\">\n <a class=\"ng-dropdown-checkbox-container\" *ngIf=\"config.showOptionSelectCheckbox\">\n <input type=\"checkbox\" class=\"ng-dropdown-checkbox-input ng-ignore-propagation\"\n [id]=\"dataStateService.getUniqueId('sop', i)\"\n [checked]=\"getSelectedState(option.id)\"\n [disabled]=\"option.disabled\"\n (change)=\"toggleOptionSelectedState(option)\"\n (click)=\"onOptionCheckboxClick(option, $event)\"\n />\n <label class=\"ng-ignore-propagation\" [for]=\"dataStateService.getUniqueId('sop', i)\">\n <span class=\"ng-ignore-propagation\" [title]=\"option.text\">{{ option.text }}</span>\n </label>\n </a>\n <span *ngIf=\"!config.showOptionSelectCheckbox\" [title]=\"option.text\">\n <span *ngIf=\"config.showOptionIndex\">{{option.index}} -</span>\n <span *ngIf=\"config.showOptionTrackBy\">{{option.id}} - </span>{{ option.text }}\n </span>\n </ng-container>\n <ng-container\n *ngIf=\"dataStateService.dropdownOptionTemplate\"\n [ngTemplateOutlet]=\"dataStateService.dropdownOptionTemplate\"\n [ngTemplateOutletContext]=\"{ option: option, selected: getSelectedState(option.id) }\"\n >\n </ng-container>\n </li>\n </ng-container>\n </ng-container>\n <li *ngIf=\"!dataStateService.dataLoading && dataStateService.totalOptionCount === 0\" class=\"ng-dropdown-no-data\">\n {{ config.translations.noDataMessage }}\n </li>\n</ul>\n"
}] }
];
/** @nocollapse */
DropdownOptionsComponent.ctorParameters = function () { return [
{ type: DropdownConfigService },
{ type: DropdownDataStateService },
{ type: DropdownEventStateService }
]; };
return DropdownOptionsComponent;
}());
export { DropdownOptionsComponent };
if (false) {
/** @type {?} */
DropdownOptionsComponent.prototype.config;
/** @type {?} */
DropdownOptionsComponent.prototype.dataStateService;
/**
* @type {?}
* @private
*/
DropdownOptionsComponent.prototype.eventStateService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-options.component.js","sourceRoot":"ng://ornamentum/","sources":["dropdown/components/dropdown-options/dropdown-options.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component } from '@angular/core';\n\nimport { get } from '../../../utility/services/object-utility.class';\n\nimport { DropdownOption } from '../../models/dropdown-option.model';\n\nimport { DropdownDataStateService } from '../../services/dropdown-data-state.service';\nimport { DropdownConfigService } from '../../services/dropdown-config.service';\nimport { DropdownEventStateService } from '../../services/dropdown-event-state.service';\n\n/**\n * Dropdown options list component.\n */\n@Component({\n  selector: 'ng-dropdown-options',\n  templateUrl: './dropdown-options.component.html'\n})\nexport class DropdownOptionsComponent {\n  constructor(\n    public config: DropdownConfigService,\n    public dataStateService: DropdownDataStateService,\n    private eventStateService: DropdownEventStateService\n  ) {}\n\n  /**\n   * Unique data row tracking callback.\n   * @param index Current index.\n   * @param option Dropdown option reference.\n   */\n  public optionTrackBy(index: number, option: DropdownOption): number {\n    return option.index;\n  }\n\n  /**\n   * Get selected state by option identifier.\n   * @param id Option select track by identifier.\n   */\n  public getSelectedState(id: any): boolean {\n    if (this.config.selectMode === 'multi') {\n      return this.dataStateService.selectedOptions.some((option: any) => {\n        return get(option, this.config.selectTrackBy) === id;\n      });\n    }\n\n    return get(this.dataStateService.selectedOption, this.config.selectTrackBy) === id;\n  }\n\n  /**\n   * Option click event handler.\n   * @param option Option object reference.\n   * @param event Click event arguments object.\n   */\n  public onOptionClick(option: DropdownOption, event: MouseEvent): void {\n    const target = event.target as HTMLElement;\n    if (target && target.classList && target.classList.contains('ng-ignore-propagation')) {\n      return;\n    }\n\n    this.toggleOptionSelectedState(option);\n  }\n\n  /**\n   * Option checkbox click event handler.\n   * @param option Option object reference.\n   * @param event Click event arguments object.\n   */\n  public onOptionCheckboxClick(option: DropdownOption, event: MouseEvent): void {\n    // Prevent single mode checkbox getting unchecked on tapping already selected.\n    if (this.config.selectMode === 'single') {\n      const selectedId = get(this.dataStateService.selectedOption, this.config.selectTrackBy);\n      const id = get(option.option, this.config.selectTrackBy);\n      if (selectedId === id) {\n        event.preventDefault();\n      }\n    }\n  }\n\n  /**\n   * Toggle option select state and update selected items depending on select mode.\n   * @param option Option object reference.\n   */\n  public toggleOptionSelectedState(option: DropdownOption): void {\n    const id = get(option.option, this.config.selectTrackBy);\n\n    switch (this.config.selectMode) {\n      case 'multi': {\n        const selectedIndex = this.dataStateService.selectedOptions.findIndex((value: any) => {\n          return get(value, this.config.selectTrackBy) === id;\n        });\n\n        if (selectedIndex < 0) {\n          this.dataStateService.selectedOptions.push(option.option);\n        } else {\n          this.dataStateService.selectedOptions.splice(selectedIndex, 1);\n        }\n\n        this.eventStateService.selectChangeStream.emit(this.dataStateService.selectedOptions);\n        break;\n      }\n      case 'single-toggle': {\n        if (get(this.dataStateService.selectedOption, this.config.selectTrackBy) === id) {\n          this.dataStateService.selectedOption = undefined;\n        } else {\n          this.dataStateService.selectedOption = option.option;\n        }\n\n        this.eventStateService.selectChangeStream.emit(this.dataStateService.selectedOption);\n        break;\n      }\n      case 'single': {\n        const selectedId = get(this.dataStateService.selectedOption, this.config.selectTrackBy);\n        this.dataStateService.selectedOption = option.option;\n\n        if (selectedId !== id) {\n          this.eventStateService.selectChangeStream.emit(this.dataStateService.selectedOption);\n        }\n        break;\n      }\n    }\n\n    if (this.config.closeMenuOnSelect) {\n      this.dataStateService.componentLoaderRef.hide();\n    }\n  }\n}\n"]}