UNPKG

@junte/ui

Version:

Quality Angular UI components kit

245 lines 29.7 kB
var SwitcherComponent_1; 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'; let SwitcherComponent = SwitcherComponent_1 = class SwitcherComponent { constructor(logger, breakpoint, device) { 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 = () => this.logger.error('value accessor is not registered'); this.onTouched = () => this.logger.error('value accessor is not registered'); this.registerOnChange = fn => this.onChange = fn; this.registerOnTouched = fn => this.onTouched = fn; this.onBlur = () => this.onTouched(); } set orientation(type) { this._orientation = type || Orientation.horizontal; } get orientation() { return this._orientation; } set mode(mode) { this._mode = mode || SelectMode.single; } get mode() { return this._mode; } set features(features) { this._features = features || []; } get features() { return this._features; } set width(width) { this._width = width || Width.default; } writeValue(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); } setDisabledState(disabled) { this.disabled = disabled; } select(value) { switch (this.mode) { case SelectMode.single: const current = this.selected.length > 0 ? this.selected[0] : null; if (current !== null) { const 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: const index = !!this.keyField ? this.selected.indexOf(value[this.keyField]) : this.selected.findIndex(e => 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; } } selectAll() { this.options.forEach(o => this.selected.push(o.value)); this.version++; this.onChange(this.selected); this.updated.emit(this.selected); } }; SwitcherComponent.ctorParameters = () => [ { 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(() => SwitcherComponent_1), multi: true } ] }), __metadata("design:paramtypes", [NGXLogger, BreakpointService, DeviceService]) ], 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"]}