@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
JavaScript
/**
* @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]=\"'▼'\"></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"]}