@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?
109 lines (107 loc) • 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 SwitchComponent {
constructor() {
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) {
event.stopPropagation();
event.preventDefault();
if (!this.disabled && this.validate(this.data, (this.source === this.ideal ? this.original : this.ideal))) {
if (this.source === this.ideal) {
this.source = this.original;
}
else {
this.source = this.ideal;
}
this.onIntoComponentChange.emit({
id: this.id,
name: this.name,
value: this.source,
type: "switch",
item: this.data
});
setTimeout(() => {
if (this.check) {
this.check.nativeElement.focus();
}
if (this.uncheck) {
this.uncheck.nativeElement.focus();
}
}, 66);
}
}
static settingsPatterns() {
return ['switch:::']; //selected, state, alt state
}
transform(source, data, args) {
this.ideal = args.length ? String(args[0]) : "";
this.onText = args.length > 1 ? (args[1].length ? args[1] : 'ON') : 'ON';
this.offText = args.length > 2 ? (args[2].length ? args[2] : 'OFF') : 'OFF';
this.source = String(source);
this.data = data;
this.original = this.source === this.ideal ? "" : source;
}
}
SwitchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SwitchComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
SwitchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: SwitchComponent, selector: "switch-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="source === ideal"
#check
tabindex="{{active ? 0 : -1}}"
class="switch fa fa-toggle-on {{disabled ? 'disabled' : ''}}"
aria-checked="true"
role="checkbox"
(keyup)="keyup($event)"
(click)="click($event)"></span>
<span *ngIf="source !== ideal"
#uncheck tabindex="{{active ? 0 : -1}}"
class="switch fa fa-toggle-off {{disabled ? 'disabled' : ''}}"
aria-checked="false"
role="checkbox"
(keyup)="keyup($event)"
(click)="click($event)"></span>
<span class="text {{disabled ? 'disabled' : ''}}" [class.selected]="source === ideal"
[textContent]="source === ideal ? onText : offText"></span>
`, isInline: true, styles: [":host{display:table;float:left;min-height:var(--sedeh-min-height, 25px)}:host .switch{font-size:1.4rem;cursor:pointer;float:left}:host .switch:focus{outline:none;zoom:1.1;right:var(--sedeh-shift-right, 0);position:relative;color:var(--sedeh-focus-color, darkblue)}:host .switch:hover{opacity:var(--sedeh-hover-opacity, .5)}:host .switch.fa-toggle-on{color:var(--sedeh-sected-color, green)}:host .switch.fa-toggle-off{color:var(--sedeh-disapproved-color, red)}:host .switch.disabled{color:var(--sedeh-disabled-color, #888)}:host .switch.disabled.fa-toggle-on{color:var(--sedeh-disabled-color, #888)}:host .switch.disabled.fa-toggle-off{color:var(--sedeh-disabled-color, #888)}:host .text{font-size:1.2rem;text-transform:uppercase;float:left;margin-left:var(--sedeh-margin-left, 5px)}:host .text.selected{color:var(--sedeh-sected-color, green)}:host .text.disabled{color:var(--sedeh-disabled-color, #888)}\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: SwitchComponent, decorators: [{
type: Component,
args: [{ selector: 'switch-component', template: `
<span *ngIf="source === ideal"
#check
tabindex="{{active ? 0 : -1}}"
class="switch fa fa-toggle-on {{disabled ? 'disabled' : ''}}"
aria-checked="true"
role="checkbox"
(keyup)="keyup($event)"
(click)="click($event)"></span>
<span *ngIf="source !== ideal"
#uncheck tabindex="{{active ? 0 : -1}}"
class="switch fa fa-toggle-off {{disabled ? 'disabled' : ''}}"
aria-checked="false"
role="checkbox"
(keyup)="keyup($event)"
(click)="click($event)"></span>
<span class="text {{disabled ? 'disabled' : ''}}" [class.selected]="source === ideal"
[textContent]="source === ideal ? onText : offText"></span>
`, styles: [":host{display:table;float:left;min-height:var(--sedeh-min-height, 25px)}:host .switch{font-size:1.4rem;cursor:pointer;float:left}:host .switch:focus{outline:none;zoom:1.1;right:var(--sedeh-shift-right, 0);position:relative;color:var(--sedeh-focus-color, darkblue)}:host .switch:hover{opacity:var(--sedeh-hover-opacity, .5)}:host .switch.fa-toggle-on{color:var(--sedeh-sected-color, green)}:host .switch.fa-toggle-off{color:var(--sedeh-disapproved-color, red)}:host .switch.disabled{color:var(--sedeh-disabled-color, #888)}:host .switch.disabled.fa-toggle-on{color:var(--sedeh-disabled-color, #888)}:host .switch.disabled.fa-toggle-off{color:var(--sedeh-disabled-color, #888)}:host .text{font-size:1.2rem;text-transform:uppercase;float:left;margin-left:var(--sedeh-margin-left, 5px)}:host .text.selected{color:var(--sedeh-sected-color, green)}:host .text.disabled{color:var(--sedeh-disabled-color, #888)}\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":"switch.component.js","sourceRoot":"","sources":["../../../../../projects/into-pipes/src/lib/switch/switch.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: 'switch-component',\r\n    template: `\r\n      <span *ngIf=\"source === ideal\" \r\n          #check \r\n          tabindex=\"{{active ? 0 : -1}}\" \r\n          class=\"switch fa fa-toggle-on {{disabled ? 'disabled' : ''}}\" \r\n          aria-checked=\"true\"\r\n          role=\"checkbox\"\r\n          (keyup)=\"keyup($event)\" \r\n          (click)=\"click($event)\"></span>\r\n      <span *ngIf=\"source !== ideal\"\r\n          #uncheck tabindex=\"{{active ? 0 : -1}}\" \r\n          class=\"switch fa fa-toggle-off {{disabled ? 'disabled' : ''}}\" \r\n          aria-checked=\"false\"\r\n          role=\"checkbox\"\r\n          (keyup)=\"keyup($event)\" \r\n          (click)=\"click($event)\"></span>\r\n      <span class=\"text {{disabled ? 'disabled' : ''}}\" [class.selected]=\"source === ideal\" \r\n        [textContent]=\"source === ideal ? onText : offText\"></span>\r\n\r\n    `,\r\n    styles: [\r\n      `\r\n      :host {display:table;float:left;min-height: var(--sedeh-min-height, 25px)}\r\n      :host .switch {font-size: 1.4rem; cursor: pointer;float: left}\r\n      :host .switch:focus{outline: none;zoom: 1.1;right: var(--sedeh-shift-right, 0);position: relative;color: var(--sedeh-focus-color, darkblue);}\r\n      :host .switch:hover{opacity: var(--sedeh-hover-opacity, 0.5);}\r\n      :host .switch.fa-toggle-on {color: var(--sedeh-sected-color, green)}\r\n      :host .switch.fa-toggle-off {color: var(--sedeh-disapproved-color, red)}\r\n      :host .switch.disabled {color: var(--sedeh-disabled-color, #888)}\r\n      :host .switch.disabled.fa-toggle-on {color: var(--sedeh-disabled-color, #888)}\r\n      :host .switch.disabled.fa-toggle-off {color: var(--sedeh-disabled-color, #888)}\r\n\r\n      :host .text {font-size: 1.2rem; text-transform: uppercase; float: left; margin-left: var(--sedeh-margin-left, 5px);}\r\n      :host .text.selected {color:  var(--sedeh-sected-color, green)}\r\n      :host .text.disabled {color:  var(--sedeh-disabled-color, #888)}\r\n      `\r\n    ]\r\n})\r\nexport class SwitchComponent implements PipeComponentInterface {\r\n\r\n  data: any;\r\n  source!: string;\r\n  original!: string;\r\n  ideal!: string;\r\n  id!: string;\r\n  name!: string;\r\n  onText!: string;\r\n  offText!: string;\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) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n\r\n    if (!this.disabled && this.validate(this.data, (this.source === this.ideal ? this.original : this.ideal))) {\r\n      if (this.source === this.ideal) {\r\n        this.source = this.original;\r\n      } else {\r\n        this.source = this.ideal;\r\n      }\r\n      this.onIntoComponentChange.emit({\r\n        id: this.id,\r\n        name: this.name,\r\n        value: this.source,\r\n        type: \"switch\",\r\n        item: this.data\r\n      });\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    }\r\n  }\r\n\r\n  static settingsPatterns() {\r\n    return ['switch:::']; //selected, state, alt state\r\n  }\r\n  transform(source: any, data: any, args: any[]) {\r\n    this.ideal= args.length ? String(args[0]) : \"\";\r\n    this.onText= args.length > 1 ? (args[1].length ? args[1] : 'ON') : 'ON';\r\n    this.offText= args.length > 2 ? (args[2].length ? args[2] : 'OFF') : 'OFF';\r\n    this.source= String(source);\r\n    this.data = data;\r\n    this.original= this.source === this.ideal ? \"\" : source;\r\n  }\r\n}\r\n\r\n"]}