@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?
124 lines • 15.7 kB
JavaScript
import { Component, ViewChild, Output, EventEmitter } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
export class CheckboxComponent {
constructor() {
this.displayable = true;
this.disabled = false;
this.active = true;
this.validate = (item, newValue) => true;
this.onIntoComponentChange = new EventEmitter();
}
keyup(event) {
const code = event.which;
if (code === 13 && !this.disabled) {
event.target.click();
}
}
click(event, checked) {
event.stopPropagation();
event.preventDefault();
const newState = (checked ? this.state1 : this.state2);
if (!this.disabled && this.validate(this.data, newState)) {
this.displayable = false;
this.source = newState;
this.onIntoComponentChange.emit({
id: this.id,
name: this.name,
value: this.source,
type: "check",
item: this.data
});
if (this.useFont) {
setTimeout(() => {
if (this.check) {
this.check.nativeElement.focus();
}
if (this.uncheck) {
this.uncheck.nativeElement.focus();
}
}, 66);
}
else {
setTimeout(() => this.displayable = true, 66);
}
}
}
static settingsPatterns() {
return ['checkbox:true:false:false:false', 'checkbox:true:false:true:false', 'checkbox:true:false:true:true']; //state1 state2, useFont, onoff
}
transform(source, data, args) {
this.state1 = args && args.length ? String(args[0]) : "";
this.state2 = (args && args.length > 1) ? String(args[1]) : '';
this.useFont = (args && args.length > 2 && args[2].length) ? args[2] === 'true' : false;
this.onOff = (args && args.length > 3 && args[3].length) ? args[3] === 'true' : false;
this.source = String(source);
this.data = data;
}
}
CheckboxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CheckboxComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
CheckboxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CheckboxComponent, selector: "checkbox-component", outputs: { onIntoComponentChange: "onIntoComponentChange" }, viewQueries: [{ propertyName: "check", first: true, predicate: ["check"], descendants: true }, { propertyName: "uncheck", first: true, predicate: ["uncheck"], descendants: true }], ngImport: i0, template: `
<span *ngIf="useFont" class="check-font {{disabled ? 'disabled' : ''}}">
<span *ngIf="source === state1"
#check tabindex="{{active ? 0 : -1}}"
class="fa"
[class.fa-toggle-on]="onOff"
[class.fa-check]="!onOff"
(keyup)="keyup($event)"
(click)="click($event, false)"></span>
<span *ngIf="source === state2"
#uncheck tabindex="{{active ? 0 : -1}}"
class="fa"
checked
[class.fa-toggle-off]="onOff"
[class.fa-close]="!onOff"
(keyup)="keyup($event)"
(click)="click($event, true)"></span>
</span>
<input *ngIf="!useFont && displayable"
type="checkbox"
tabindex="{{active ? 0 : -1}}"
[disabled]="disabled"
[checked]="source===state1"
(keyup)="keyup($event)"
(click)="click($event, source!==state1)" />
`, isInline: true, styles: [":host .check-font .fa{margin:var(--sedeh-margin, 0 5px)}:host{display:table;float:left;min-height:var(--sedeh-min-height, 25px)}.check-font:hover{opacity:var(--sedeh-hover-opacity, .5)}.check-font .fa:focus{outline:none;zoom:1.1;right:var(--sedeh-shift-right, 0);position:relative;color:var(--sedeh-focus-color, darkblue)}.check-font{cursor:pointer}.check-font.disabled:hover{color:var(--sedeh-disabled-color, #888)}.check-font.disabled{color:var(--sedeh-disabled-color, #888);pointer-events:none}\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: CheckboxComponent, decorators: [{
type: Component,
args: [{ selector: 'checkbox-component', template: `
<span *ngIf="useFont" class="check-font {{disabled ? 'disabled' : ''}}">
<span *ngIf="source === state1"
#check tabindex="{{active ? 0 : -1}}"
class="fa"
[class.fa-toggle-on]="onOff"
[class.fa-check]="!onOff"
(keyup)="keyup($event)"
(click)="click($event, false)"></span>
<span *ngIf="source === state2"
#uncheck tabindex="{{active ? 0 : -1}}"
class="fa"
checked
[class.fa-toggle-off]="onOff"
[class.fa-close]="!onOff"
(keyup)="keyup($event)"
(click)="click($event, true)"></span>
</span>
<input *ngIf="!useFont && displayable"
type="checkbox"
tabindex="{{active ? 0 : -1}}"
[disabled]="disabled"
[checked]="source===state1"
(keyup)="keyup($event)"
(click)="click($event, source!==state1)" />
`, styles: [":host .check-font .fa{margin:var(--sedeh-margin, 0 5px)}:host{display:table;float:left;min-height:var(--sedeh-min-height, 25px)}.check-font:hover{opacity:var(--sedeh-hover-opacity, .5)}.check-font .fa:focus{outline:none;zoom:1.1;right:var(--sedeh-shift-right, 0);position:relative;color:var(--sedeh-focus-color, darkblue)}.check-font{cursor:pointer}.check-font.disabled:hover{color:var(--sedeh-disabled-color, #888)}.check-font.disabled{color:var(--sedeh-disabled-color, #888);pointer-events:none}\n"] }]
}], propDecorators: { check: [{
type: ViewChild,
args: ["check"]
}], uncheck: [{
type: ViewChild,
args: ["uncheck"]
}], onIntoComponentChange: [{
type: Output,
args: ["onIntoComponentChange"]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"","sources":["../../../../../projects/into-pipes/src/lib/checkbox/checkbox.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild, Output, EventEmitter } from '@angular/core';\r\nimport { PipeComponentInterface } from '../common/pipe.component.interface';\r\n\r\n@Component({\r\n    selector: 'checkbox-component',\r\n    template: `\r\n    <span *ngIf=\"useFont\" class=\"check-font {{disabled ? 'disabled' : ''}}\">\r\n      <span *ngIf=\"source === state1\" \r\n          #check tabindex=\"{{active ? 0 : -1}}\" \r\n          class=\"fa\" \r\n          [class.fa-toggle-on]=\"onOff\" \r\n          [class.fa-check]=\"!onOff\" \r\n          (keyup)=\"keyup($event)\" \r\n          (click)=\"click($event, false)\"></span>\r\n      <span *ngIf=\"source === state2\"\r\n          #uncheck tabindex=\"{{active ? 0 : -1}}\" \r\n          class=\"fa\" \r\n          checked\r\n          [class.fa-toggle-off]=\"onOff\" \r\n          [class.fa-close]=\"!onOff\" \r\n          (keyup)=\"keyup($event)\" \r\n          (click)=\"click($event, true)\"></span>\r\n    </span>\r\n    <input *ngIf=\"!useFont && displayable\" \r\n            type=\"checkbox\" \r\n            tabindex=\"{{active ? 0 : -1}}\" \r\n            [disabled]=\"disabled\"\r\n            [checked]=\"source===state1\" \r\n            (keyup)=\"keyup($event)\"\r\n            (click)=\"click($event, source!==state1)\" />\r\n    `,\r\n    styles: [\r\n      `\r\n      :host .check-font .fa{margin: var(--sedeh-margin, 0 5px);}\r\n      :host {display:table;float:left;min-height: var(--sedeh-min-height, 25px);}\r\n      .check-font:hover{opacity: var(--sedeh-hover-opacity, 0.5);}\r\n      .check-font .fa:focus{outline: none;zoom: 1.1;right: var(--sedeh-shift-right, 0);position: relative;color: var(--sedeh-focus-color, darkblue);}\r\n      .check-font {cursor: pointer;}\r\n      .check-font.disabled:hover{color: var(--sedeh-disabled-color, #888);}\r\n      .check-font.disabled {color: var(--sedeh-disabled-color, #888); pointer-events: none}\r\n      `\r\n    ]\r\n})\r\nexport class CheckboxComponent implements PipeComponentInterface {\r\n\r\n  data: any;\r\n  source!: string;\r\n  state1!: string;\r\n  state2!: string;\r\n  id!: string;\r\n  name!: string;\r\n  onOff!: boolean;\r\n  useFont!: boolean;\r\n  displayable = true;\r\n  disabled = false;\r\n  active = true;\r\n  validate = (item: any, newValue: any) => true;\r\n\r\n  @ViewChild(\"check\")\r\n  check: any;\r\n\r\n  @ViewChild(\"uncheck\")\r\n  uncheck: any;\r\n\r\n  @Output(\"onIntoComponentChange\")\r\n  onIntoComponentChange = new EventEmitter();\r\n\r\n  keyup(event: any) {\r\n    const code = event.which;\r\n    if (code === 13 && !this.disabled) {\r\n      event.target.click();\r\n\t\t}\r\n  }\r\n\r\n  click(event: any, checked: boolean) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n\r\n    const newState = (checked ? this.state1 : this.state2);\r\n    if (!this.disabled && this.validate(this.data, newState)) {\r\n      this.displayable = false;\r\n      this.source = newState;\r\n      this.onIntoComponentChange.emit({\r\n        id: this.id,\r\n        name: this.name,\r\n        value: this.source,\r\n        type: \"check\",\r\n        item: this.data\r\n      });\r\n      if (this.useFont) {\r\n        setTimeout(() => {\r\n          if (this.check) {\r\n            this.check.nativeElement.focus();\r\n          }\r\n          if (this.uncheck) {\r\n            this.uncheck.nativeElement.focus();\r\n          }\r\n        },66);\r\n      } else {\r\n        setTimeout(()=> this.displayable = true, 66)\r\n      }\r\n    }\r\n  }\r\n\r\n  static settingsPatterns() {\r\n    return ['checkbox:true:false:false:false', 'checkbox:true:false:true:false', 'checkbox:true:false:true:true']; //state1 state2, useFont, onoff\r\n  }\r\n  transform(source: any, data: any, args: any[]) {\r\n    this.state1= args && args.length ? String(args[0]) : \"\";\r\n    this.state2= (args && args.length > 1) ? String(args[1])  : '';\r\n    this.useFont= (args && args.length > 2 && args[2].length) ? args[2] === 'true' : false;\r\n    this.onOff= (args && args.length > 3 && args[3].length) ? args[3] === 'true' : false;\r\n    this.source= String(source);\r\n    this.data = data;\r\n  }\r\n}\r\n\r\n"]}