UNPKG

@sedeh/into-pipes

Version:

Have you ever wanted to transform data in different parts of your application into interactive objects without writing a single line of code?

117 lines 16.1 kB
import { Component, Output, EventEmitter, ViewChild } from '@angular/core'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; export class SelectComponent { constructor(renderer) { this.renderer = renderer; this.multiselect = false; this.editMode = false; this.locked = false; this.disabled = false; this.active = true; this.validate = (item, newValue) => true; this.onIntoComponentChange = new EventEmitter(); } getOptions(options) { const list = []; for (let i = 0; i < options.length; i++) { list.push(options[i].label); } return list; } change(event) { event.stopPropagation(); event.preventDefault(); const options = this.multiselect ? this.getOptions(event.target.selectedOptions) : event.target.value; if (!this.disabled && this.validate(this.data, options)) { this.source = options; this.original = this.source; this.editMode = false; this.onIntoComponentChange.emit({ id: this.id, name: this.name, value: options, type: 'change', item: this.data }); } else { this.source = this.original; this.editMode = false; event.target.value = this.source; } } handleEdit(event) { const code = event.which; event.stopPropagation(); event.preventDefault(); if (!this.disabled && ((code === 13) || (code === 9))) { event.target.click(); } } clickName(event) { event.stopPropagation(); event.preventDefault(); if (!this.disabled) { this.editMode = true; } } static settingsPatterns() { return ['select:false:false', 'select:false:true', 'select:true:false', 'select:true:true']; //multi, locked by default } transform(source, data, args) { this.original = source; this.source = source; this.data = data; this.options = this.service.getDataFor(this.name, this.id, data); this.multiselect = (args?.length && args[0].length) ? (args[0] === 'true') : false; this.locked = (args?.length > 1 && args[1].length) ? args[1] === 'true' : false; } } SelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SelectComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); SelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: SelectComponent, selector: "select-component", outputs: { onIntoComponentChange: "onIntoComponentChange" }, viewQueries: [{ propertyName: "selectEditor", first: true, predicate: ["selectEditor"], descendants: true }], ngImport: i0, template: ` <select *ngIf="locked || editMode" tabindex="{{active ? 0 : -1}}" [multiple]="multiselect ? true:null" [disabled]="disabled" (change)="change($event)"> <option *ngFor="let x of options" [attr.selected]="source.indexOf(x) < 0 ? null : 'selected'" [value]="x" [textContent]="x"></option> </select> <span *ngIf="!locked && !editMode" class="locked {{disabled ? 'disabled' : ''}}" tabindex="{{active ? 0 : -1}}" (keyup)='handleEdit($event)' (click)="clickName($event)">{{source}}</span> `, isInline: true, styles: [".locked{display:inline-block;cursor:pointer;min-width:30px;width:100%;-webkit-user-select:none;user-select:none;border:1px solid transparent}:host{width:100%;display:table;float:left;min-height:var(--sedeh-min-height, 25px)}:host .locked:hover{border:var(--sedeh-solid-border, 1px solid #fabdab)}:host .locked.disabled:hover{border-color:transparent;cursor:default}@media print{:host select{border:0}:host select::-ms-expand{display:none}:host select{appearance:none;text-indent:.01px;text-indent:1px;text-overflow:\"\"}}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SelectComponent, decorators: [{ type: Component, args: [{ selector: 'select-component', template: ` <select *ngIf="locked || editMode" tabindex="{{active ? 0 : -1}}" [multiple]="multiselect ? true:null" [disabled]="disabled" (change)="change($event)"> <option *ngFor="let x of options" [attr.selected]="source.indexOf(x) < 0 ? null : 'selected'" [value]="x" [textContent]="x"></option> </select> <span *ngIf="!locked && !editMode" class="locked {{disabled ? 'disabled' : ''}}" tabindex="{{active ? 0 : -1}}" (keyup)='handleEdit($event)' (click)="clickName($event)">{{source}}</span> `, styles: [".locked{display:inline-block;cursor:pointer;min-width:30px;width:100%;-webkit-user-select:none;user-select:none;border:1px solid transparent}:host{width:100%;display:table;float:left;min-height:var(--sedeh-min-height, 25px)}:host .locked:hover{border:var(--sedeh-solid-border, 1px solid #fabdab)}:host .locked.disabled:hover{border-color:transparent;cursor:default}@media print{:host select{border:0}:host select::-ms-expand{display:none}:host select{appearance:none;text-indent:.01px;text-indent:1px;text-overflow:\"\"}}\n"] }] }], ctorParameters: function () { return [{ type: i0.Renderer2 }]; }, propDecorators: { selectEditor: [{ type: ViewChild, args: ["selectEditor"] }], onIntoComponentChange: [{ type: Output, args: ["onIntoComponentChange"] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../projects/into-pipes/src/lib/select/select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Output, EventEmitter, ViewChild, Renderer2 } from '@angular/core';\r\nimport { PipeComponentInterface, PipeServiceComponentInterface } from '../common/pipe.component.interface';\r\n\r\n@Component({\r\n    selector: 'select-component',\r\n    template: `\r\n    <select \r\n      *ngIf=\"locked || editMode\"\r\n      tabindex=\"{{active ? 0 : -1}}\" \r\n      [multiple]=\"multiselect ? true:null\" \r\n      [disabled]=\"disabled\"\r\n      (change)=\"change($event)\">\r\n        <option *ngFor=\"let x of options\" \r\n          [attr.selected]=\"source.indexOf(x) < 0 ? null : 'selected'\"  \r\n          [value]=\"x\" \r\n          [textContent]=\"x\"></option>\r\n    </select>\r\n    <span *ngIf=\"!locked && !editMode\"\r\n      class=\"locked {{disabled ? 'disabled' : ''}}\" \r\n      tabindex=\"{{active ? 0 : -1}}\"\r\n      (keyup)='handleEdit($event)'\r\n      (click)=\"clickName($event)\">{{source}}</span>\r\n    `,\r\n    styles: [\r\n      `\r\n      .locked {\r\n        display: inline-block;\r\n        cursor: pointer;\r\n        min-width: 30px;\r\n        width: 100%;\r\n        -webkit-user-select: none;       \r\n        -moz-user-select: none;\r\n        -ms-user-select: none;\r\n        user-select: none;\r\n        border: 1px solid transparent;\r\n      }\r\n      :host {width: 100%;display:table;float:left;min-height: var(--sedeh-min-height, 25px)}\r\n      :host .locked:hover{border: var(--sedeh-solid-border, 1px solid #fabdab);}\r\n      :host .locked.disabled:hover{border-color: transparent;cursor: default;}\r\n      @media print {\r\n        :host select {\r\n            border: 0;\r\n        }\r\n        :host select::-ms-expand {display: none;}\r\n        :host select {\r\n          -webkit-appearance: none;\r\n          -moz-appearance: none;\r\n          appearance: none;\r\n          text-indent: 0.01px;\r\n          text-overflow: \"\";\r\n          text-indent: 1px;\r\n          text-overflow: '';\r\n        }\r\n      }\r\n      `\r\n    ]\r\n})\r\nexport class SelectComponent implements PipeComponentInterface {\r\n\r\n  data: any;\r\n  source!: string;\r\n  options!: string;\r\n  original!: string;\r\n  id!: string;\r\n  name!: string;\r\n  multiselect = false;\r\n  editMode = false;\r\n  locked = false;\r\n  service!: PipeServiceComponentInterface;\r\n  disabled = false;\r\n  active = true;\r\n  validate = (item: any, newValue: any) => true;\r\n\r\n  @ViewChild(\"selectEditor\")\r\n  selectEditor: any;\r\n  \r\n  @Output(\"onIntoComponentChange\")\r\n  onIntoComponentChange = new EventEmitter();\r\n\r\n  constructor(private renderer: Renderer2) {\r\n  }\r\n\r\n  private getOptions(options: any) {\r\n    const list = [];\r\n    for (let i = 0; i < options.length; i++) {\r\n      list.push(options[i].label);\r\n    }\r\n    return list;\r\n  }\r\n  change(event: any) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n    const options = this.multiselect ? this.getOptions(event.target.selectedOptions) : event.target.value;\r\n\r\n    if (!this.disabled && this.validate(this.data, options)) {\r\n      this.source = options;\r\n      this.original = this.source;\r\n      this.editMode = false;\r\n      this.onIntoComponentChange.emit({\r\n        id: this.id,\r\n        name: this.name,\r\n        value: options,\r\n        type: 'change',\r\n        item: this.data\r\n      });\r\n    } else {\r\n      this.source = this.original;\r\n      this.editMode = false;\r\n      event.target.value = this.source;\r\n    }\r\n  }\r\n\r\n  handleEdit(event: any) {\r\n    const code = event.which;\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n\r\n    if(!this.disabled && ((code === 13) || (code === 9))) {\r\n      event.target.click();\r\n    }\r\n  }\r\n\r\n  clickName(event: any) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n\r\n    if (!this.disabled) {\r\n      this.editMode = true;\r\n    }\r\n  }\r\n\r\n  static settingsPatterns() {\r\n    return ['select:false:false', 'select:false:true', 'select:true:false', 'select:true:true']; //multi, locked by default\r\n  }\r\n  transform(source: any, data: any, args: any[]) {\r\n    this.original = source;\r\n    this.source= source;\r\n    this.data = data;\r\n    this.options = this.service.getDataFor(this.name, this.id, data);\r\n    this.multiselect = (args?.length && args[0].length) ? (args[0] === 'true') : false;\r\n    this.locked = (args?.length > 1 && args[1].length) ? args[1] === 'true' : false;\r\n  }\r\n}\r\n\r\n"]}