UNPKG

@asi-ngtools/lib

Version:

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

356 lines (355 loc) 28 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; 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'; var AsiSelectComponent = /** @class */ (function (_super) { tslib_1.__extends(AsiSelectComponent, _super); function AsiSelectComponent(renderer, elementRef) { var _this = _super.call(this) || this; _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 _this; } /** * @return {?} */ AsiSelectComponent.prototype.ngOnInit = /** * @return {?} */ function () { this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition); if (this.multiple) { this.renderer.addClass(this.elementRef.nativeElement, 'multiple'); } }; /** * @return {?} */ AsiSelectComponent.prototype.onDropdownClose = /** * @return {?} */ function () { this.open = false; }; /** * @return {?} */ AsiSelectComponent.prototype.isOpened = /** * @return {?} */ function () { return this.open; }; /** * @return {?} */ AsiSelectComponent.prototype.ngOnChanges = /** * @return {?} */ function () { this.initData(); }; /** * @return {?} */ AsiSelectComponent.prototype.initData = /** * @return {?} */ function () { var _this = this; this.selectDatas = []; this.data = this.data || []; if (this.withEmptyValue) { this.selectDatas.push(null); } this.data.forEach(function (data) { /** @type {?} */ var proxyData = { selected: false, value: data }; _this.selectDatas.push(proxyData); }); }; /** * @param {?} value * @return {?} */ AsiSelectComponent.prototype.checkAll = /** * @param {?} value * @return {?} */ function (value) { var _this = this; this.allChecked = value; this.selectDatas.forEach(function (data) { if (data != null && (value !== data.selected)) { _this.internalSelectValue(null, data); } }); this.onModelChange(this._value); }; /** * @return {?} */ AsiSelectComponent.prototype.updateAllChecked = /** * @return {?} */ function () { this.allChecked = nh.find(this.selectDatas, function (data) { return data != null ? !data.selected : false; }) == null; }; /** * @param {?} event * @param {?} data * @return {?} */ AsiSelectComponent.prototype.selectValue = /** * @param {?} event * @param {?} data * @return {?} */ function (event, data) { this.internalSelectValue(event, data); this.onModelChange(this._value); }; /** * @param {?} event * @param {?} data * @return {?} */ AsiSelectComponent.prototype.internalSelectValue = /** * @param {?} event * @param {?} data * @return {?} */ function (event, data) { var _this = this; if (data == null) { this.onModelChange(null); this.open = false; return; } /** @type {?} */ var realValue = data.value; if (this.multiple) { if (event != null) { event.stopPropagation(); } if (this._value == null) { this._value = []; } /** @type {?} */ var removed = nh.remove(this._value, function (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 {?} */ AsiSelectComponent.prototype.toggleSelect = /** * @return {?} */ function () { this.open = !this.open; }; /** * @param {?} value * @return {?} */ AsiSelectComponent.prototype.writeValue = /** * @param {?} value * @return {?} */ function (value) { var _this = this; if (isNaN(value) && nh.isEmpty(value)) { this._value = null; } else { this._value = value; } if (this.multiple) { if (this._value != null) { this.selectDatas.forEach(function (data) { if (data != null) { data.selected = nh.find(_this.value, function (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(function (data) { if (data != null) { data.selected = false; } }); } this.updateAllChecked(); } this.manageHasValue(); }; /** * @param {?} value * @return {?} */ AsiSelectComponent.prototype.onModelChange = /** * @param {?} value * @return {?} */ function (value) { this.value = value; this.manageHasValue(); }; /** * @return {?} */ AsiSelectComponent.prototype.manageHasValue = /** * @return {?} */ function () { 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(function () { return AsiSelectComponent; }), multi: true } ] }] } ]; /** @nocollapse */ AsiSelectComponent.ctorParameters = function () { return [ { 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,] }] }; return AsiSelectComponent; }(DefaultControlValueAccessor)); export { AsiSelectComponent }; 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"]}