UNPKG

@asi-ngtools/lib

Version:

This project is a little components library, simple to use, which will help you to simplify your project.

305 lines (304 loc) 26.2 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import { DefaultControlValueAccessor } from './../common/default-control-value-accessor'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { Component, Input, ContentChild, forwardRef, Renderer2, ElementRef } from '@angular/core'; import { AsiComponentTemplateOptionDef, AsiComponentTemplateEmptyDef, AsiComponentTemplateSelectedDef } from '../common/asi-component-template'; import * as nh from '../../native-helper'; export class AsiSelectComponent extends DefaultControlValueAccessor { /** * @param {?} renderer * @param {?} elementRef */ constructor(renderer, elementRef) { super(); this.renderer = renderer; this.elementRef = elementRef; /** * Label position */ this.labelPosition = 'top'; /** * Multi selection */ this.multiple = false; /** * Add an empty value (template must be define) */ this.withEmptyValue = false; this.open = false; this.allChecked = false; } /** * @return {?} */ ngOnInit() { this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition); if (this.multiple) { this.renderer.addClass(this.elementRef.nativeElement, 'multiple'); } } /** * @return {?} */ onDropdownClose() { this.open = false; } /** * @return {?} */ isOpened() { return this.open; } /** * @return {?} */ ngOnChanges() { this.initData(); } /** * @return {?} */ initData() { this.selectDatas = []; this.data = this.data || []; if (this.withEmptyValue) { this.selectDatas.push(null); } this.data.forEach((data) => { /** @type {?} */ const proxyData = { selected: false, value: data }; this.selectDatas.push(proxyData); }); } /** * @param {?} value * @return {?} */ checkAll(value) { this.allChecked = value; this.selectDatas.forEach((data) => { if (data != null && (value !== data.selected)) { this.internalSelectValue(null, data); } }); this.onModelChange(this._value); } /** * @return {?} */ updateAllChecked() { this.allChecked = nh.find(this.selectDatas, (data) => { return data != null ? !data.selected : false; }) == null; } /** * @param {?} event * @param {?} data * @return {?} */ selectValue(event, data) { this.internalSelectValue(event, data); this.onModelChange(this._value); } /** * @param {?} event * @param {?} data * @return {?} */ internalSelectValue(event, data) { if (data == null) { this.onModelChange(null); this.open = false; return; } /** @type {?} */ let realValue = data.value; if (this.multiple) { if (event != null) { event.stopPropagation(); } if (this._value == null) { this._value = []; } /** @type {?} */ let removed = nh.remove(this._value, (value) => { if (value != null) { if (this.trackBy != null) { return value[this.trackBy] === realValue[this.trackBy]; } else { return value === realValue; } } return false; }); if (nh.isEmpty(removed)) { this.value.push(realValue); data.selected = true; } else { data.selected = false; } if (nh.isEmpty(this._value)) { this._value = null; } if (event != null) { this.updateAllChecked(); } } else { this.open = false; this._value = realValue; } } /** * @return {?} */ toggleSelect() { this.open = !this.open; } /** * @param {?} value * @return {?} */ writeValue(value) { if (isNaN(value) && nh.isEmpty(value)) { this._value = null; } else { this._value = value; } if (this.multiple) { if (this._value != null) { this.selectDatas.forEach((data) => { if (data != null) { data.selected = nh.find(this.value, (possibleValue) => { if (possibleValue != null) { if (this.trackBy != null) { return possibleValue[this.trackBy] === data.value[this.trackBy]; } else { return possibleValue === data.value; } } return false; }) != null; } }); } else { this.selectDatas.forEach((data) => { if (data != null) { data.selected = false; } }); } this.updateAllChecked(); } this.manageHasValue(); } /** * @param {?} value * @return {?} */ onModelChange(value) { this.value = value; this.manageHasValue(); } /** * @return {?} */ manageHasValue() { if (this.value != null) { this.renderer.addClass(this.elementRef.nativeElement, 'has-value'); } else { this.renderer.removeClass(this.elementRef.nativeElement, 'has-value'); } } } AsiSelectComponent.decorators = [ { type: Component, args: [{ selector: 'asi-select', host: { 'class': 'asi-component asi-select' }, template: "<label class=\"input-label\" *ngIf=\"label != null\">{{label | translate}}</label>\r\n\r\n<div class=\"asi-select-container\" aria-labelledby=\"select\">\r\n <div class=\"asi-select-header asi-focus-error\" (keyup.esc)=\"toggleSelect()\">\r\n <asi-checkbox *ngIf=\"multiple\" [disabled]=\"disabled\" [ngModel]=\"allChecked\" (onValueChange)=\"checkAll($event)\">\r\n </asi-checkbox>\r\n <button type=\"button\" class=\"item-container\" [disabled]=\"disabled\" (click)=\"toggleSelect()\">\r\n <span>\r\n <div class=\"item\">\r\n <ng-template *ngIf=\"value != null\" [ngTemplateOutlet]=\"selectedDef.template\"\r\n [ngTemplateOutletContext]=\"{$implicit : value}\"></ng-template>\r\n <ng-template *ngIf=\"value == null\" [ngTemplateOutlet]=\"emptyDef?.template\"\r\n [ngTemplateOutletContext]=\"{$implicit : value}\"></ng-template>\r\n </div>\r\n <div class=\"drop-icon-container\">\r\n <span class=\"drop-icon\" [innerHtml]=\"'&#9660;'\"></span>\r\n </div>\r\n </span>\r\n </button>\r\n </div>\r\n\r\n <asi-dropdown [open]=\"open\" (onClose)=\"onDropdownClose()\" dropDownClass=\"asi-select-dropdown\">\r\n <div class=\"drop-down-select\">\r\n <div class=\"drop-down-panel\">\r\n <button type=\"button\" class=\"drop-down-item\" [ngClass]=\"{'empty' : data == null , 'selected' : data?.selected}\"\r\n (keyup.esc)=\"toggleSelect()\" (click)=\"selectValue($event, data)\" *ngFor=\"let data of selectDatas\">\r\n <span class=\"option\">\r\n <asi-checkbox *ngIf=\"multiple && data != null\" [ngModel]=\"data.selected\"\r\n (click)=\"selectValue($event, data)\"></asi-checkbox>\r\n <div class=\"item\" aria-labelledby=\"item\">\r\n <ng-template *ngIf=\"data != null\" [ngTemplateOutlet]=\"optionDef.template\"\r\n [ngTemplateOutletContext]=\"{$implicit : data.value}\"></ng-template>\r\n </div>\r\n </span>\r\n </button>\r\n </div>\r\n </div>\r\n </asi-dropdown>\r\n</div>\r\n", providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => AsiSelectComponent), multi: true } ] }] } ]; /** @nocollapse */ AsiSelectComponent.ctorParameters = () => [ { type: Renderer2 }, { type: ElementRef } ]; AsiSelectComponent.propDecorators = { label: [{ type: Input }], labelPosition: [{ type: Input }], data: [{ type: Input }], multiple: [{ type: Input }], trackBy: [{ type: Input }], withEmptyValue: [{ type: Input }], optionDef: [{ type: ContentChild, args: [AsiComponentTemplateOptionDef,] }], emptyDef: [{ type: ContentChild, args: [AsiComponentTemplateEmptyDef,] }], selectedDef: [{ type: ContentChild, args: [AsiComponentTemplateSelectedDef,] }] }; if (false) { /** * Label to display (is translated) * @type {?} */ AsiSelectComponent.prototype.label; /** * Label position * @type {?} */ AsiSelectComponent.prototype.labelPosition; /** * Data to display * @type {?} */ AsiSelectComponent.prototype.data; /** * Multi selection * @type {?} */ AsiSelectComponent.prototype.multiple; /** * Track data base on a sub attribute rather than reference * @type {?} */ AsiSelectComponent.prototype.trackBy; /** * Add an empty value (template must be define) * @type {?} */ AsiSelectComponent.prototype.withEmptyValue; /** @type {?} */ AsiSelectComponent.prototype.optionDef; /** @type {?} */ AsiSelectComponent.prototype.emptyDef; /** @type {?} */ AsiSelectComponent.prototype.selectedDef; /** @type {?} */ AsiSelectComponent.prototype.selectDatas; /** @type {?} */ AsiSelectComponent.prototype.open; /** @type {?} */ AsiSelectComponent.prototype.allChecked; /** @type {?} */ AsiSelectComponent.prototype.renderer; /** @type {?} */ AsiSelectComponent.prototype.elementRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asi-select.component.js","sourceRoot":"ng://@asi-ngtools/lib/","sources":["lib/components/asi-select/asi-select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { DefaultControlValueAccessor } from './../common/default-control-value-accessor';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { Component, Input, ContentChild, OnInit, OnChanges, forwardRef, Renderer2, ElementRef } from '@angular/core';\r\n\r\nimport {\r\n  AsiComponentTemplateOptionDef, AsiComponentTemplateEmptyDef,\r\n  AsiComponentTemplateSelectedDef\r\n} from '../common/asi-component-template';\r\n\r\nimport * as nh from '../../native-helper';\r\n\r\n@Component({\r\n  selector: 'asi-select',\r\n  host: { 'class': 'asi-component asi-select' },\r\n  templateUrl: 'asi-select.component.html',\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => AsiSelectComponent),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class AsiSelectComponent extends DefaultControlValueAccessor implements OnInit, OnChanges {\r\n\r\n  /** Label to display (is translated) */\r\n  @Input() label: string;\r\n\r\n  /** Label position */\r\n  @Input() labelPosition: 'top' | 'left' | 'right' | 'bottom' | 'bottom-center' | 'top-center' = 'top';\r\n\r\n  /** Data to display  */\r\n  @Input() data: Array<any>;\r\n\r\n  /** Multi selection  */\r\n  @Input() multiple = false;\r\n\r\n  /** Track data base on a sub attribute rather than reference  */\r\n  @Input() trackBy: string;\r\n\r\n  /** Add an empty value (template must be define) */\r\n  @Input() withEmptyValue = false;\r\n\r\n  @ContentChild(AsiComponentTemplateOptionDef) optionDef: AsiComponentTemplateOptionDef;\r\n  @ContentChild(AsiComponentTemplateEmptyDef) emptyDef: AsiComponentTemplateEmptyDef;\r\n  @ContentChild(AsiComponentTemplateSelectedDef) selectedDef: AsiComponentTemplateSelectedDef;\r\n\r\n  // Copie des données d'entrée\r\n  selectDatas: Array<any>;\r\n  open = false;\r\n  allChecked = false;\r\n\r\n  constructor(private renderer: Renderer2,\r\n    private elementRef: ElementRef) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition);\r\n    if (this.multiple) {\r\n      this.renderer.addClass(this.elementRef.nativeElement, 'multiple');\r\n    }\r\n  }\r\n\r\n  onDropdownClose() {\r\n    this.open = false;\r\n  }\r\n\r\n  public isOpened() {\r\n    return this.open;\r\n  }\r\n\r\n  ngOnChanges() {\r\n    this.initData();\r\n  }\r\n\r\n  private initData() {\r\n    this.selectDatas = [];\r\n    this.data = this.data || [];\r\n\r\n    if (this.withEmptyValue) {\r\n      this.selectDatas.push(null);\r\n    }\r\n\r\n    this.data.forEach((data) => {\r\n      const proxyData = {\r\n        selected: false,\r\n        value: data\r\n      }\r\n      this.selectDatas.push(proxyData);\r\n    });\r\n  }\r\n\r\n  checkAll(value: any): void {\r\n    this.allChecked = value;\r\n    this.selectDatas.forEach((data) => {\r\n      if (data != null && (value !== data.selected)) {\r\n        this.internalSelectValue(null, data);\r\n      }\r\n    });\r\n    this.onModelChange(this._value);\r\n  }\r\n\r\n  updateAllChecked(): void {\r\n    this.allChecked = nh.find(this.selectDatas, (data) => {\r\n      return data != null ? !data.selected : false;\r\n    }) == null;\r\n  }\r\n\r\n  selectValue(event: MouseEvent, data: any) {\r\n    this.internalSelectValue(event, data);\r\n    this.onModelChange(this._value);\r\n  }\r\n\r\n  private internalSelectValue(event: MouseEvent, data: any) {\r\n    if (data == null) {\r\n      this.onModelChange(null);\r\n      this.open = false;\r\n      return;\r\n    }\r\n\r\n    let realValue = data.value;\r\n    if (this.multiple) {\r\n      if (event != null) {\r\n        event.stopPropagation();\r\n      }\r\n\r\n      if (this._value == null) {\r\n        this._value = [];\r\n      }\r\n\r\n      let removed = nh.remove(this._value, (value: any) => {\r\n        if (value != null) {\r\n          if (this.trackBy != null) {\r\n            return value[this.trackBy] === realValue[this.trackBy];\r\n          } else {\r\n            return value === realValue;\r\n          }\r\n        }\r\n        return false;\r\n      });\r\n\r\n      if (nh.isEmpty(removed)) {\r\n        this.value.push(realValue);\r\n        data.selected = true;\r\n      } else {\r\n        data.selected = false;\r\n      }\r\n\r\n      if (nh.isEmpty(this._value)) {\r\n        this._value = null;\r\n      }\r\n\r\n      if (event != null) {\r\n        this.updateAllChecked();\r\n      }\r\n    } else {\r\n      this.open = false;\r\n      this._value = realValue;\r\n    }\r\n  }\r\n\r\n  toggleSelect(): void {\r\n    this.open = !this.open;\r\n  }\r\n\r\n  writeValue(value: any) {\r\n    if (isNaN(value) && nh.isEmpty(value)) {\r\n      this._value = null;\r\n    } else {\r\n      this._value = value;\r\n    }\r\n    if (this.multiple) {\r\n      if (this._value != null) {\r\n        this.selectDatas.forEach((data) => {\r\n          if (data != null) {\r\n            data.selected = nh.find(this.value, (possibleValue: any) => {\r\n              if (possibleValue != null) {\r\n                if (this.trackBy != null) {\r\n                  return possibleValue[this.trackBy] === data.value[this.trackBy];\r\n                } else {\r\n                  return possibleValue === data.value;\r\n                }\r\n              }\r\n              return false;\r\n            }) != null;\r\n          }\r\n        });\r\n      } else {\r\n        this.selectDatas.forEach((data) => {\r\n          if (data != null) {\r\n            data.selected = false;\r\n          }\r\n        });\r\n      }\r\n      this.updateAllChecked();\r\n    }\r\n    this.manageHasValue();\r\n  }\r\n\r\n  onModelChange(value: any) {\r\n    this.value = value;\r\n    this.manageHasValue();\r\n  }\r\n\r\n  private manageHasValue() {\r\n    if (this.value != null) {\r\n      this.renderer.addClass(this.elementRef.nativeElement, 'has-value');\r\n    } else {\r\n      this.renderer.removeClass(this.elementRef.nativeElement, 'has-value');\r\n    }\r\n  }\r\n}\r\n"]}