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?

157 lines 18.2 kB
import { Component, ViewChild, Output, EventEmitter } from '@angular/core'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "../common/into.pipe"; export class InputComponent { constructor(renderer) { this.renderer = renderer; this.editName = false; this.disabled = false; this.active = true; this.locked = false; this.validate = (item, newValue) => true; this.onIntoComponentChange = new EventEmitter(); } keyup(event) { event.stopPropagation(); event.preventDefault(); if (!this.disabled) { const code = event.which; if (!code || (code === 13) || (code === 9) || (code === 27)) { this.blur(event); } } } blur(event) { event.stopPropagation(); event.preventDefault(); const newValue = String(event.target.value); if (this.oldValue !== newValue) { if (this.validate(this.data, newValue)) { this.source = newValue; this.editName = false; this.onIntoComponentChange.emit({ id: this.id, name: this.name, value: this.source, type: "change", item: this.data }); } else { this.source = this.oldValue; this.editName = false; } } this.editName = false; if (!this.disabled && this.oldValue !== String(this.source) && this.validate(this.data, String(this.source))) { this.onIntoComponentChange.emit({ id: this.id, name: this.name, value: this.source, item: this.data }); } } 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.editName = true; this.oldValue = String(this.source); setTimeout(() => { this.renderer.selectRootElement(this.nameEditor.nativeElement).focus(); }, 66); } } static settingsPatterns() { return ['input:::false', 'input:::true']; //placeholder, into a pipe, locked by default } transform(source, data, args) { this.source = source; this.data = data; this.placeholder = args && args.length ? args[0] : ""; this.formatting = args && args.length > 1 ? args[1] : ""; this.locked = (args && args.length > 2 && args[2].length) ? args[2] === 'true' : false; } } InputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: InputComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); InputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: InputComponent, selector: "input-component", outputs: { onIntoComponentChange: "onIntoComponentChange" }, viewQueries: [{ propertyName: "nameEditor", first: true, predicate: ["nameEditor"], descendants: true }, { propertyName: "nameHolder", first: true, predicate: ["nameHolder"], descendants: true }], ngImport: i0, template: ` <span *ngIf="editName || locked"> <input #nameEditor type='text' [id]="id" [name]="name" [disabled]="disabled" [value]="source" [placeholder]="placeholder" (blur)="blur($event)" (keyup)='keyup($event)'> </span> <span #nameHolder *ngIf="!locked && !editName && formatting" class="locked {{disabled ? 'disabled' : ''}}" tabindex="{{active ? 0 : -1}}" (keyup)='handleEdit($event)' (click)="clickName($event)" [innerHTML]="source ? (source | into:formatting) : '&nbsp;'"> </span> <span #nameHolder *ngIf='!locked && !editName && !formatting' class='locked' tabindex="{{active ? 0 : -1}}" (keyup)='handleEdit($event)' (click)="clickName($event)" [innerHTML]="source ? source : '&nbsp;'"> </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}input{cursor:beam}: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}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.InToPipe, name: "into" }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: InputComponent, decorators: [{ type: Component, args: [{ selector: 'input-component', template: ` <span *ngIf="editName || locked"> <input #nameEditor type='text' [id]="id" [name]="name" [disabled]="disabled" [value]="source" [placeholder]="placeholder" (blur)="blur($event)" (keyup)='keyup($event)'> </span> <span #nameHolder *ngIf="!locked && !editName && formatting" class="locked {{disabled ? 'disabled' : ''}}" tabindex="{{active ? 0 : -1}}" (keyup)='handleEdit($event)' (click)="clickName($event)" [innerHTML]="source ? (source | into:formatting) : '&nbsp;'"> </span> <span #nameHolder *ngIf='!locked && !editName && !formatting' class='locked' tabindex="{{active ? 0 : -1}}" (keyup)='handleEdit($event)' (click)="clickName($event)" [innerHTML]="source ? source : '&nbsp;'"> </span> `, styles: [".locked{display:inline-block;cursor:pointer;min-width:30px;width:100%;-webkit-user-select:none;user-select:none;border:1px solid transparent}input{cursor:beam}: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}\n"] }] }], ctorParameters: function () { return [{ type: i0.Renderer2 }]; }, propDecorators: { nameEditor: [{ type: ViewChild, args: ["nameEditor"] }], nameHolder: [{ type: ViewChild, args: ["nameHolder"] }], onIntoComponentChange: [{ type: Output, args: ["onIntoComponentChange"] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../projects/into-pipes/src/lib/input/input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild, Renderer2, Output, EventEmitter } from '@angular/core';\r\nimport { PipeComponentInterface } from '../common/pipe.component.interface';\r\n\r\n@Component({\r\n    selector: 'input-component',\r\n    template: `\r\n    <span *ngIf=\"editName || locked\">\r\n    <input #nameEditor\r\n        type='text' \r\n        [id]=\"id\"\r\n        [name]=\"name\"\r\n        [disabled]=\"disabled\"\r\n        [value]=\"source\"\r\n        [placeholder]=\"placeholder\"\r\n        (blur)=\"blur($event)\" \r\n        (keyup)='keyup($event)'>\r\n    </span>\r\n    <span #nameHolder\r\n        *ngIf=\"!locked && !editName && formatting\"\r\n        class=\"locked {{disabled ? 'disabled' : ''}}\" \r\n        tabindex=\"{{active ? 0 : -1}}\"\r\n        (keyup)='handleEdit($event)'\r\n        (click)=\"clickName($event)\"\r\n        [innerHTML]=\"source ? (source | into:formatting) : '&nbsp;'\">\r\n    </span>\r\n    <span #nameHolder\r\n        *ngIf='!locked && !editName && !formatting'\r\n        class='locked' \r\n        tabindex=\"{{active ? 0 : -1}}\"\r\n        (keyup)='handleEdit($event)'\r\n        (click)=\"clickName($event)\"\r\n        [innerHTML]=\"source ? source : '&nbsp;'\">\r\n    </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        input {\r\n          cursor: beam;\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        `\r\n    ]\r\n})\r\nexport class InputComponent implements PipeComponentInterface {\r\n\r\n  data: any;\r\n  source!: string;\r\n  id!: string;\r\n  name!: string;\r\n  placeholder!: string;\r\n  formatting!:string;\r\n  editName = false;\r\n  oldValue!: string;\r\n  disabled = false;\r\n  active = true;\r\n  locked = false;\r\n  validate = (item: any, newValue: any) => true;\r\n\r\n  @ViewChild(\"nameEditor\")\r\n  nameEditor: any;\r\n\r\n  @ViewChild(\"nameHolder\")\r\n  nameHolder: 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\r\n  keyup(event: any) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n\r\n    if (!this.disabled) {\r\n      const code = event.which;\r\n      if (!code || (code === 13) || (code === 9) || (code === 27) ) {\r\n        this.blur(event);\r\n      }\r\n    }\r\n  }\r\n  blur(event: any) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n\r\n    const newValue = String(event.target.value);\r\n    if (this.oldValue !== newValue) {\r\n      if (this.validate(this.data, newValue)) {\r\n        this.source = newValue;\r\n        this.editName = false;\r\n        this.onIntoComponentChange.emit({\r\n          id: this.id,\r\n          name: this.name,\r\n          value: this.source,\r\n          type: \"change\",\r\n          item: this.data\r\n        });\r\n      } else {\r\n        this.source = this.oldValue;\r\n        this.editName = false;\r\n      }\r\n    }\r\n    this.editName = false;\r\n    if(!this.disabled && this.oldValue !== String(this.source) && this.validate(this.data, String(this.source))) {\r\n      this.onIntoComponentChange.emit({\r\n        id: this.id,\r\n        name: this.name,\r\n        value: this.source,\r\n        item: this.data\r\n      });\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.editName = true;\r\n      this.oldValue = String(this.source);\r\n      setTimeout(() => {\r\n        this.renderer.selectRootElement(this.nameEditor.nativeElement).focus();\r\n      },66);\r\n    }\r\n  }\r\n\r\n  static settingsPatterns() {\r\n    return ['input:::false','input:::true']; //placeholder, into a pipe, locked by default\r\n  }\r\n  transform(source: any, data: any, args: any[]) {\r\n    this.source= source;\r\n    this.data = data;\r\n    this.placeholder= args && args.length ? args[0] : \"\";\r\n    this.formatting = args && args.length > 1 ? args[1] : \"\";\r\n    this.locked = (args && args.length > 2 && args[2].length) ? args[2] === 'true' : false;\r\n  }\r\n}\r\n\r\n"]}