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