@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
JavaScript
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) : ' '">
</span>
<span #nameHolder
*ngIf='!locked && !editName && !formatting'
class='locked'
tabindex="{{active ? 0 : -1}}"
(keyup)='handleEdit($event)'
(click)="clickName($event)"
[innerHTML]="source ? 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}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) : ' '">
</span>
<span #nameHolder
*ngIf='!locked && !editName && !formatting'
class='locked'
tabindex="{{active ? 0 : -1}}"
(keyup)='handleEdit($event)'
(click)="clickName($event)"
[innerHTML]="source ? 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}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"]}