@junte/ui
Version:
Quality Angular UI components kit
265 lines • 31.5 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { Component, ContentChildren, EventEmitter, forwardRef, HostBinding, HostListener, Input, Output, QueryList } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { NGXLogger } from 'ngx-logger';
import { DeviceService } from '../../layout/responsive/device.service';
import { PropertyApi } from '../../core/decorators/api';
import { Feature } from '../../core/enums/feature';
import { Orientation } from '../../core/enums/orientation';
import { UI } from '../../core/enums/ui';
import { Width } from '../../core/enums/width';
import { isEqual } from '../../core/utils/equal';
import { BreakpointService } from '../../layout/responsive/breakpoint.service';
import { SelectMode } from '../select/enums';
import { SwitcherOptionComponent } from './switcher-option.component';
var SwitcherComponent = /** @class */ (function () {
function SwitcherComponent(logger, breakpoint, device) {
var _this = this;
this.logger = logger;
this.breakpoint = breakpoint;
this.device = device;
this.host = 'jnt-switcher-host';
this.ui = UI;
this._features = [];
this._orientation = Orientation.horizontal;
this._width = Width.default;
this.disabled = false;
this._mode = SelectMode.single;
this.capacity = 3;
this.loading = false;
this.updated = new EventEmitter();
this.selected = [];
this.version = 0;
this.onChange = function () { return _this.logger.error('value accessor is not registered'); };
this.onTouched = function () { return _this.logger.error('value accessor is not registered'); };
this.registerOnChange = function (fn) { return _this.onChange = fn; };
this.registerOnTouched = function (fn) { return _this.onTouched = fn; };
this.onBlur = function () { return _this.onTouched(); };
}
SwitcherComponent_1 = SwitcherComponent;
Object.defineProperty(SwitcherComponent.prototype, "orientation", {
get: function () {
return this._orientation;
},
set: function (type) {
this._orientation = type || Orientation.horizontal;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SwitcherComponent.prototype, "mode", {
get: function () {
return this._mode;
},
set: function (mode) {
this._mode = mode || SelectMode.single;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SwitcherComponent.prototype, "features", {
get: function () {
return this._features;
},
set: function (features) {
this._features = features || [];
},
enumerable: true,
configurable: true
});
Object.defineProperty(SwitcherComponent.prototype, "width", {
set: function (width) {
this._width = width || Width.default;
},
enumerable: true,
configurable: true
});
SwitcherComponent.prototype.writeValue = function (value) {
if (this.mode === SelectMode.multiple && !value) {
throw new Error('Wrong value form multiple select mode');
}
this.selected = (this.mode === SelectMode.single ? (!!value ? [value] : []) : value);
};
SwitcherComponent.prototype.setDisabledState = function (disabled) {
this.disabled = disabled;
};
SwitcherComponent.prototype.select = function (value) {
switch (this.mode) {
case SelectMode.single:
var current = this.selected.length > 0 ? this.selected[0] : null;
if (current !== null) {
var same = !!this.keyField
? current[this.keyField] === value[this.keyField]
: isEqual(current, value);
if (same && !this.features.includes(Feature.allowEmpty)) {
return;
}
this.selected = same || value === null ? [] : [value];
this.onChange(same ? null : value);
this.updated.emit(same ? null : value);
}
else {
this.selected = value === null ? [] : [value];
this.onChange(value);
this.updated.emit(value);
}
this.version++;
break;
case SelectMode.multiple:
var index = !!this.keyField
? this.selected.indexOf(value[this.keyField])
: this.selected.findIndex(function (e) { return isEqual(e, value); });
if (index !== -1) {
this.selected.splice(index, 1);
}
else {
this.selected.push(value);
}
this.version++;
this.onChange(this.selected);
this.updated.emit(this.selected);
break;
}
};
SwitcherComponent.prototype.selectAll = function () {
var _this = this;
this.options.forEach(function (o) { return _this.selected.push(o.value); });
this.version++;
this.onChange(this.selected);
this.updated.emit(this.selected);
};
var SwitcherComponent_1;
SwitcherComponent.ctorParameters = function () { return [
{ type: NGXLogger },
{ type: BreakpointService },
{ type: DeviceService }
]; };
__decorate([
HostBinding('attr.host'),
__metadata("design:type", Object)
], SwitcherComponent.prototype, "host", void 0);
__decorate([
HostBinding('attr.data-width'),
__metadata("design:type", String)
], SwitcherComponent.prototype, "_width", void 0);
__decorate([
PropertyApi({
description: 'Switcher orientation ',
path: 'ui.orientation',
default: Orientation.horizontal,
options: [Orientation.horizontal, Orientation.vertical]
}),
HostBinding('attr.data-orientation'),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], SwitcherComponent.prototype, "orientation", null);
__decorate([
PropertyApi({
description: 'Set disabled state',
type: 'boolean',
default: 'false',
}),
HostBinding('attr.data-disabled'),
Input(),
__metadata("design:type", Object)
], SwitcherComponent.prototype, "disabled", void 0);
__decorate([
PropertyApi({
description: 'Select key field',
type: 'string',
default: 'key'
}),
Input(),
__metadata("design:type", String)
], SwitcherComponent.prototype, "keyField", void 0);
__decorate([
HostBinding('attr.data-mode'),
__metadata("design:type", String)
], SwitcherComponent.prototype, "_mode", void 0);
__decorate([
PropertyApi({
description: 'Switcher mode',
path: 'ui.select.mode',
default: SelectMode.single,
options: [SelectMode.single, SelectMode.multiple]
}),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], SwitcherComponent.prototype, "mode", null);
__decorate([
PropertyApi({
description: 'Add badge with the number of selected items; Select all item in switcher; Allow empty value in switcher; Adapted on mobile; Display marks',
path: 'ui.feature',
default: '[ui.feature.adapted]',
options: [Feature.badge, Feature.selectAll, Feature.allowEmpty, Feature.adapted, Feature.marks]
}),
Input(),
__metadata("design:type", Array),
__metadata("design:paramtypes", [Array])
], SwitcherComponent.prototype, "features", null);
__decorate([
PropertyApi({
description: 'Display skeleton',
type: 'count: number',
}),
Input(),
__metadata("design:type", Object)
], SwitcherComponent.prototype, "capacity", void 0);
__decorate([
PropertyApi({
description: 'Loading',
type: 'boolean',
default: 'false',
}),
Input(),
__metadata("design:type", Object)
], SwitcherComponent.prototype, "loading", void 0);
__decorate([
PropertyApi({
description: 'Input width',
path: 'ui.width',
default: Width.default,
options: [Width.default, Width.fluid]
}),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], SwitcherComponent.prototype, "width", null);
__decorate([
PropertyApi({
description: 'Selected value',
type: '(selected)='
}),
Output('selected'),
__metadata("design:type", Object)
], SwitcherComponent.prototype, "updated", void 0);
__decorate([
ContentChildren(SwitcherOptionComponent),
__metadata("design:type", QueryList)
], SwitcherComponent.prototype, "options", void 0);
__decorate([
HostListener('blur'),
__metadata("design:type", Object)
], SwitcherComponent.prototype, "onBlur", void 0);
SwitcherComponent = SwitcherComponent_1 = __decorate([
Component({
selector: 'jnt-switcher',
template: "<ng-template #optionDefaultTemplate\n let-icon=\"option.icon\"\n let-dot=\"option.dot\"\n let-badge=\"option.badge\"\n let-label=\"option.label\"\n let-selected=\"selected\">\n <jnt-dot child-of=\"jnt-switcher-host\" *ngIf=\"dot\" [color]=\"dot.color\"></jnt-dot>\n <jnt-icon child-of=\"jnt-switcher-host\" *ngIf=\"icon\" data-icon [icon]=\"icon\"></jnt-icon>\n\n <div child-of=\"jnt-switcher-host\" data-switch *ngIf=\"!!features && features.includes(ui.feature.marks)\"\n [attr.data-single]=\"mode === ui.select.mode.single\">\n <span child-of=\"jnt-switcher-host\" data-indicator *ngIf=\"selected\"></span>\n </div>\n\n <jnt-stack child-of=\"jnt-switcher-host\" *ngIf=\"label || badge\" [orientation]=\"ui.orientation.horizontal\"\n [justify]=\"ui.justify.between\"\n [align]=\"ui.align.center\"\n [gutter]=\"ui.gutter.small\"\n data-title>\n <div child-of=\"jnt-switcher-host\" data-label *ngIf=\"label\">{{label}}</div>\n <jnt-badge child-of=\"jnt-switcher-host\" *ngIf=\"badge\"\n [position]=\"ui.position.inline\"\n [color]=\"badge.color\"\n [text]=\"badge.text\"\n [value]=\"badge.value\"\n [overflow]=\"badge.overflow\">\n </jnt-badge>\n </jnt-stack>\n</ng-template>\n\n<div child-of=\"jnt-switcher-host\" data-switcher>\n <div child-of=\"jnt-switcher-host\" data-scroll [attr.data-windows]=\"device.platform.windows\">\n <jnt-stack child-of=\"jnt-switcher-host\" data-options\n [orientation]=\"breakpoint.current === ui.breakpoint.mobile && (features | includes : ui.feature.adapted) ?\n ui.orientation.vertical : orientation\"\n [gutter]=\"ui.gutter.none\"\n [align]=\"ui.align.stretch\">\n <ng-container *ngIf=\"!loading; else loadingTemplate\">\n <ng-container *ngFor=\"let option of options\">\n <ng-container *ngIf=\"!!option.optionTemplate;else defaultOptionTemplate\">\n <div child-of=\"jnt-switcher-host\" data-option data-custom-option tabindex=\"0\"\n [attr.data-selected]=\"option.value | check:selected:keyField:version\"\n [attr.data-disabled]=\"option.disabled\"\n (click)=\"select(option.value)\">\n <ng-container *ngTemplateOutlet=\"option.optionTemplate; context: {selected: option.value | check:selected:keyField:version }\"></ng-container>\n </div>\n </ng-container>\n <ng-template #defaultOptionTemplate>\n <jnt-stack child-of=\"jnt-switcher-host\" data-option tabindex=\"0\"\n [orientation]=\"ui.orientation.horizontal\"\n [align]=\"ui.align.center\"\n [gutter]=\"ui.gutter.small\"\n [attr.data-selected]=\"option.value | check:selected:keyField:version\"\n [attr.data-disabled]=\"option.disabled\"\n (click)=\"select(option.value)\">\n <ng-container *ngTemplateOutlet=\"optionDefaultTemplate; context: {option: option, mode: mode, selected: option.value | check:selected:keyField:version }\">\n </ng-container>\n </jnt-stack>\n </ng-template>\n </ng-container>\n </ng-container>\n </jnt-stack>\n </div>\n</div>\n\n<jnt-badge child-of=\"jnt-switcher-host\" data-count\n *ngIf=\"!!features && features.includes(ui.feature.badge) && mode === ui.select.mode.multiple && selected.length > 0\"\n [color]=\"ui.color.green\"\n [value]=\"selected.length\"></jnt-badge>\n\n<jnt-button child-of=\"jnt-switcher-host\" data-button\n *ngIf=\"!!features && features.includes(ui.feature.selectAll) && mode === ui.select.mode.multiple\"\n [text]=\"'action.select_all' | translate\"\n [outline]=\"ui.outline.transparent\"\n [size]=\"ui.size.tiny\"\n [scheme]=\"ui.scheme.secondary\"\n (click)=\"selectAll()\"></jnt-button>\n\n<ng-template #loadingTemplate>\n <div child-of=\"jnt-switcher-host\" data-placeholder *ngFor=\"let line of capacity | mockArray\"></div>\n</ng-template>",
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(function () { return SwitcherComponent_1; }),
multi: true
}
]
}),
__metadata("design:paramtypes", [NGXLogger,
BreakpointService,
DeviceService])
], SwitcherComponent);
return SwitcherComponent;
}());
export { SwitcherComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"switcher.component.js","sourceRoot":"ng://@junte/ui/","sources":["lib/forms/switcher/switcher.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChildren, EventEmitter, forwardRef, HostBinding, HostListener, Input, Output, QueryList } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { NGXLogger } from 'ngx-logger';\nimport { DeviceService } from '../../layout/responsive/device.service';\nimport { PropertyApi } from '../../core/decorators/api';\nimport { Feature } from '../../core/enums/feature';\nimport { Orientation } from '../../core/enums/orientation';\nimport { UI } from '../../core/enums/ui';\nimport { Width } from '../../core/enums/width';\nimport { isEqual } from '../../core/utils/equal';\nimport { BreakpointService } from '../../layout/responsive/breakpoint.service';\nimport { SelectMode } from '../select/enums';\nimport { Key } from '../select/model';\nimport { SwitcherOptionComponent } from './switcher-option.component';\n\n@Component({\n  selector: 'jnt-switcher',\n  templateUrl: './switcher.encapsulated.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => SwitcherComponent),\n      multi: true\n    }\n  ]\n})\nexport class SwitcherComponent implements ControlValueAccessor {\n\n  @HostBinding('attr.host')\n  readonly host = 'jnt-switcher-host';\n\n  ui = UI;\n\n  private _features: Feature[] = [];\n  private _orientation: Orientation = Orientation.horizontal;\n\n  @HostBinding('attr.data-width')\n  _width: Width = Width.default;\n\n  @PropertyApi({\n    description: 'Switcher orientation ',\n    path: 'ui.orientation',\n    default: Orientation.horizontal,\n    options: [Orientation.horizontal, Orientation.vertical]\n  })\n  @HostBinding('attr.data-orientation')\n  @Input() set orientation(type: Orientation) {\n    this._orientation = type || Orientation.horizontal;\n  }\n\n  get orientation() {\n    return this._orientation;\n  }\n\n  @PropertyApi({\n    description: 'Set disabled state',\n    type: 'boolean',\n    default: 'false',\n  })\n  @HostBinding('attr.data-disabled')\n  @Input()\n  disabled = false;\n\n  @PropertyApi({\n    description: 'Select key field',\n    type: 'string',\n    default: 'key'\n  })\n  @Input() keyField: string;\n\n  @HostBinding('attr.data-mode')\n  _mode: SelectMode = SelectMode.single;\n\n  @PropertyApi({\n    description: 'Switcher mode',\n    path: 'ui.select.mode',\n    default: SelectMode.single,\n    options: [SelectMode.single, SelectMode.multiple]\n  })\n  @Input() set mode(mode: SelectMode) {\n    this._mode = mode || SelectMode.single;\n  }\n\n  get mode() {\n    return this._mode;\n  }\n\n  @PropertyApi({\n    description: 'Add badge with the number of selected items; Select all item in switcher; Allow empty value in switcher; Adapted on mobile; Display marks',\n    path: 'ui.feature',\n    default: '[ui.feature.adapted]',\n    options: [Feature.badge, Feature.selectAll, Feature.allowEmpty, Feature.adapted, Feature.marks]\n  })\n  @Input()\n  set features(features: Feature[]) {\n    this._features = features || [];\n  }\n\n  get features() {\n    return this._features;\n  }\n\n  @PropertyApi({\n    description: 'Display skeleton',\n    type: 'count: number',\n  })\n  @Input()\n  capacity = 3;\n\n  @PropertyApi({\n    description: 'Loading',\n    type: 'boolean',\n    default: 'false',\n  })\n  @Input()\n  loading = false;\n\n  @PropertyApi({\n    description: 'Input width',\n    path: 'ui.width',\n    default: Width.default,\n    options: [Width.default, Width.fluid]\n  })\n  @Input() set width(width: Width) {\n    this._width = width || Width.default;\n  }\n\n  @PropertyApi({\n    description: 'Selected value',\n    type: '(selected)='\n  })\n  @Output('selected')\n  updated = new EventEmitter<any>();\n\n  @ContentChildren(SwitcherOptionComponent)\n  options: QueryList<SwitcherOptionComponent>;\n\n  selected: any[] = [];\n  version = 0;\n\n  onChange: (value: any) => void = () => this.logger.error('value accessor is not registered');\n  onTouched: () => void = () => this.logger.error('value accessor is not registered');\n  registerOnChange = fn => this.onChange = fn;\n  registerOnTouched = fn => this.onTouched = fn;\n  @HostListener('blur') onBlur = () => this.onTouched();\n\n  constructor(private logger: NGXLogger,\n              public breakpoint: BreakpointService,\n              public device: DeviceService) {\n  }\n\n  writeValue(value: any | any[]) {\n    if (this.mode === SelectMode.multiple && !value) {\n      throw new Error('Wrong value form multiple select mode');\n    }\n\n    this.selected = (this.mode === SelectMode.single ? (!!value ? [value] : []) : value) as Key[];\n  }\n\n  setDisabledState(disabled: boolean) {\n    this.disabled = disabled;\n  }\n\n  select(value: any) {\n    switch (this.mode) {\n      case SelectMode.single:\n        const current = this.selected.length > 0 ? this.selected[0] : null;\n        if (current !== null) {\n          const same = !!this.keyField\n            ? current[this.keyField] === value[this.keyField]\n            : isEqual(current, value);\n          if (same && !this.features.includes(Feature.allowEmpty)) {\n            return;\n          }\n\n          this.selected = same || value === null ? [] : [value];\n          this.onChange(same ? null : value);\n          this.updated.emit(same ? null : value);\n        } else {\n          this.selected = value === null ? [] : [value];\n          this.onChange(value);\n          this.updated.emit(value);\n        }\n\n        this.version++;\n        break;\n      case SelectMode.multiple:\n        const index = !!this.keyField\n          ? this.selected.indexOf(value[this.keyField])\n          : this.selected.findIndex(e => isEqual(e, value));\n        if (index !== -1) {\n          this.selected.splice(index, 1);\n        } else {\n          this.selected.push(value);\n        }\n        this.version++;\n        this.onChange(this.selected);\n        this.updated.emit(this.selected);\n        break;\n    }\n  }\n\n  selectAll() {\n    this.options.forEach(o => this.selected.push(o.value));\n    this.version++;\n    this.onChange(this.selected);\n    this.updated.emit(this.selected);\n  }\n}\n"]}