@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?
105 lines • 15.3 kB
JavaScript
import { Component, EventEmitter } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
export class PhoneComponent {
constructor() {
this.disabled = false;
this.active = true;
this.validate = (item, newValue) => true;
this.onIntoComponentChange = new EventEmitter();
}
static settingsPatterns() {
return ['phone:true:true']; //islink, format
}
transform(source, data, args) {
this.source = source;
this.isLink = (args?.length && args[0].length) ? (args[0] === 'true') : false;
this.formatting = (args?.length > 1 && args[1].length) ? (args[1] === 'true') : false;
}
normalizeSource() {
let result = this.source.replace(/[\ \-\.\(\)\+]/g, '');
result = result[0] === '1' ? result.substring(1) : result;
if (result.length === 10) {
result = '+1 ' + result + ';ext=' + result;
}
else if (result.length > 10) {
const b = result.slice(0, 10);
const e = result.slice(10);
result = '+1' + b + ';ext=' + e;
}
return result;
}
formattedSource() {
let result = this.source;
if (this.formatting) {
result = this.source.replace(/[\ \-\.\(\)\+]/g, '');
result = result[0] === '1' ? result.substring(1) : result;
if (result.length === 10) {
result = '+1 ' + result.replace(/(\d{3})(\d{3})(\d{4})/, "($1)$2-$3");
}
else if (result.length > 10) {
const b = result.slice(0, 10);
const e = result.slice(10);
result = '+1 ' + b.replace(/(\d{3})(\d{3})(\d{4})/, "($1)$2-$3");
result += (' ext. ' + e);
}
}
return result;
}
keyup(event) {
const code = event.which;
event.stopPropagation();
event.preventDefault();
if (code === 13 && !this.disabled) {
event.target.click();
}
}
change(event) {
if (!this.disabled) {
this.onIntoComponentChange.emit({
id: this.id,
name: this.name,
value: this.source,
type: 'click',
item: event.type
});
}
}
}
PhoneComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: PhoneComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
PhoneComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: PhoneComponent, selector: "phone", ngImport: i0, template: `
<a
*ngIf="isLink"
tabindex="{{active ? 0 : -1}}"
class="phone {{disabled ? 'disabled' : ''}}"
[href]="disabled ? null : 'tel:' + normalizeSource()"
(keyup)='keyup($event)'
(click)="change($event)">
<span class='fa fa-phone' aria-hidden='true'></span>
<span [textContent]="formattedSource()"></span>
</a>
<span *ngIf="!isLink phone">
<span class='fa fa-phone' aria-hidden='true'></span>
<span [textContent]="formattedSource()"></span>
</span>
`, isInline: true, styles: [":host{display:table;float:left;min-height:var(--sedeh-min-height, 25px)}:host .phone{text-decoration:none}:host .phone:focus{outline:none}:host .phone:focus .fa{zoom:1.1;right:var(--sedeh-shift-right, 0);position:relative;color:var(--sedeh-focus-color, darkblue)}:host .phone:hover{opacity:var(--sedeh-hover-opacity , .5)}:host .phone.disabled .fa-phone{color:var(--sedeh-disabled-color, #888)}:host .phone.disabled:hover .fa-phone{color:var(--sedeh-disabled-color, #888)}:host .phone.disabled{color:var(--sedeh-disabled-color, #888);cursor:default;pointer-events:none;text-decoration:none}:host .fa{margin:var(--sedeh-margin , 0 5px)}@media print{:host a{text-decoration:none}:host .fa-phone{display:none}:host a .fa-phone{display: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: PhoneComponent, decorators: [{
type: Component,
args: [{ selector: 'phone', template: `
<a
*ngIf="isLink"
tabindex="{{active ? 0 : -1}}"
class="phone {{disabled ? 'disabled' : ''}}"
[href]="disabled ? null : 'tel:' + normalizeSource()"
(keyup)='keyup($event)'
(click)="change($event)">
<span class='fa fa-phone' aria-hidden='true'></span>
<span [textContent]="formattedSource()"></span>
</a>
<span *ngIf="!isLink phone">
<span class='fa fa-phone' aria-hidden='true'></span>
<span [textContent]="formattedSource()"></span>
</span>
`, styles: [":host{display:table;float:left;min-height:var(--sedeh-min-height, 25px)}:host .phone{text-decoration:none}:host .phone:focus{outline:none}:host .phone:focus .fa{zoom:1.1;right:var(--sedeh-shift-right, 0);position:relative;color:var(--sedeh-focus-color, darkblue)}:host .phone:hover{opacity:var(--sedeh-hover-opacity , .5)}:host .phone.disabled .fa-phone{color:var(--sedeh-disabled-color, #888)}:host .phone.disabled:hover .fa-phone{color:var(--sedeh-disabled-color, #888)}:host .phone.disabled{color:var(--sedeh-disabled-color, #888);cursor:default;pointer-events:none;text-decoration:none}:host .fa{margin:var(--sedeh-margin , 0 5px)}@media print{:host a{text-decoration:none}:host .fa-phone{display:none}:host a .fa-phone{display:none}}\n"] }]
}] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"phone.component.js","sourceRoot":"","sources":["../../../../../projects/into-pipes/src/lib/phone/phone.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter } from '@angular/core';\r\nimport { PipeComponentInterface } from '../common/pipe.component.interface';\r\n\r\n@Component({\r\n    selector: 'phone',\r\n    template: `\r\n    <a  \r\n        *ngIf=\"isLink\" \r\n        tabindex=\"{{active ? 0 : -1}}\"\r\n        class=\"phone {{disabled ? 'disabled' : ''}}\"\r\n        [href]=\"disabled ? null : 'tel:' + normalizeSource()\" \r\n        (keyup)='keyup($event)' \r\n        (click)=\"change($event)\">\r\n        <span class='fa fa-phone' aria-hidden='true'></span>\r\n        <span [textContent]=\"formattedSource()\"></span>\r\n    </a>\r\n    <span *ngIf=\"!isLink phone\">\r\n        <span class='fa fa-phone' aria-hidden='true'></span>\r\n        <span [textContent]=\"formattedSource()\"></span>\r\n    </span>\r\n    `,\r\n    styles: [\r\n        `\r\n        :host {display:table;float:left;min-height: var(--sedeh-min-height, 25px)}\r\n        :host .phone {text-decoration: none;}\r\n        :host .phone:focus{outline: none;}\r\n        :host .phone:focus .fa{zoom: 1.1;right: var(--sedeh-shift-right, 0);position: relative;color: var(--sedeh-focus-color, darkblue);}\r\n        :host .phone:hover {opacity: var(--sedeh-hover-opacity , 0.5);}\r\n        :host .phone.disabled .fa-phone{color: var(--sedeh-disabled-color, #888);}\r\n        :host .phone.disabled:hover .fa-phone{color: var(--sedeh-disabled-color, #888);}\r\n        :host .phone.disabled{color: var(--sedeh-disabled-color, #888);cursor:default;pointer-events: none;text-decoration: none;}\r\n        :host .fa{margin: var(--sedeh-margin , 0 5px);}\r\n        @media print {\r\n            :host a { text-decoration: none }\r\n            :host .fa-phone {display: none;}\r\n            :host a .fa-phone {display: none;}\r\n        }\r\n        `\r\n    ]\r\n})\r\nexport class PhoneComponent implements PipeComponentInterface {\r\n    source!: string;\r\n\tid!: string;\r\n    name!: string;\r\n    isLink!: boolean;\r\n    formatting!: boolean;  disabled = false;\r\n    active = true;\r\n    validate = (item: any, newValue: any) => true;\r\n\r\n\tonIntoComponentChange = new EventEmitter();\r\n\r\n    static settingsPatterns() {\r\n        return ['phone:true:true']; //islink, format\r\n    }\r\n    transform(source: any, data: any, args: any[]) {\r\n        this.source = source;\r\n        this.isLink= (args?.length && args[0].length) ? (args[0] === 'true') : false;\r\n        this.formatting= (args?.length > 1 && args[1].length) ? (args[1] === 'true') : false;\r\n    }\r\n    normalizeSource() {\r\n        let result = this.source.replace(/[\\ \\-\\.\\(\\)\\+]/g, '');\r\n        result = result[0] === '1' ? result.substring(1) : result;\r\n\r\n        if (result.length === 10) {\r\n            result = '+1 ' + result + ';ext=' + result;\r\n        } else if (result.length > 10) {\r\n            const b = result.slice(0, 10);\r\n            const e = result.slice(10);\r\n            result = '+1' + b + ';ext=' + e;\r\n        }\r\n        return result;\r\n    }\r\n    formattedSource() {\r\n        let result = this.source;\r\n        \r\n        if (this.formatting) {\r\n            result = this.source.replace(/[\\ \\-\\.\\(\\)\\+]/g, '');\r\n            result = result[0] === '1' ? result.substring(1) : result;\r\n\r\n            if (result.length === 10) {\r\n                result = '+1 ' + result.replace(/(\\d{3})(\\d{3})(\\d{4})/, \"($1)$2-$3\"); \r\n            } else if (result.length > 10) {\r\n                const b = result.slice(0, 10);\r\n                const e = result.slice(10);\r\n                result = '+1 ' + b.replace(/(\\d{3})(\\d{3})(\\d{4})/, \"($1)$2-$3\"); \r\n                result+= (' ext. ' + e);\r\n            }\r\n        }\r\n        return result;\r\n    }\r\n    keyup(event: any) {\r\n        const code = event.which;\r\n        event.stopPropagation();\r\n        event.preventDefault();\r\n    \r\n        if (code === 13 && !this.disabled) {\r\n            event.target.click();\r\n        }\r\n    }\r\n    change(event: any) {\r\n        if (!this.disabled) {\r\n            this.onIntoComponentChange.emit({\r\n                id: this.id,\r\n                name: this.name,\r\n                value: this.source,\r\n                type: 'click',\r\n                item: event.type\r\n            });\r\n        }\r\n    }\r\n}\r\n"]}