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?

161 lines 19.7 kB
import { Component, ViewChild, Output, EventEmitter } from '@angular/core'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; export class TextComponent { constructor(renderer) { this.renderer = renderer; this.rows = 4; this.limit = 0; this.editName = false; this.counter = false; this.locked = false; this.disabled = false; this.active = true; this.validate = (item, newValue) => true; this.onIntoComponentChange = new EventEmitter(); } keyup(event) { if (!this.disabled) { const code = event.which; if ((code === 48) || (code === 8)) { this.source = event.target.value; } else if (((code > 48) && (code <= 90)) || ((code >= 96) && (code <= 111)) || (code == 32) || ((code >= 186) && (code <= 222))) { if (!this.limit || this.source.length < this.limit) { this.source = event.target.value; } } else if ((code === 13) || (code === 9) || (code === 27)) { this.updateValue(code); } } } updateValue(code) { if (!this.disabled) { if (this.oldValue !== String(this.source)) { if (this.validate(this.data, String(this.source))) { this.editName = false; this.onIntoComponentChange.emit({ id: this.id, name: this.name, value: this.source, type: 'blur', item: this.oldValue }); this.oldValue = String(this.source); } else { this.source = this.oldValue; this.editName = false; } } } if (code === 9 || code === 0) { this.editName = false; } } blur(event) { event.stopPropagation(); event.preventDefault(); this.updateValue(0); } focus(event) { if (!this.disabled) { this.click(event); } } click(event) { event.stopPropagation(); event.preventDefault(); if (!this.disabled) { this.editName = true; setTimeout(() => { if (this.nameEditor) { this.renderer.selectRootElement(this.nameEditor.nativeElement).focus(); } }, 99); } } static settingsPatterns() { return ['text:::true:false', 'text:::true:true']; //rows, limit, counter, locked by default } transform(source, data, args) { this.data = data; this.source = source; this.oldValue = source; this.rows = args?.length ? args[0] : 4; this.limit = args?.length > 1 ? args[1] : 0; this.counter = (args?.length && args[2].length) > 2 ? (args[2] === 'true') : false; this.locked = (args?.length > 3 && args[3].length) ? args[3] === 'true' : false; } } TextComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TextComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); TextComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TextComponent, selector: "text-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 class="text-wrapper" *ngIf="locked || editName"> <textarea #nameEditor [id]="id" [name]="name" [value]="source" [disabled]="disabled" [attr.maxlength]="limit ? limit : null" [rows]="rows" (blur)="blur($event)" (keyup)='keyup($event)'> </textarea> <span *ngIf="counter" class="counter" [textContent]="limit ? (limit - source.length) + ' remaining' : source.length + ' typed'"> </span> </span> <span #nameHolder *ngIf="!locked && !editName" class="locked {{disabled ? 'disabled' : ''}}" tabindex="{{active ? 0 : -1}}" (click)="click($event)" (keyup)="focus($event)" [innerHTML]="source"> </span> `, isInline: true, styles: [".locked{display:block;cursor:pointer;min-height:var(--sedeh-min-height, 25px);min-width:var(--sedeh-min-width, 25px);-webkit-user-select:none;user-select:none;border:1px solid transparent}.text-wrapper{box-sizing:border-box;display:table;width:100%}.text-wrapper textarea{box-sizing:border-box;display:block;cursor:beam;width:100%}.counter{display:table;float:right}:host{box-sizing:border-box;width:100%;display:table;float:left;min-height:var(--sedeh-min-height, 25px);min-width:var(--sedeh-min-width, 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"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TextComponent, decorators: [{ type: Component, args: [{ selector: 'text-component', template: ` <span class="text-wrapper" *ngIf="locked || editName"> <textarea #nameEditor [id]="id" [name]="name" [value]="source" [disabled]="disabled" [attr.maxlength]="limit ? limit : null" [rows]="rows" (blur)="blur($event)" (keyup)='keyup($event)'> </textarea> <span *ngIf="counter" class="counter" [textContent]="limit ? (limit - source.length) + ' remaining' : source.length + ' typed'"> </span> </span> <span #nameHolder *ngIf="!locked && !editName" class="locked {{disabled ? 'disabled' : ''}}" tabindex="{{active ? 0 : -1}}" (click)="click($event)" (keyup)="focus($event)" [innerHTML]="source"> </span> `, styles: [".locked{display:block;cursor:pointer;min-height:var(--sedeh-min-height, 25px);min-width:var(--sedeh-min-width, 25px);-webkit-user-select:none;user-select:none;border:1px solid transparent}.text-wrapper{box-sizing:border-box;display:table;width:100%}.text-wrapper textarea{box-sizing:border-box;display:block;cursor:beam;width:100%}.counter{display:table;float:right}:host{box-sizing:border-box;width:100%;display:table;float:left;min-height:var(--sedeh-min-height, 25px);min-width:var(--sedeh-min-width, 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":"text.component.js","sourceRoot":"","sources":["../../../../../projects/into-pipes/src/lib/text/text.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: 'text-component',\r\n    template: `\r\n    <span class=\"text-wrapper\" *ngIf=\"locked || editName\">\r\n      <textarea #nameEditor\r\n        [id]=\"id\"\r\n        [name]=\"name\"\r\n        [value]=\"source\"\r\n        [disabled]=\"disabled\"\r\n        [attr.maxlength]=\"limit ? limit : null\"\r\n        [rows]=\"rows\"\r\n        (blur)=\"blur($event)\" \r\n        (keyup)='keyup($event)'>\r\n      </textarea>\r\n      <span \r\n        *ngIf=\"counter\" \r\n        class=\"counter\" \r\n        [textContent]=\"limit ? (limit - source.length) + ' remaining' : source.length + ' typed'\">\r\n      </span>\r\n    </span>\r\n    <span #nameHolder\r\n        *ngIf=\"!locked && !editName\"\r\n        class=\"locked {{disabled ? 'disabled' : ''}}\"\r\n        tabindex=\"{{active ? 0 : -1}}\"\r\n        (click)=\"click($event)\"\r\n        (keyup)=\"focus($event)\"\r\n        [innerHTML]=\"source\">\r\n    </span>\r\n    `,\r\n    styles: [\r\n        `\r\n        .locked {\r\n          display: block;\r\n          cursor: pointer;\r\n          min-height: var(--sedeh-min-height, 25px);\r\n          min-width: var(--sedeh-min-width, 25px);\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        .text-wrapper{box-sizing: border-box;display:table;width: 100%;}\r\n        .text-wrapper textarea {box-sizing: border-box;display:block;cursor: beam;width: 100%;}\r\n        .counter{display: table;float:right;}\r\n        :host {box-sizing: border-box;width: 100%;display:table;float:left;min-height: var(--sedeh-min-height, 25px);min-width: var(--sedeh-min-width, 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 TextComponent implements PipeComponentInterface {\r\n\r\n  source!: string;\r\n  data: any;\r\n  id!: string;\r\n  name!: string;\r\n  rows = 4;\r\n  limit = 0;\r\n  editName = false;\r\n  counter = false;\r\n  locked = false;\r\n  oldValue!: string;\r\n  disabled = false;\r\n  active = true;\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  keyup(event: any) {   \r\n    if (!this.disabled) {\r\n      const code = event.which;\r\n      if ((code === 48) || (code === 8)) {\r\n        this.source = event.target.value;\r\n      } else if (((code > 48) && (code <= 90)) ||\r\n          ((code >= 96) && (code <= 111)) || (code == 32) ||\r\n          ((code >= 186) && (code <= 222))) {\r\n            if (!this.limit || this.source.length < this.limit) {\r\n              this.source = event.target.value;\r\n            }\r\n      } else if ((code === 13) || (code === 9) || (code === 27) ) {\r\n        this.updateValue(code);\r\n      }\r\n    } \r\n  }\r\n  private updateValue(code: number) {\r\n    if (!this.disabled) {\r\n      if (this.oldValue !== String(this.source)) {\r\n        if (this.validate(this.data, String(this.source))) {\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: 'blur',\r\n            item: this.oldValue\r\n          });\r\n          this.oldValue = String(this.source);\r\n        } else {\r\n          this.source = this.oldValue;\r\n          this.editName = false;\r\n        }\r\n      }\r\n    }\r\n    if (code === 9 || code === 0) {\r\n      this.editName = false;\r\n    }\r\n  }\r\n  blur(event: any) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n    this.updateValue(0);\r\n  }\r\n  focus(event: any) {\r\n    if (!this.disabled) {\r\n      this.click(event);\r\n    }\r\n  }\r\n  click(event: any) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n  \r\n    if (!this.disabled) {\r\n      this.editName = true;\r\n\r\n      setTimeout(()=>{\r\n        if (this.nameEditor) {\r\n          this.renderer.selectRootElement(this.nameEditor.nativeElement).focus();\r\n        }\r\n      },99);\r\n    }\r\n  }\r\n  static settingsPatterns() {\r\n    return ['text:::true:false', 'text:::true:true']; //rows, limit, counter, locked by default\r\n  }\r\n  transform(source: any, data: any, args: any[]) {\r\n    this.data = data;\r\n    this.source = source;\r\n    this.oldValue = source;\r\n    this.rows = args?.length ? args[0] : 4;\r\n    this.limit = args?.length > 1 ? args[1] : 0;\r\n    this.counter = (args?.length && args[2].length) > 2 ? (args[2] === 'true') : false;\r\n    this.locked = (args?.length > 3 && args[3].length) ? args[3] === 'true' : false;\r\n  }\r\n}\r\n"]}