Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

lct-components

Package Overview
Dependencies
Maintainers
1
Versions
90
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

lct-components - npm Package Compare versions

Comparing version 0.1.0 to 0.1.1

116

bundles/lct-components.umd.js

@@ -591,8 +591,2 @@ (function (global, factory) {

var CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR = {
provide: i2.NG_VALUE_ACCESSOR,
// tslint:disable-next-line: no-use-before-declare
useExisting: i0.forwardRef(function () { return InputTextComponent; }),
multi: true
};
var InputTextComponent = /** @class */ (function () {

@@ -616,16 +610,2 @@ function InputTextComponent(render) {

}
InputTextComponent.prototype.writeValue = function (value) {
if (typeof value !== 'undefined') {
this.onKeyUpHandler(value);
}
};
InputTextComponent.prototype.registerOnChange = function (fn) {
this.propagateChange = fn;
};
InputTextComponent.prototype.registerOnTouched = function (fn) {
// console.log('reg touch', fn)
};
InputTextComponent.prototype.onKeyUpHandler = function (event) {
this.propagateChange(this.inputValue);
};
InputTextComponent.prototype.ngAfterViewInit = function () {

@@ -656,2 +636,22 @@ var _this = this;

};
InputTextComponent.prototype.writeValue = function (value) {
if (typeof value !== 'undefined') {
this.onKeyUpHandler(value);
}
};
InputTextComponent.prototype.registerOnChange = function (fn) {
this.propagateChange = fn;
};
InputTextComponent.prototype.registerOnTouched = function (fn) {
// console.log('reg touch', fn)
};
InputTextComponent.prototype.onKeyUpHandler = function (event) {
if (!this.inputValue && typeof event === 'string') {
this.inputValue = event;
}
if (this.inputValue && event === null) {
this.inputValue = '';
}
this.propagateChange(this.inputValue);
};
InputTextComponent.prototype.click = function () {

@@ -675,3 +675,7 @@ if (!this.disabled) {

InputTextComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0__namespace, type: InputTextComponent, deps: [{ token: i0__namespace.Renderer2 }], target: i0__namespace.ɵɵFactoryTarget.Component });
InputTextComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.5", type: InputTextComponent, selector: "lct-input-text", inputs: { disabled: "disabled", icon: "icon", iconPosition: "iconPosition", pdaAutoEnter: "pdaAutoEnter", placeholder: "placeholder", showIcon: "showIcon", title: "title", type: "type" }, outputs: { enterEmitted: "enterEmitted", iconClick: "iconClick", inputClick: "inputClick" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], viewQueries: [{ propertyName: "inputScan", first: true, predicate: ["inputScan"], descendants: true }, { propertyName: "iconDiv", first: true, predicate: ["iconDiv"], descendants: true }], ngImport: i0__namespace, template: "<div>\n <div class=\"title\">\n {{title}}\n </div>\n <div class=\"input-with-icon iconLeft\">\n <input [type]=\"type\"\n class=\"form-control\"\n #inputScan\n [disabled]=\"disabled\"\n [placeholder]=\"placeholder\"\n [(ngModel)]=\"inputValue\"\n (keydown.enter)=\"enterEmit()\"\n (keydown.tab)=\"enterEmit()\"\n (keyup)=\"onKeyUpHandler($event)\"\n (click)=\"clickInput()\"\n (ngModelChange)=\"lpnUpdate.next(inputScan.value);\"\n >\n <div class=\"icon\" #iconDiv *ngIf=\"showIcon\">\n <img [src]=\"icon\" [ngStyle]=\"{'cursor': disabled ? 'not-allowed' : 'pointer'}\" alt=\"\" (click)=\"click()\">\n </div>\n </div>\n</div>\n", styles: ["*{font-family:\"Barlow\",\"Open Sans\",\"Helvetica Neue\",\"Segoe UI\",\"Calibri\",\"Arial\",sans-serif}.title{color:#3c4149;font-size:12px;letter-spacing:0;line-height:15px;margin-left:2px;margin-bottom:5px}.input-with-icon{box-sizing:border-box;position:relative;height:40px}@media (max-width: 375px){.input-with-icon{height:50px}}.input-with-icon .form-control{height:100%;width:100%;border:1px solid #C2C2C2;border-radius:5px;background-color:#e0e5ee;box-sizing:border-box;color:#3c4149;font-size:14px;letter-spacing:0;line-height:17px;padding:12px 20px 12px 15px}.input-with-icon .form-control.iconLeft{padding:12px 20px 12px 60px}.input-with-icon .form-control:disabled{cursor:not-allowed;background-color:#c8ccd4}.input-with-icon .icon{position:absolute;right:1%;top:.01rem;width:2.6rem;height:2.6rem;border-radius:.3rem;display:flex;justify-content:center;align-items:center;box-sizing:border-box}.input-with-icon .icon :hover{cursor:pointer}@media (max-width: 375px){.input-with-icon .icon{top:.3rem}}.input-with-icon .icon.iconLeft{left:15px}\n"], directives: [{ type: i2__namespace.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i2__namespace.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2__namespace.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i1__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1__namespace.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
InputTextComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.5", type: InputTextComponent, selector: "lct-input-text", inputs: { disabled: "disabled", icon: "icon", iconPosition: "iconPosition", pdaAutoEnter: "pdaAutoEnter", placeholder: "placeholder", showIcon: "showIcon", title: "title", type: "type" }, outputs: { enterEmitted: "enterEmitted", iconClick: "iconClick", inputClick: "inputClick" }, providers: [{
provide: i2.NG_VALUE_ACCESSOR,
useExisting: InputTextComponent,
multi: true
}], viewQueries: [{ propertyName: "inputScan", first: true, predicate: ["inputScan"], descendants: true }, { propertyName: "iconDiv", first: true, predicate: ["iconDiv"], descendants: true }], ngImport: i0__namespace, template: "<div>\n <div class=\"title\">\n {{title}}\n </div>\n <div class=\"input-with-icon iconLeft\">\n <input [type]=\"type\"\n class=\"form-control\"\n #inputScan\n [disabled]=\"disabled\"\n [placeholder]=\"placeholder\"\n [(ngModel)]=\"inputValue\"\n (keydown.enter)=\"enterEmit()\"\n (keydown.tab)=\"enterEmit()\"\n (keyup)=\"onKeyUpHandler($event)\"\n (click)=\"clickInput()\"\n (ngModelChange)=\"lpnUpdate.next(inputScan.value);\"\n >\n <div class=\"icon\" #iconDiv *ngIf=\"showIcon\">\n <img [src]=\"icon\" [ngStyle]=\"{'cursor': disabled ? 'not-allowed' : 'pointer'}\" alt=\"\" (click)=\"click()\">\n </div>\n </div>\n</div>\n", styles: ["*{font-family:\"Barlow\",\"Open Sans\",\"Helvetica Neue\",\"Segoe UI\",\"Calibri\",\"Arial\",sans-serif}.title{color:#3c4149;font-size:12px;letter-spacing:0;line-height:15px;margin-left:2px;margin-bottom:5px}.input-with-icon{box-sizing:border-box;position:relative;height:40px}@media (max-width: 375px){.input-with-icon{height:50px}}.input-with-icon .form-control{height:100%;width:100%;border:1px solid #C2C2C2;border-radius:5px;background-color:#e0e5ee;box-sizing:border-box;color:#3c4149;font-size:14px;letter-spacing:0;line-height:17px;padding:12px 20px 12px 15px}.input-with-icon .form-control.iconLeft{padding:12px 20px 12px 60px}.input-with-icon .form-control:disabled{cursor:not-allowed;background-color:#c8ccd4}.input-with-icon .icon{position:absolute;right:1%;top:.01rem;width:2.6rem;height:2.6rem;border-radius:.3rem;display:flex;justify-content:center;align-items:center;box-sizing:border-box}.input-with-icon .icon :hover{cursor:pointer}@media (max-width: 375px){.input-with-icon .icon{top:.3rem}}.input-with-icon .icon.iconLeft{left:15px}\n"], directives: [{ type: i2__namespace.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i2__namespace.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2__namespace.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i1__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1__namespace.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0__namespace, type: InputTextComponent, decorators: [{

@@ -683,3 +687,7 @@ type: i0.Component,

styleUrls: ['./input-text.component.scss'],
providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR]
providers: [{
provide: i2.NG_VALUE_ACCESSOR,
useExisting: InputTextComponent,
multi: true
}]
}]

@@ -741,11 +749,4 @@ }], ctorParameters: function () { return [{ type: i0__namespace.Renderer2 }]; }, propDecorators: { disabled: [{

var CUSTOM_SWITCH_CONTROL_VALUE_ACCESSOR = {
provide: i2.NG_VALUE_ACCESSOR,
// tslint:disable-next-line: no-use-before-declare
useExisting: i0.forwardRef(function () { return SwitchComponent; }),
multi: true
};
var SwitchComponent = /** @class */ (function () {
function SwitchComponent(renderer) {
this.renderer = renderer;
function SwitchComponent() {
this.checked = false;

@@ -759,22 +760,23 @@ this.disabled = false;

SwitchComponent.prototype.ngAfterViewInit = function () {
var _a, _b;
if ((this.checked === '' || this.checked === true || this.checked !== 'false') && this.checked !== false) {
this.renderer.setAttribute((_a = this.checkbox) === null || _a === void 0 ? void 0 : _a.nativeElement, 'checked', 'checked');
if ((typeof this.checked === 'string' && (this.checked.toLowerCase() === 'true' || this.checked.toLowerCase() === 'checked' || this.checked === '')) ||
(typeof this.checked === 'boolean' && this.checked)) {
console.log('entra al true check');
this.checked = true;
}
if ((this.disabled === '' || this.disabled === true || this.disabled !== 'false') && this.disabled !== false) {
this.renderer.setAttribute((_b = this.checkbox) === null || _b === void 0 ? void 0 : _b.nativeElement, 'disabled', 'disabled');
else {
this.checked = false;
}
};
SwitchComponent.prototype.toggle = function () {
var _a, _b, _c;
if ((_a = this.checkbox) === null || _a === void 0 ? void 0 : _a.nativeElement.checked) {
this.renderer.setAttribute((_b = this.checkbox) === null || _b === void 0 ? void 0 : _b.nativeElement, 'checked', 'checked');
if ((typeof this.disabled === 'string' && (this.disabled.toLowerCase() === 'true' || this.disabled.toLowerCase() === 'disabled' || this.disabled === '')) ||
(typeof this.disabled === 'boolean' && this.disabled)) {
this.disabled = true;
}
else {
this.renderer.removeAttribute((_c = this.checkbox) === null || _c === void 0 ? void 0 : _c.nativeElement, 'checked');
this.disabled = false;
}
};
SwitchComponent.prototype.toggle = function () {
this.checked = !this.checked;
this.onKeyUpHandler();
};
SwitchComponent.prototype.writeValue = function (value) {
console.log('value', value);
if (typeof value !== 'undefined') {

@@ -791,13 +793,18 @@ this.onKeyUpHandler(value);

SwitchComponent.prototype.onKeyUpHandler = function (event) {
var _a;
this.propagateChange((_a = this.checkbox) === null || _a === void 0 ? void 0 : _a.nativeElement.checked);
if (typeof event === 'boolean') {
this.checked = event;
}
this.propagateChange(this.checked);
};
SwitchComponent.prototype.enterEmit = function () {
var _a;
this.enterEmitted.emit((_a = this.checkbox) === null || _a === void 0 ? void 0 : _a.nativeElement.checked);
this.enterEmitted.emit(this.checked);
};
return SwitchComponent;
}());
SwitchComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0__namespace, type: SwitchComponent, deps: [{ token: i0__namespace.Renderer2 }], target: i0__namespace.ɵɵFactoryTarget.Component });
SwitchComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.5", type: SwitchComponent, selector: "lct-switch", inputs: { checked: "checked", disabled: "disabled" }, outputs: { enterEmitted: "enterEmitted" }, providers: [CUSTOM_SWITCH_CONTROL_VALUE_ACCESSOR], viewQueries: [{ propertyName: "checkbox", first: true, predicate: ["checkbox"], descendants: true }], ngImport: i0__namespace, template: "<label class=\"switch\" (click)=\"toggle()\">\n <input type=\"checkbox\" #checkbox >\n <span class=\"slider round\"></span>\n</label>\n", styles: [".switch{position:relative;display:inline-block;width:38px;height:20px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;border:1px solid #C8CCD4;transition:.4s}.slider:before{position:absolute;content:\"\";left:0%;right:50%;top:0%;bottom:0%;background-color:#e0e5ee;box-shadow:0 2px 2px #12245e26;transition:.4s}.slider:after{border:1px solid #C8CCD4;box-sizing:border-box}input:checked+.slider{background-color:#2a5aed;border:1px solid #2A5AED;box-sizing:border-box}input:disabled+.slider{background-color:#c8ccd4;cursor:not-allowed}input:checked+.slider:before{transform:translate(17px)}.slider.round{border-radius:100px}.slider.round:before{border-radius:50%}\n"] });
SwitchComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0__namespace, type: SwitchComponent, deps: [], target: i0__namespace.ɵɵFactoryTarget.Component });
SwitchComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.5", type: SwitchComponent, selector: "lct-switch", inputs: { checked: "checked", disabled: "disabled" }, outputs: { enterEmitted: "enterEmitted" }, providers: [{
provide: i2.NG_VALUE_ACCESSOR,
useExisting: SwitchComponent,
multi: true
}], ngImport: i0__namespace, template: "<label class=\"switch\">\n <input type=\"checkbox\" (click)=\"toggle()\" [checked]=\"checked\" [disabled]=\"disabled\">\n <span class=\"slider round\"></span>\n</label>\n", styles: [".switch{position:relative;display:inline-block;width:38px;height:20px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;border:1px solid #C8CCD4;transition:.4s}.slider:before{position:absolute;content:\"\";left:0%;right:50%;top:0%;bottom:0%;background-color:#e0e5ee;box-shadow:0 2px 2px #12245e26;transition:.4s}.slider:after{border:1px solid #C8CCD4;box-sizing:border-box}input:checked+.slider{background-color:#2a5aed;border:1px solid #2A5AED;box-sizing:border-box}input:disabled+.slider{background-color:#c8ccd4;cursor:not-allowed}input:checked+.slider:before{transform:translate(17px)}.slider.round{border-radius:100px}.slider.round:before{border-radius:50%}\n"] });
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0__namespace, type: SwitchComponent, decorators: [{

@@ -809,11 +816,12 @@ type: i0.Component,

styleUrls: ['./switch.component.css'],
providers: [CUSTOM_SWITCH_CONTROL_VALUE_ACCESSOR]
providers: [{
provide: i2.NG_VALUE_ACCESSOR,
useExisting: SwitchComponent,
multi: true
}]
}]
}], ctorParameters: function () { return [{ type: i0__namespace.Renderer2 }]; }, propDecorators: { checked: [{
}], ctorParameters: function () { return []; }, propDecorators: { checked: [{
type: i0.Input
}], disabled: [{
type: i0.Input
}], checkbox: [{
type: i0.ViewChild,
args: ['checkbox']
}], enterEmitted: [{

@@ -884,4 +892,2 @@ type: i0.Output

exports.ButtonComponent = ButtonComponent;
exports.CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR = CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR;
exports.CUSTOM_SWITCH_CONTROL_VALUE_ACCESSOR = CUSTOM_SWITCH_CONTROL_VALUE_ACCESSOR;
exports.InputTextComponent = InputTextComponent;

@@ -888,0 +894,0 @@ exports.LctComponentsComponent = LctComponentsComponent;

import { __awaiter } from "tslib";
import { Component, EventEmitter, forwardRef, Input, Output, ViewChild } from '@angular/core';
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
import { Subject } from "rxjs";

@@ -9,8 +9,2 @@ import { debounceTime, distinctUntilChanged } from "rxjs/operators";

import * as i2 from "@angular/common";
export const CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR = {
provide: NG_VALUE_ACCESSOR,
// tslint:disable-next-line: no-use-before-declare
useExisting: forwardRef(() => InputTextComponent),
multi: true
};
export class InputTextComponent {

@@ -34,16 +28,2 @@ constructor(render) {

}
writeValue(value) {
if (typeof value !== 'undefined') {
this.onKeyUpHandler(value);
}
}
registerOnChange(fn) {
this.propagateChange = fn;
}
registerOnTouched(fn) {
// console.log('reg touch', fn)
}
onKeyUpHandler(event) {
this.propagateChange(this.inputValue);
}
ngAfterViewInit() {

@@ -70,2 +50,22 @@ var _a, _b;

}
writeValue(value) {
if (typeof value !== 'undefined') {
this.onKeyUpHandler(value);
}
}
registerOnChange(fn) {
this.propagateChange = fn;
}
registerOnTouched(fn) {
// console.log('reg touch', fn)
}
onKeyUpHandler(event) {
if (!this.inputValue && typeof event === 'string') {
this.inputValue = event;
}
if (this.inputValue && event === null) {
this.inputValue = '';
}
this.propagateChange(this.inputValue);
}
click() {

@@ -88,3 +88,7 @@ if (!this.disabled) {

InputTextComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: InputTextComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
InputTextComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.5", type: InputTextComponent, selector: "lct-input-text", inputs: { disabled: "disabled", icon: "icon", iconPosition: "iconPosition", pdaAutoEnter: "pdaAutoEnter", placeholder: "placeholder", showIcon: "showIcon", title: "title", type: "type" }, outputs: { enterEmitted: "enterEmitted", iconClick: "iconClick", inputClick: "inputClick" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], viewQueries: [{ propertyName: "inputScan", first: true, predicate: ["inputScan"], descendants: true }, { propertyName: "iconDiv", first: true, predicate: ["iconDiv"], descendants: true }], ngImport: i0, template: "<div>\n <div class=\"title\">\n {{title}}\n </div>\n <div class=\"input-with-icon iconLeft\">\n <input [type]=\"type\"\n class=\"form-control\"\n #inputScan\n [disabled]=\"disabled\"\n [placeholder]=\"placeholder\"\n [(ngModel)]=\"inputValue\"\n (keydown.enter)=\"enterEmit()\"\n (keydown.tab)=\"enterEmit()\"\n (keyup)=\"onKeyUpHandler($event)\"\n (click)=\"clickInput()\"\n (ngModelChange)=\"lpnUpdate.next(inputScan.value);\"\n >\n <div class=\"icon\" #iconDiv *ngIf=\"showIcon\">\n <img [src]=\"icon\" [ngStyle]=\"{'cursor': disabled ? 'not-allowed' : 'pointer'}\" alt=\"\" (click)=\"click()\">\n </div>\n </div>\n</div>\n", styles: ["*{font-family:\"Barlow\",\"Open Sans\",\"Helvetica Neue\",\"Segoe UI\",\"Calibri\",\"Arial\",sans-serif}.title{color:#3c4149;font-size:12px;letter-spacing:0;line-height:15px;margin-left:2px;margin-bottom:5px}.input-with-icon{box-sizing:border-box;position:relative;height:40px}@media (max-width: 375px){.input-with-icon{height:50px}}.input-with-icon .form-control{height:100%;width:100%;border:1px solid #C2C2C2;border-radius:5px;background-color:#e0e5ee;box-sizing:border-box;color:#3c4149;font-size:14px;letter-spacing:0;line-height:17px;padding:12px 20px 12px 15px}.input-with-icon .form-control.iconLeft{padding:12px 20px 12px 60px}.input-with-icon .form-control:disabled{cursor:not-allowed;background-color:#c8ccd4}.input-with-icon .icon{position:absolute;right:1%;top:.01rem;width:2.6rem;height:2.6rem;border-radius:.3rem;display:flex;justify-content:center;align-items:center;box-sizing:border-box}.input-with-icon .icon :hover{cursor:pointer}@media (max-width: 375px){.input-with-icon .icon{top:.3rem}}.input-with-icon .icon.iconLeft{left:15px}\n"], directives: [{ type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
InputTextComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.5", type: InputTextComponent, selector: "lct-input-text", inputs: { disabled: "disabled", icon: "icon", iconPosition: "iconPosition", pdaAutoEnter: "pdaAutoEnter", placeholder: "placeholder", showIcon: "showIcon", title: "title", type: "type" }, outputs: { enterEmitted: "enterEmitted", iconClick: "iconClick", inputClick: "inputClick" }, providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: InputTextComponent,
multi: true
}], viewQueries: [{ propertyName: "inputScan", first: true, predicate: ["inputScan"], descendants: true }, { propertyName: "iconDiv", first: true, predicate: ["iconDiv"], descendants: true }], ngImport: i0, template: "<div>\n <div class=\"title\">\n {{title}}\n </div>\n <div class=\"input-with-icon iconLeft\">\n <input [type]=\"type\"\n class=\"form-control\"\n #inputScan\n [disabled]=\"disabled\"\n [placeholder]=\"placeholder\"\n [(ngModel)]=\"inputValue\"\n (keydown.enter)=\"enterEmit()\"\n (keydown.tab)=\"enterEmit()\"\n (keyup)=\"onKeyUpHandler($event)\"\n (click)=\"clickInput()\"\n (ngModelChange)=\"lpnUpdate.next(inputScan.value);\"\n >\n <div class=\"icon\" #iconDiv *ngIf=\"showIcon\">\n <img [src]=\"icon\" [ngStyle]=\"{'cursor': disabled ? 'not-allowed' : 'pointer'}\" alt=\"\" (click)=\"click()\">\n </div>\n </div>\n</div>\n", styles: ["*{font-family:\"Barlow\",\"Open Sans\",\"Helvetica Neue\",\"Segoe UI\",\"Calibri\",\"Arial\",sans-serif}.title{color:#3c4149;font-size:12px;letter-spacing:0;line-height:15px;margin-left:2px;margin-bottom:5px}.input-with-icon{box-sizing:border-box;position:relative;height:40px}@media (max-width: 375px){.input-with-icon{height:50px}}.input-with-icon .form-control{height:100%;width:100%;border:1px solid #C2C2C2;border-radius:5px;background-color:#e0e5ee;box-sizing:border-box;color:#3c4149;font-size:14px;letter-spacing:0;line-height:17px;padding:12px 20px 12px 15px}.input-with-icon .form-control.iconLeft{padding:12px 20px 12px 60px}.input-with-icon .form-control:disabled{cursor:not-allowed;background-color:#c8ccd4}.input-with-icon .icon{position:absolute;right:1%;top:.01rem;width:2.6rem;height:2.6rem;border-radius:.3rem;display:flex;justify-content:center;align-items:center;box-sizing:border-box}.input-with-icon .icon :hover{cursor:pointer}@media (max-width: 375px){.input-with-icon .icon{top:.3rem}}.input-with-icon .icon.iconLeft{left:15px}\n"], directives: [{ type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: InputTextComponent, decorators: [{

@@ -96,3 +100,7 @@ type: Component,

styleUrls: ['./input-text.component.scss'],
providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR]
providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: InputTextComponent,
multi: true
}]
}]

@@ -128,2 +136,2 @@ }], ctorParameters: function () { return [{ type: i0.Renderer2 }]; }, propDecorators: { disabled: [{

}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-text.component.js","sourceRoot":"","sources":["../../../../../projects/lct-components/src/lib/input-text/input-text.component.ts","../../../../../projects/lct-components/src/lib/input-text/input-text.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter, forwardRef,\n  Input,\n  OnInit,\n  Output,\n  Renderer2,\n  ViewChild\n} from '@angular/core';\nimport {Subject} from \"rxjs\";\nimport {debounceTime, distinctUntilChanged} from \"rxjs/operators\";\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from \"@angular/forms\";\n\nexport const CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  // tslint:disable-next-line: no-use-before-declare\n  useExisting: forwardRef(() => InputTextComponent),\n  multi: true\n};\n\n@Component({\n  selector: 'lct-input-text',\n  templateUrl: './input-text.component.html',\n  styleUrls: ['./input-text.component.scss'],\n  providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR]\n})\nexport class InputTextComponent implements ControlValueAccessor, OnInit, AfterViewInit {\n\n  @Input() disabled = false;\n  @Input() icon = ''\n  @Input() iconPosition: 'left' | 'right' = 'right';\n  @Input() pdaAutoEnter = false;\n  @Input() placeholder = '';\n  @Input() showIcon = false;\n  @Input() title = 'Insert Title';\n  @Input() type: 'email' | 'number' | 'text' = 'text';\n  @Output() enterEmitted = new EventEmitter<string>()\n  @Output() iconClick = new EventEmitter();\n  @Output() inputClick = new EventEmitter();\n  @ViewChild('inputScan') inputScan: ElementRef | undefined;\n  @ViewChild('iconDiv') iconDiv: ElementRef | undefined;\n\n  inputValue = '';\n  public lpnUpdate = new Subject<string>();\n\n  public propagateChange = (_: any) => { };\n\n  constructor(private render: Renderer2) {\n  }\n\n  writeValue(value: any): void {\n    if (typeof value !== 'undefined') {\n      this.onKeyUpHandler(value);\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n   // console.log('reg touch', fn)\n  }\n\n  onKeyUpHandler(event?: KeyboardEvent) {\n    this.propagateChange(this.inputValue);\n  }\n\n  ngAfterViewInit() {\n    if (this.iconPosition === \"left\" && this.showIcon) {\n      this.render.addClass(this.inputScan?.nativeElement, 'iconLeft')\n      this.render.addClass(this.iconDiv?.nativeElement, 'iconLeft')\n    }\n    if (this.pdaAutoEnter) {\n      this.lpnUpdate\n        .pipe(\n          debounceTime(200),\n          distinctUntilChanged()\n        )\n        .subscribe(async value => {\n          if (value) {\n            this.enterEmit();\n          } else {\n            return;\n          }\n        });\n    }\n  }\n\n  ngOnInit(): void {\n  }\n\n  click() {\n    if (!this.disabled) {\n      this.iconClick.emit('iconClick')\n    }\n  }\n\n  clickInput( ) {\n    if (!this.disabled) {\n      this.inputClick.emit('inputClick')\n    }\n  }\n\n  enterEmit() {\n    if (this.inputValue) {\n      this.enterEmitted.emit(this.inputValue);\n    }\n  }\n\n}\n","<div>\n  <div class=\"title\">\n    {{title}}\n  </div>\n  <div class=\"input-with-icon iconLeft\">\n    <input [type]=\"type\"\n           class=\"form-control\"\n           #inputScan\n           [disabled]=\"disabled\"\n           [placeholder]=\"placeholder\"\n           [(ngModel)]=\"inputValue\"\n           (keydown.enter)=\"enterEmit()\"\n           (keydown.tab)=\"enterEmit()\"\n           (keyup)=\"onKeyUpHandler($event)\"\n           (click)=\"clickInput()\"\n           (ngModelChange)=\"lpnUpdate.next(inputScan.value);\"\n    >\n    <div class=\"icon\" #iconDiv *ngIf=\"showIcon\">\n      <img [src]=\"icon\" [ngStyle]=\"{'cursor': disabled ? 'not-allowed' : 'pointer'}\" alt=\"\" (click)=\"click()\">\n    </div>\n  </div>\n</div>\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-text.component.js","sourceRoot":"","sources":["../../../../../projects/lct-components/src/lib/input-text/input-text.component.ts","../../../../../projects/lct-components/src/lib/input-text/input-text.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  Renderer2,\n  ViewChild\n} from '@angular/core';\nimport {Subject} from \"rxjs\";\nimport {debounceTime, distinctUntilChanged} from \"rxjs/operators\";\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from \"@angular/forms\";\n\n@Component({\n  selector: 'lct-input-text',\n  templateUrl: './input-text.component.html',\n  styleUrls: ['./input-text.component.scss'],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: InputTextComponent,\n    multi: true\n  }]\n})\nexport class InputTextComponent implements ControlValueAccessor, OnInit, AfterViewInit {\n\n  @Input() disabled = false;\n  @Input() icon = ''\n  @Input() iconPosition: 'left' | 'right' = 'right';\n  @Input() pdaAutoEnter = false;\n  @Input() placeholder = '';\n  @Input() showIcon = false;\n  @Input() title = 'Insert Title';\n  @Input() type: 'email' | 'number' | 'text' = 'text';\n  @Output() enterEmitted = new EventEmitter<string>()\n  @Output() iconClick = new EventEmitter();\n  @Output() inputClick = new EventEmitter();\n  @ViewChild('inputScan') inputScan: ElementRef | undefined;\n  @ViewChild('iconDiv') iconDiv: ElementRef | undefined;\n\n  inputValue = '';\n  public lpnUpdate = new Subject<string>();\n\n  public propagateChange = (_: any) => { };\n\n  constructor(private render: Renderer2) {\n  }\n\n  ngAfterViewInit() {\n    if (this.iconPosition === \"left\" && this.showIcon) {\n      this.render.addClass(this.inputScan?.nativeElement, 'iconLeft')\n      this.render.addClass(this.iconDiv?.nativeElement, 'iconLeft')\n    }\n    if (this.pdaAutoEnter) {\n      this.lpnUpdate\n        .pipe(\n          debounceTime(200),\n          distinctUntilChanged()\n        )\n        .subscribe(async value => {\n          if (value) {\n            this.enterEmit();\n          } else {\n            return;\n          }\n        });\n    }\n  }\n\n  ngOnInit(): void {\n  }\n\n  writeValue(value: any): void {\n    if (typeof value !== 'undefined') {\n      this.onKeyUpHandler(value);\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    // console.log('reg touch', fn)\n  }\n\n  onKeyUpHandler(event?: KeyboardEvent | string) {\n    if (!this.inputValue && typeof event === 'string') {\n      this.inputValue = event;\n    }\n    if (this.inputValue && event === null){\n      this.inputValue = '';\n    }\n    this.propagateChange(this.inputValue);\n  }\n\n  click() {\n    if (!this.disabled) {\n      this.iconClick.emit('iconClick')\n    }\n  }\n\n  clickInput( ) {\n    if (!this.disabled) {\n      this.inputClick.emit('inputClick')\n    }\n  }\n\n  enterEmit() {\n    if (this.inputValue) {\n      this.enterEmitted.emit(this.inputValue);\n    }\n  }\n\n}\n","<div>\n  <div class=\"title\">\n    {{title}}\n  </div>\n  <div class=\"input-with-icon iconLeft\">\n    <input [type]=\"type\"\n           class=\"form-control\"\n           #inputScan\n           [disabled]=\"disabled\"\n           [placeholder]=\"placeholder\"\n           [(ngModel)]=\"inputValue\"\n           (keydown.enter)=\"enterEmit()\"\n           (keydown.tab)=\"enterEmit()\"\n           (keyup)=\"onKeyUpHandler($event)\"\n           (click)=\"clickInput()\"\n           (ngModelChange)=\"lpnUpdate.next(inputScan.value);\"\n    >\n    <div class=\"icon\" #iconDiv *ngIf=\"showIcon\">\n      <img [src]=\"icon\" [ngStyle]=\"{'cursor': disabled ? 'not-allowed' : 'pointer'}\" alt=\"\" (click)=\"click()\">\n    </div>\n  </div>\n</div>\n"]}

@@ -10,3 +10,3 @@ import { NgModule } from '@angular/core';

import { LoadingComponent } from './loading/loading.component';
import { SwitchComponent } from './switch/switch.component';
import { SwitchComponent } from "./switch/switch.component";
import * as i0 from "@angular/core";

@@ -61,2 +61,2 @@ export class LctComponentsModule {

}] });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGN0LWNvbXBvbmVudHMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbGN0LWNvbXBvbmVudHMvc3JjL2xpYi9sY3QtY29tcG9uZW50cy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNwRSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQztBQUN0RixPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQzNDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDNUQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDdkUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDL0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDJCQUEyQixDQUFDOztBQTRCNUQsTUFBTSxPQUFPLG1CQUFtQjs7Z0hBQW5CLG1CQUFtQjtpSEFBbkIsbUJBQW1CLGlCQXRCNUIsZUFBZTtRQUNmLGtCQUFrQjtRQUNsQixzQkFBc0I7UUFDdEIsZUFBZTtRQUNmLHVCQUF1QjtRQUN2QixnQkFBZ0I7UUFDaEIsZUFBZSxhQUdmLFlBQVk7UUFDWixXQUFXLGFBR1gsZUFBZTtRQUNmLGtCQUFrQjtRQUNsQixzQkFBc0I7UUFDdEIsZUFBZTtRQUNmLHVCQUF1QjtRQUN2QixnQkFBZ0I7UUFDaEIsZUFBZTtpSEFHTixtQkFBbUIsWUFkckI7WUFDUCxZQUFZO1lBQ1osV0FBVztTQUNaOzJGQVdVLG1CQUFtQjtrQkF4Qi9CLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLGVBQWU7d0JBQ2Ysa0JBQWtCO3dCQUNsQixzQkFBc0I7d0JBQ3RCLGVBQWU7d0JBQ2YsdUJBQXVCO3dCQUN2QixnQkFBZ0I7d0JBQ2hCLGVBQWU7cUJBQ2hCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLFdBQVc7cUJBQ1o7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGVBQWU7d0JBQ2Ysa0JBQWtCO3dCQUNsQixzQkFBc0I7d0JBQ3RCLGVBQWU7d0JBQ2YsdUJBQXVCO3dCQUN2QixnQkFBZ0I7d0JBQ2hCLGVBQWU7cUJBQ2hCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IExjdENvbXBvbmVudHNDb21wb25lbnQgfSBmcm9tICcuL2xjdC1jb21wb25lbnRzLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTZWxlY3RNdWx0aXBsZUNvbXBvbmVudCB9IGZyb20gJy4vc2VsZWN0LW11bHRpcGxlL3NlbGVjdC1tdWx0aXBsZS5jb21wb25lbnQnO1xuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcbmltcG9ydCB7Rm9ybXNNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xuaW1wb3J0IHsgU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9zZWxlY3Qvc2VsZWN0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCdXR0b25Db21wb25lbnQgfSBmcm9tICcuL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcbmltcG9ydCB7IElucHV0VGV4dENvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQtdGV4dC9pbnB1dC10ZXh0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBMb2FkaW5nQ29tcG9uZW50IH0gZnJvbSAnLi9sb2FkaW5nL2xvYWRpbmcuY29tcG9uZW50JztcbmltcG9ydCB7IFN3aXRjaENvbXBvbmVudCB9IGZyb20gJy4vc3dpdGNoL3N3aXRjaC5jb21wb25lbnQnO1xuXG5cblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgQnV0dG9uQ29tcG9uZW50LFxuICAgIElucHV0VGV4dENvbXBvbmVudCxcbiAgICBMY3RDb21wb25lbnRzQ29tcG9uZW50LFxuICAgIFNlbGVjdENvbXBvbmVudCxcbiAgICBTZWxlY3RNdWx0aXBsZUNvbXBvbmVudCxcbiAgICBMb2FkaW5nQ29tcG9uZW50LFxuICAgIFN3aXRjaENvbXBvbmVudFxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBCdXR0b25Db21wb25lbnQsXG4gICAgSW5wdXRUZXh0Q29tcG9uZW50LFxuICAgIExjdENvbXBvbmVudHNDb21wb25lbnQsXG4gICAgU2VsZWN0Q29tcG9uZW50LFxuICAgIFNlbGVjdE11bHRpcGxlQ29tcG9uZW50LFxuICAgIExvYWRpbmdDb21wb25lbnQsXG4gICAgU3dpdGNoQ29tcG9uZW50XG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgTGN0Q29tcG9uZW50c01vZHVsZSB7IH1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGN0LWNvbXBvbmVudHMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbGN0LWNvbXBvbmVudHMvc3JjL2xpYi9sY3QtY29tcG9uZW50cy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNwRSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQztBQUN0RixPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQzNDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDNUQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDdkUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDL0QsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLDJCQUEyQixDQUFDOztBQTRCMUQsTUFBTSxPQUFPLG1CQUFtQjs7Z0hBQW5CLG1CQUFtQjtpSEFBbkIsbUJBQW1CLGlCQXRCNUIsZUFBZTtRQUNmLGtCQUFrQjtRQUNsQixzQkFBc0I7UUFDdEIsZUFBZTtRQUNmLHVCQUF1QjtRQUN2QixnQkFBZ0I7UUFDaEIsZUFBZSxhQUdmLFlBQVk7UUFDWixXQUFXLGFBR1gsZUFBZTtRQUNmLGtCQUFrQjtRQUNsQixzQkFBc0I7UUFDdEIsZUFBZTtRQUNmLHVCQUF1QjtRQUN2QixnQkFBZ0I7UUFDaEIsZUFBZTtpSEFHTixtQkFBbUIsWUFkckI7WUFDUCxZQUFZO1lBQ1osV0FBVztTQUNaOzJGQVdVLG1CQUFtQjtrQkF4Qi9CLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLGVBQWU7d0JBQ2Ysa0JBQWtCO3dCQUNsQixzQkFBc0I7d0JBQ3RCLGVBQWU7d0JBQ2YsdUJBQXVCO3dCQUN2QixnQkFBZ0I7d0JBQ2hCLGVBQWU7cUJBQ2hCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLFdBQVc7cUJBQ1o7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGVBQWU7d0JBQ2Ysa0JBQWtCO3dCQUNsQixzQkFBc0I7d0JBQ3RCLGVBQWU7d0JBQ2YsdUJBQXVCO3dCQUN2QixnQkFBZ0I7d0JBQ2hCLGVBQWU7cUJBQ2hCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IExjdENvbXBvbmVudHNDb21wb25lbnQgfSBmcm9tICcuL2xjdC1jb21wb25lbnRzLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTZWxlY3RNdWx0aXBsZUNvbXBvbmVudCB9IGZyb20gJy4vc2VsZWN0LW11bHRpcGxlL3NlbGVjdC1tdWx0aXBsZS5jb21wb25lbnQnO1xuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcbmltcG9ydCB7Rm9ybXNNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xuaW1wb3J0IHsgU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9zZWxlY3Qvc2VsZWN0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCdXR0b25Db21wb25lbnQgfSBmcm9tICcuL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcbmltcG9ydCB7IElucHV0VGV4dENvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQtdGV4dC9pbnB1dC10ZXh0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBMb2FkaW5nQ29tcG9uZW50IH0gZnJvbSAnLi9sb2FkaW5nL2xvYWRpbmcuY29tcG9uZW50JztcbmltcG9ydCB7U3dpdGNoQ29tcG9uZW50fSBmcm9tIFwiLi9zd2l0Y2gvc3dpdGNoLmNvbXBvbmVudFwiO1xuXG5cblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgQnV0dG9uQ29tcG9uZW50LFxuICAgIElucHV0VGV4dENvbXBvbmVudCxcbiAgICBMY3RDb21wb25lbnRzQ29tcG9uZW50LFxuICAgIFNlbGVjdENvbXBvbmVudCxcbiAgICBTZWxlY3RNdWx0aXBsZUNvbXBvbmVudCxcbiAgICBMb2FkaW5nQ29tcG9uZW50LFxuICAgIFN3aXRjaENvbXBvbmVudFxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBCdXR0b25Db21wb25lbnQsXG4gICAgSW5wdXRUZXh0Q29tcG9uZW50LFxuICAgIExjdENvbXBvbmVudHNDb21wb25lbnQsXG4gICAgU2VsZWN0Q29tcG9uZW50LFxuICAgIFNlbGVjdE11bHRpcGxlQ29tcG9uZW50LFxuICAgIExvYWRpbmdDb21wb25lbnQsXG4gICAgU3dpdGNoQ29tcG9uZW50XG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgTGN0Q29tcG9uZW50c01vZHVsZSB7IH1cbiJdfQ==

@@ -1,13 +0,6 @@

import { Component, EventEmitter, forwardRef, Input, Output, ViewChild } from '@angular/core';
import { Component, EventEmitter, Input, Output } from '@angular/core';
import { NG_VALUE_ACCESSOR } from "@angular/forms";
import * as i0 from "@angular/core";
export const CUSTOM_SWITCH_CONTROL_VALUE_ACCESSOR = {
provide: NG_VALUE_ACCESSOR,
// tslint:disable-next-line: no-use-before-declare
useExisting: forwardRef(() => SwitchComponent),
multi: true
};
export class SwitchComponent {
constructor(renderer) {
this.renderer = renderer;
constructor() {
this.checked = false;

@@ -21,22 +14,23 @@ this.disabled = false;

ngAfterViewInit() {
var _a, _b;
if ((this.checked === '' || this.checked === true || this.checked !== 'false') && this.checked !== false) {
this.renderer.setAttribute((_a = this.checkbox) === null || _a === void 0 ? void 0 : _a.nativeElement, 'checked', 'checked');
if ((typeof this.checked === 'string' && (this.checked.toLowerCase() === 'true' || this.checked.toLowerCase() === 'checked' || this.checked === '')) ||
(typeof this.checked === 'boolean' && this.checked)) {
console.log('entra al true check');
this.checked = true;
}
if ((this.disabled === '' || this.disabled === true || this.disabled !== 'false') && this.disabled !== false) {
this.renderer.setAttribute((_b = this.checkbox) === null || _b === void 0 ? void 0 : _b.nativeElement, 'disabled', 'disabled');
else {
this.checked = false;
}
}
toggle() {
var _a, _b, _c;
if ((_a = this.checkbox) === null || _a === void 0 ? void 0 : _a.nativeElement.checked) {
this.renderer.setAttribute((_b = this.checkbox) === null || _b === void 0 ? void 0 : _b.nativeElement, 'checked', 'checked');
if ((typeof this.disabled === 'string' && (this.disabled.toLowerCase() === 'true' || this.disabled.toLowerCase() === 'disabled' || this.disabled === '')) ||
(typeof this.disabled === 'boolean' && this.disabled)) {
this.disabled = true;
}
else {
this.renderer.removeAttribute((_c = this.checkbox) === null || _c === void 0 ? void 0 : _c.nativeElement, 'checked');
this.disabled = false;
}
}
toggle() {
this.checked = !this.checked;
this.onKeyUpHandler();
}
writeValue(value) {
console.log('value', value);
if (typeof value !== 'undefined') {

@@ -53,12 +47,17 @@ this.onKeyUpHandler(value);

onKeyUpHandler(event) {
var _a;
this.propagateChange((_a = this.checkbox) === null || _a === void 0 ? void 0 : _a.nativeElement.checked);
if (typeof event === 'boolean') {
this.checked = event;
}
this.propagateChange(this.checked);
}
enterEmit() {
var _a;
this.enterEmitted.emit((_a = this.checkbox) === null || _a === void 0 ? void 0 : _a.nativeElement.checked);
this.enterEmitted.emit(this.checked);
}
}
SwitchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: SwitchComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
SwitchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.5", type: SwitchComponent, selector: "lct-switch", inputs: { checked: "checked", disabled: "disabled" }, outputs: { enterEmitted: "enterEmitted" }, providers: [CUSTOM_SWITCH_CONTROL_VALUE_ACCESSOR], viewQueries: [{ propertyName: "checkbox", first: true, predicate: ["checkbox"], descendants: true }], ngImport: i0, template: "<label class=\"switch\" (click)=\"toggle()\">\n <input type=\"checkbox\" #checkbox >\n <span class=\"slider round\"></span>\n</label>\n", styles: [".switch{position:relative;display:inline-block;width:38px;height:20px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;border:1px solid #C8CCD4;transition:.4s}.slider:before{position:absolute;content:\"\";left:0%;right:50%;top:0%;bottom:0%;background-color:#e0e5ee;box-shadow:0 2px 2px #12245e26;transition:.4s}.slider:after{border:1px solid #C8CCD4;box-sizing:border-box}input:checked+.slider{background-color:#2a5aed;border:1px solid #2A5AED;box-sizing:border-box}input:disabled+.slider{background-color:#c8ccd4;cursor:not-allowed}input:checked+.slider:before{transform:translate(17px)}.slider.round{border-radius:100px}.slider.round:before{border-radius:50%}\n"] });
SwitchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: SwitchComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
SwitchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.5", type: SwitchComponent, selector: "lct-switch", inputs: { checked: "checked", disabled: "disabled" }, outputs: { enterEmitted: "enterEmitted" }, providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: SwitchComponent,
multi: true
}], ngImport: i0, template: "<label class=\"switch\">\n <input type=\"checkbox\" (click)=\"toggle()\" [checked]=\"checked\" [disabled]=\"disabled\">\n <span class=\"slider round\"></span>\n</label>\n", styles: [".switch{position:relative;display:inline-block;width:38px;height:20px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;border:1px solid #C8CCD4;transition:.4s}.slider:before{position:absolute;content:\"\";left:0%;right:50%;top:0%;bottom:0%;background-color:#e0e5ee;box-shadow:0 2px 2px #12245e26;transition:.4s}.slider:after{border:1px solid #C8CCD4;box-sizing:border-box}input:checked+.slider{background-color:#2a5aed;border:1px solid #2A5AED;box-sizing:border-box}input:disabled+.slider{background-color:#c8ccd4;cursor:not-allowed}input:checked+.slider:before{transform:translate(17px)}.slider.round{border-radius:100px}.slider.round:before{border-radius:50%}\n"] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: SwitchComponent, decorators: [{

@@ -70,14 +69,15 @@ type: Component,

styleUrls: ['./switch.component.css'],
providers: [CUSTOM_SWITCH_CONTROL_VALUE_ACCESSOR]
providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: SwitchComponent,
multi: true
}]
}]
}], ctorParameters: function () { return [{ type: i0.Renderer2 }]; }, propDecorators: { checked: [{
}], ctorParameters: function () { return []; }, propDecorators: { checked: [{
type: Input
}], disabled: [{
type: Input
}], checkbox: [{
type: ViewChild,
args: ['checkbox']
}], enterEmitted: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2xjdC1jb21wb25lbnRzL3NyYy9saWIvc3dpdGNoL3N3aXRjaC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9sY3QtY29tcG9uZW50cy9zcmMvbGliL3N3aXRjaC9zd2l0Y2guY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFNBQVMsRUFFVCxZQUFZLEVBQUUsVUFBVSxFQUN4QixLQUFLLEVBRUwsTUFBTSxFQUVOLFNBQVMsRUFDVixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQXVCLGlCQUFpQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7O0FBRXZFLE1BQU0sQ0FBQyxNQUFNLG9DQUFvQyxHQUFRO0lBQ3ZELE9BQU8sRUFBRSxpQkFBaUI7SUFDMUIsa0RBQWtEO0lBQ2xELFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsZUFBZSxDQUFDO0lBQzlDLEtBQUssRUFBRSxJQUFJO0NBQ1osQ0FBQztBQVFGLE1BQU0sT0FBTyxlQUFlO0lBUzFCLFlBQW9CLFFBQW1CO1FBQW5CLGFBQVEsR0FBUixRQUFRLENBQVc7UUFQOUIsWUFBTyxHQUFxQixLQUFLLENBQUM7UUFDbEMsYUFBUSxHQUFxQixLQUFLLENBQUM7UUFFbEMsaUJBQVksR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFBO1FBRTVDLG9CQUFlLEdBQUcsQ0FBQyxDQUFNLEVBQUUsRUFBRSxHQUFHLENBQUMsQ0FBQztJQUVFLENBQUM7SUFFNUMsUUFBUTtJQUNSLENBQUM7SUFFRCxlQUFlOztRQUNiLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxLQUFLLEVBQUUsSUFBSSxJQUFJLENBQUMsT0FBTyxLQUFLLElBQUksSUFBSSxJQUFJLENBQUMsT0FBTyxLQUFLLE9BQU8sQ0FBQyxJQUFJLElBQUksQ0FBQyxPQUFPLEtBQUssS0FBSyxFQUFFO1lBQ3hHLElBQUksQ0FBQyxRQUFRLENBQUMsWUFBWSxDQUFDLE1BQUEsSUFBSSxDQUFDLFFBQVEsMENBQUUsYUFBYSxFQUFDLFNBQVMsRUFBRSxTQUFTLENBQUMsQ0FBQztTQUMvRTtRQUNELElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxLQUFLLEVBQUUsSUFBSSxJQUFJLENBQUMsUUFBUSxLQUFLLElBQUksSUFBSSxJQUFJLENBQUMsUUFBUSxLQUFLLE9BQU8sQ0FBQyxJQUFJLElBQUksQ0FBQyxRQUFRLEtBQUssS0FBSyxFQUFFO1lBQzVHLElBQUksQ0FBQyxRQUFRLENBQUMsWUFBWSxDQUFDLE1BQUEsSUFBSSxDQUFDLFFBQVEsMENBQUUsYUFBYSxFQUFDLFVBQVUsRUFBRSxVQUFVLENBQUMsQ0FBQztTQUNqRjtJQUNILENBQUM7SUFFRCxNQUFNOztRQUNKLElBQUksTUFBQSxJQUFJLENBQUMsUUFBUSwwQ0FBRSxhQUFhLENBQUMsT0FBTyxFQUFFO1lBQ3hDLElBQUksQ0FBQyxRQUFRLENBQUMsWUFBWSxDQUFDLE1BQUEsSUFBSSxDQUFDLFFBQVEsMENBQUUsYUFBYSxFQUFDLFNBQVMsRUFBRSxTQUFTLENBQUMsQ0FBQztTQUMvRTthQUFNO1lBQ0wsSUFBSSxDQUFDLFFBQVEsQ0FBQyxlQUFlLENBQUMsTUFBQSxJQUFJLENBQUMsUUFBUSwwQ0FBRSxhQUFhLEVBQUMsU0FBUyxDQUFDLENBQUM7U0FDdkU7UUFDRCxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQUVELFVBQVUsQ0FBQyxLQUFVO1FBQ25CLE9BQU8sQ0FBQyxHQUFHLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQzVCLElBQUksT0FBTyxLQUFLLEtBQUssV0FBVyxFQUFFO1lBQ2hDLElBQUksQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDNUI7SUFDSCxDQUFDO0lBRUQsZ0JBQWdCLENBQUMsRUFBTztRQUN0QixJQUFJLENBQUMsZUFBZSxHQUFHLEVBQUUsQ0FBQztJQUM1QixDQUFDO0lBRUQsaUJBQWlCLENBQUMsRUFBTztRQUN2QiwrQkFBK0I7SUFDakMsQ0FBQztJQUVELGNBQWMsQ0FBQyxLQUFxQjs7UUFDbEMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxNQUFBLElBQUksQ0FBQyxRQUFRLDBDQUFFLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUM3RCxDQUFDO0lBR0QsU0FBUzs7UUFDUCxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxNQUFBLElBQUksQ0FBQyxRQUFRLDBDQUFFLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUMvRCxDQUFDOzs0R0F0RFUsZUFBZTtnR0FBZixlQUFlLHNJQUZmLENBQUMsb0NBQW9DLENBQUMsZ0lDekJuRCwySUFJQTsyRkR1QmEsZUFBZTtrQkFOM0IsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsWUFBWTtvQkFDdEIsV0FBVyxFQUFFLHlCQUF5QjtvQkFDdEMsU0FBUyxFQUFFLENBQUMsd0JBQXdCLENBQUM7b0JBQ3JDLFNBQVMsRUFBRSxDQUFDLG9DQUFvQyxDQUFDO2lCQUNsRDtnR0FHVSxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDaUIsUUFBUTtzQkFBOUIsU0FBUzt1QkFBQyxVQUFVO2dCQUNYLFlBQVk7c0JBQXJCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBBZnRlclZpZXdJbml0LFxuICBDb21wb25lbnQsXG4gIEVsZW1lbnRSZWYsXG4gIEV2ZW50RW1pdHRlciwgZm9yd2FyZFJlZixcbiAgSW5wdXQsXG4gIE9uSW5pdCxcbiAgT3V0cHV0LFxuICBSZW5kZXJlcjIsXG4gIFZpZXdDaGlsZFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtDb250cm9sVmFsdWVBY2Nlc3NvciwgTkdfVkFMVUVfQUNDRVNTT1J9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xuXG5leHBvcnQgY29uc3QgQ1VTVE9NX1NXSVRDSF9DT05UUk9MX1ZBTFVFX0FDQ0VTU09SOiBhbnkgPSB7XG4gIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxuICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6IG5vLXVzZS1iZWZvcmUtZGVjbGFyZVxuICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBTd2l0Y2hDb21wb25lbnQpLFxuICBtdWx0aTogdHJ1ZVxufTtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbGN0LXN3aXRjaCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9zd2l0Y2guY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9zd2l0Y2guY29tcG9uZW50LmNzcyddLFxuICBwcm92aWRlcnM6IFtDVVNUT01fU1dJVENIX0NPTlRST0xfVkFMVUVfQUNDRVNTT1JdXG59KVxuZXhwb3J0IGNsYXNzIFN3aXRjaENvbXBvbmVudCBpbXBsZW1lbnRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBPbkluaXQsIEFmdGVyVmlld0luaXQge1xuXG4gIEBJbnB1dCgpIGNoZWNrZWQ6IGJvb2xlYW4gfCBzdHJpbmcgPSBmYWxzZTtcbiAgQElucHV0KCkgZGlzYWJsZWQ6IGJvb2xlYW4gfCBzdHJpbmcgPSBmYWxzZTtcbiAgQFZpZXdDaGlsZCgnY2hlY2tib3gnKSBjaGVja2JveDogRWxlbWVudFJlZiB8IHVuZGVmaW5lZDtcbiAgQE91dHB1dCgpIGVudGVyRW1pdHRlZCA9IG5ldyBFdmVudEVtaXR0ZXI8c3RyaW5nPigpXG5cbiAgcHVibGljIHByb3BhZ2F0ZUNoYW5nZSA9IChfOiBhbnkpID0+IHsgfTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlbmRlcmVyOiBSZW5kZXJlcjIpIHsgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICB9XG5cbiAgbmdBZnRlclZpZXdJbml0KCkge1xuICAgIGlmICgodGhpcy5jaGVja2VkID09PSAnJyB8fCB0aGlzLmNoZWNrZWQgPT09IHRydWUgfHwgdGhpcy5jaGVja2VkICE9PSAnZmFsc2UnKSAmJiB0aGlzLmNoZWNrZWQgIT09IGZhbHNlKSB7XG4gICAgICB0aGlzLnJlbmRlcmVyLnNldEF0dHJpYnV0ZSh0aGlzLmNoZWNrYm94Py5uYXRpdmVFbGVtZW50LCdjaGVja2VkJywgJ2NoZWNrZWQnKTtcbiAgICB9XG4gICAgaWYgKCh0aGlzLmRpc2FibGVkID09PSAnJyB8fCB0aGlzLmRpc2FibGVkID09PSB0cnVlIHx8IHRoaXMuZGlzYWJsZWQgIT09ICdmYWxzZScpICYmIHRoaXMuZGlzYWJsZWQgIT09IGZhbHNlKSB7XG4gICAgICB0aGlzLnJlbmRlcmVyLnNldEF0dHJpYnV0ZSh0aGlzLmNoZWNrYm94Py5uYXRpdmVFbGVtZW50LCdkaXNhYmxlZCcsICdkaXNhYmxlZCcpO1xuICAgIH1cbiAgfVxuXG4gIHRvZ2dsZSgpIHtcbiAgICBpZiAodGhpcy5jaGVja2JveD8ubmF0aXZlRWxlbWVudC5jaGVja2VkKSB7XG4gICAgICB0aGlzLnJlbmRlcmVyLnNldEF0dHJpYnV0ZSh0aGlzLmNoZWNrYm94Py5uYXRpdmVFbGVtZW50LCdjaGVja2VkJywgJ2NoZWNrZWQnKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5yZW5kZXJlci5yZW1vdmVBdHRyaWJ1dGUodGhpcy5jaGVja2JveD8ubmF0aXZlRWxlbWVudCwnY2hlY2tlZCcpO1xuICAgIH1cbiAgICB0aGlzLm9uS2V5VXBIYW5kbGVyKCk7XG4gIH1cblxuICB3cml0ZVZhbHVlKHZhbHVlOiBhbnkpOiB2b2lkIHtcbiAgICBjb25zb2xlLmxvZygndmFsdWUnLCB2YWx1ZSk7XG4gICAgaWYgKHR5cGVvZiB2YWx1ZSAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgIHRoaXMub25LZXlVcEhhbmRsZXIodmFsdWUpO1xuICAgIH1cbiAgfVxuXG4gIHJlZ2lzdGVyT25DaGFuZ2UoZm46IGFueSk6IHZvaWQge1xuICAgIHRoaXMucHJvcGFnYXRlQ2hhbmdlID0gZm47XG4gIH1cblxuICByZWdpc3Rlck9uVG91Y2hlZChmbjogYW55KTogdm9pZCB7XG4gICAgLy8gY29uc29sZS5sb2coJ3JlZyB0b3VjaCcsIGZuKVxuICB9XG5cbiAgb25LZXlVcEhhbmRsZXIoZXZlbnQ/OiBLZXlib2FyZEV2ZW50KSB7XG4gICAgdGhpcy5wcm9wYWdhdGVDaGFuZ2UodGhpcy5jaGVja2JveD8ubmF0aXZlRWxlbWVudC5jaGVja2VkKTtcbiAgfVxuXG5cbiAgZW50ZXJFbWl0KCkge1xuICAgIHRoaXMuZW50ZXJFbWl0dGVkLmVtaXQodGhpcy5jaGVja2JveD8ubmF0aXZlRWxlbWVudC5jaGVja2VkKTtcbiAgfVxuXG59XG4iLCI8bGFiZWwgY2xhc3M9XCJzd2l0Y2hcIiAoY2xpY2spPVwidG9nZ2xlKClcIj5cbiAgPGlucHV0IHR5cGU9XCJjaGVja2JveFwiICNjaGVja2JveCA+XG4gIDxzcGFuIGNsYXNzPVwic2xpZGVyIHJvdW5kXCI+PC9zcGFuPlxuPC9sYWJlbD5cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2xjdC1jb21wb25lbnRzL3NyYy9saWIvc3dpdGNoL3N3aXRjaC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9sY3QtY29tcG9uZW50cy9zcmMvbGliL3N3aXRjaC9zd2l0Y2guY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFNBQVMsRUFFVCxZQUFZLEVBQ1osS0FBSyxFQUVMLE1BQU0sRUFFUCxNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQXVCLGlCQUFpQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7O0FBWXZFLE1BQU0sT0FBTyxlQUFlO0lBUTFCO1FBTlMsWUFBTyxHQUFxQixLQUFLLENBQUM7UUFDbEMsYUFBUSxHQUFxQixLQUFLLENBQUM7UUFDbEMsaUJBQVksR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFBO1FBRTdDLG9CQUFlLEdBQUcsQ0FBQyxDQUFNLEVBQUUsRUFBRSxHQUFHLENBQUMsQ0FBQztJQUV6QixDQUFDO0lBRWpCLFFBQVE7SUFDUixDQUFDO0lBRUQsZUFBZTtRQUNiLElBQ0UsQ0FBQyxPQUFPLElBQUksQ0FBQyxPQUFPLEtBQUssUUFBUSxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxXQUFXLEVBQUUsS0FBSyxNQUFNLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxXQUFXLEVBQUUsS0FBSyxTQUFTLElBQUksSUFBSSxDQUFDLE9BQU8sS0FBSyxFQUFFLENBQUMsQ0FBQztZQUNoSixDQUFDLE9BQU8sSUFBSSxDQUFDLE9BQU8sS0FBSyxTQUFTLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxFQUNuRDtZQUNBLE9BQU8sQ0FBQyxHQUFHLENBQUMscUJBQXFCLENBQUMsQ0FBQztZQUNuQyxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQztTQUNyQjthQUFNO1lBQ0wsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7U0FDdEI7UUFDRCxJQUNFLENBQUMsT0FBTyxJQUFJLENBQUMsUUFBUSxLQUFLLFFBQVEsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxFQUFFLEtBQUssTUFBTSxJQUFJLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxFQUFFLEtBQUssVUFBVSxJQUFJLElBQUksQ0FBQyxRQUFRLEtBQUssRUFBRSxDQUFDLENBQUM7WUFDckosQ0FBQyxPQUFPLElBQUksQ0FBQyxRQUFRLEtBQUssU0FBUyxJQUFJLElBQUksQ0FBQyxRQUFRLENBQUMsRUFDckQ7WUFDQSxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztTQUN0QjthQUFNO1lBQ0wsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7U0FDdkI7SUFDSCxDQUFDO0lBRUQsTUFBTTtRQUNKLElBQUksQ0FBQyxPQUFPLEdBQUcsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDO1FBQzdCLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztJQUN4QixDQUFDO0lBRUQsVUFBVSxDQUFDLEtBQVU7UUFDbkIsSUFBSSxPQUFPLEtBQUssS0FBSyxXQUFXLEVBQUU7WUFDaEMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUM1QjtJQUNILENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxFQUFPO1FBQ3RCLElBQUksQ0FBQyxlQUFlLEdBQUcsRUFBRSxDQUFDO0lBQzVCLENBQUM7SUFFRCxpQkFBaUIsQ0FBQyxFQUFPO1FBQ3ZCLCtCQUErQjtJQUNqQyxDQUFDO0lBRUQsY0FBYyxDQUFDLEtBQStCO1FBQzVDLElBQUksT0FBTyxLQUFLLEtBQUssU0FBUyxFQUFFO1lBQzlCLElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO1NBQ3RCO1FBQ0QsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDckMsQ0FBQztJQUVELFNBQVM7UUFDUCxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBVSxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDaEQsQ0FBQzs7NEdBN0RVLGVBQWU7Z0dBQWYsZUFBZSxzSUFOZixDQUFDO1lBQ1YsT0FBTyxFQUFFLGlCQUFpQjtZQUMxQixXQUFXLEVBQUUsZUFBZTtZQUM1QixLQUFLLEVBQUUsSUFBSTtTQUNaLENBQUMsMEJDckJKLDhLQUlBOzJGRG1CYSxlQUFlO2tCQVYzQixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxZQUFZO29CQUN0QixXQUFXLEVBQUUseUJBQXlCO29CQUN0QyxTQUFTLEVBQUUsQ0FBQyx3QkFBd0IsQ0FBQztvQkFDckMsU0FBUyxFQUFFLENBQUM7NEJBQ1YsT0FBTyxFQUFFLGlCQUFpQjs0QkFDMUIsV0FBVyxpQkFBaUI7NEJBQzVCLEtBQUssRUFBRSxJQUFJO3lCQUNaLENBQUM7aUJBQ0g7MEVBR1UsT0FBTztzQkFBZixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0ksWUFBWTtzQkFBckIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFmdGVyVmlld0luaXQsXG4gIENvbXBvbmVudCxcbiAgRWxlbWVudFJlZixcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCxcbiAgT25Jbml0LFxuICBPdXRwdXQsXG4gIFZpZXdDaGlsZFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtDb250cm9sVmFsdWVBY2Nlc3NvciwgTkdfVkFMVUVfQUNDRVNTT1J9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdsY3Qtc3dpdGNoJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3N3aXRjaC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3N3aXRjaC5jb21wb25lbnQuY3NzJ10sXG4gIHByb3ZpZGVyczogW3tcbiAgICBwcm92aWRlOiBOR19WQUxVRV9BQ0NFU1NPUixcbiAgICB1c2VFeGlzdGluZzogU3dpdGNoQ29tcG9uZW50LFxuICAgIG11bHRpOiB0cnVlXG4gIH1dXG59KVxuZXhwb3J0IGNsYXNzIFN3aXRjaENvbXBvbmVudCBpbXBsZW1lbnRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBPbkluaXQsIEFmdGVyVmlld0luaXQge1xuXG4gIEBJbnB1dCgpIGNoZWNrZWQ6IGJvb2xlYW4gfCBzdHJpbmcgPSBmYWxzZTtcbiAgQElucHV0KCkgZGlzYWJsZWQ6IGJvb2xlYW4gfCBzdHJpbmcgPSBmYWxzZTtcbiAgQE91dHB1dCgpIGVudGVyRW1pdHRlZCA9IG5ldyBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4oKVxuXG4gIHB1YmxpYyBwcm9wYWdhdGVDaGFuZ2UgPSAoXzogYW55KSA9PiB7IH07XG5cbiAgY29uc3RydWN0b3IoKSB7IH1cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgfVxuXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpIHtcbiAgICBpZiAoXG4gICAgICAodHlwZW9mIHRoaXMuY2hlY2tlZCA9PT0gJ3N0cmluZycgJiYgKHRoaXMuY2hlY2tlZC50b0xvd2VyQ2FzZSgpID09PSAndHJ1ZScgfHwgdGhpcy5jaGVja2VkLnRvTG93ZXJDYXNlKCkgPT09ICdjaGVja2VkJyB8fCB0aGlzLmNoZWNrZWQgPT09ICcnKSkgfHxcbiAgICAgICh0eXBlb2YgdGhpcy5jaGVja2VkID09PSAnYm9vbGVhbicgJiYgdGhpcy5jaGVja2VkKVxuICAgICkge1xuICAgICAgY29uc29sZS5sb2coJ2VudHJhIGFsIHRydWUgY2hlY2snKTtcbiAgICAgIHRoaXMuY2hlY2tlZCA9IHRydWU7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuY2hlY2tlZCA9IGZhbHNlO1xuICAgIH1cbiAgICBpZiAoXG4gICAgICAodHlwZW9mIHRoaXMuZGlzYWJsZWQgPT09ICdzdHJpbmcnICYmICh0aGlzLmRpc2FibGVkLnRvTG93ZXJDYXNlKCkgPT09ICd0cnVlJyB8fCB0aGlzLmRpc2FibGVkLnRvTG93ZXJDYXNlKCkgPT09ICdkaXNhYmxlZCcgfHwgdGhpcy5kaXNhYmxlZCA9PT0gJycpKSB8fFxuICAgICAgKHR5cGVvZiB0aGlzLmRpc2FibGVkID09PSAnYm9vbGVhbicgJiYgdGhpcy5kaXNhYmxlZClcbiAgICApIHtcbiAgICAgIHRoaXMuZGlzYWJsZWQgPSB0cnVlO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLmRpc2FibGVkID0gZmFsc2U7XG4gICAgfVxuICB9XG5cbiAgdG9nZ2xlKCkge1xuICAgIHRoaXMuY2hlY2tlZCA9ICF0aGlzLmNoZWNrZWQ7XG4gICAgdGhpcy5vbktleVVwSGFuZGxlcigpO1xuICB9XG5cbiAgd3JpdGVWYWx1ZSh2YWx1ZTogYW55KTogdm9pZCB7XG4gICAgaWYgKHR5cGVvZiB2YWx1ZSAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgIHRoaXMub25LZXlVcEhhbmRsZXIodmFsdWUpO1xuICAgIH1cbiAgfVxuXG4gIHJlZ2lzdGVyT25DaGFuZ2UoZm46IGFueSk6IHZvaWQge1xuICAgIHRoaXMucHJvcGFnYXRlQ2hhbmdlID0gZm47XG4gIH1cblxuICByZWdpc3Rlck9uVG91Y2hlZChmbjogYW55KTogdm9pZCB7XG4gICAgLy8gY29uc29sZS5sb2coJ3JlZyB0b3VjaCcsIGZuKVxuICB9XG5cbiAgb25LZXlVcEhhbmRsZXIoZXZlbnQ/OiBLZXlib2FyZEV2ZW50IHwgYm9vbGVhbikge1xuICAgIGlmICh0eXBlb2YgZXZlbnQgPT09ICdib29sZWFuJykge1xuICAgICAgdGhpcy5jaGVja2VkID0gZXZlbnQ7XG4gICAgfVxuICAgIHRoaXMucHJvcGFnYXRlQ2hhbmdlKHRoaXMuY2hlY2tlZCk7XG4gIH1cblxuICBlbnRlckVtaXQoKSB7XG4gICAgdGhpcy5lbnRlckVtaXR0ZWQuZW1pdCg8Ym9vbGVhbj50aGlzLmNoZWNrZWQpO1xuICB9XG5cbn1cbiIsIjxsYWJlbCBjbGFzcz1cInN3aXRjaFwiPlxuICA8aW5wdXQgdHlwZT1cImNoZWNrYm94XCIgKGNsaWNrKT1cInRvZ2dsZSgpXCIgW2NoZWNrZWRdPVwiY2hlY2tlZFwiIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiPlxuICA8c3BhbiBjbGFzcz1cInNsaWRlciByb3VuZFwiPjwvc3Bhbj5cbjwvbGFiZWw+XG4iXX0=
import * as i0 from '@angular/core';
import { Injectable, Component, EventEmitter, Input, Output, ElementRef, ViewChild, forwardRef, NgModule } from '@angular/core';
import { Injectable, Component, EventEmitter, Input, Output, ElementRef, ViewChild, NgModule } from '@angular/core';
import * as i1 from '@angular/common';

@@ -252,8 +252,2 @@ import { CommonModule } from '@angular/common';

const CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR = {
provide: NG_VALUE_ACCESSOR,
// tslint:disable-next-line: no-use-before-declare
useExisting: forwardRef(() => InputTextComponent),
multi: true
};
class InputTextComponent {

@@ -277,16 +271,2 @@ constructor(render) {

}
writeValue(value) {
if (typeof value !== 'undefined') {
this.onKeyUpHandler(value);
}
}
registerOnChange(fn) {
this.propagateChange = fn;
}
registerOnTouched(fn) {
// console.log('reg touch', fn)
}
onKeyUpHandler(event) {
this.propagateChange(this.inputValue);
}
ngAfterViewInit() {

@@ -313,2 +293,22 @@ var _a, _b;

}
writeValue(value) {
if (typeof value !== 'undefined') {
this.onKeyUpHandler(value);
}
}
registerOnChange(fn) {
this.propagateChange = fn;
}
registerOnTouched(fn) {
// console.log('reg touch', fn)
}
onKeyUpHandler(event) {
if (!this.inputValue && typeof event === 'string') {
this.inputValue = event;
}
if (this.inputValue && event === null) {
this.inputValue = '';
}
this.propagateChange(this.inputValue);
}
click() {

@@ -331,3 +331,7 @@ if (!this.disabled) {

InputTextComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: InputTextComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
InputTextComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.5", type: InputTextComponent, selector: "lct-input-text", inputs: { disabled: "disabled", icon: "icon", iconPosition: "iconPosition", pdaAutoEnter: "pdaAutoEnter", placeholder: "placeholder", showIcon: "showIcon", title: "title", type: "type" }, outputs: { enterEmitted: "enterEmitted", iconClick: "iconClick", inputClick: "inputClick" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], viewQueries: [{ propertyName: "inputScan", first: true, predicate: ["inputScan"], descendants: true }, { propertyName: "iconDiv", first: true, predicate: ["iconDiv"], descendants: true }], ngImport: i0, template: "<div>\n <div class=\"title\">\n {{title}}\n </div>\n <div class=\"input-with-icon iconLeft\">\n <input [type]=\"type\"\n class=\"form-control\"\n #inputScan\n [disabled]=\"disabled\"\n [placeholder]=\"placeholder\"\n [(ngModel)]=\"inputValue\"\n (keydown.enter)=\"enterEmit()\"\n (keydown.tab)=\"enterEmit()\"\n (keyup)=\"onKeyUpHandler($event)\"\n (click)=\"clickInput()\"\n (ngModelChange)=\"lpnUpdate.next(inputScan.value);\"\n >\n <div class=\"icon\" #iconDiv *ngIf=\"showIcon\">\n <img [src]=\"icon\" [ngStyle]=\"{'cursor': disabled ? 'not-allowed' : 'pointer'}\" alt=\"\" (click)=\"click()\">\n </div>\n </div>\n</div>\n", styles: ["*{font-family:\"Barlow\",\"Open Sans\",\"Helvetica Neue\",\"Segoe UI\",\"Calibri\",\"Arial\",sans-serif}.title{color:#3c4149;font-size:12px;letter-spacing:0;line-height:15px;margin-left:2px;margin-bottom:5px}.input-with-icon{box-sizing:border-box;position:relative;height:40px}@media (max-width: 375px){.input-with-icon{height:50px}}.input-with-icon .form-control{height:100%;width:100%;border:1px solid #C2C2C2;border-radius:5px;background-color:#e0e5ee;box-sizing:border-box;color:#3c4149;font-size:14px;letter-spacing:0;line-height:17px;padding:12px 20px 12px 15px}.input-with-icon .form-control.iconLeft{padding:12px 20px 12px 60px}.input-with-icon .form-control:disabled{cursor:not-allowed;background-color:#c8ccd4}.input-with-icon .icon{position:absolute;right:1%;top:.01rem;width:2.6rem;height:2.6rem;border-radius:.3rem;display:flex;justify-content:center;align-items:center;box-sizing:border-box}.input-with-icon .icon :hover{cursor:pointer}@media (max-width: 375px){.input-with-icon .icon{top:.3rem}}.input-with-icon .icon.iconLeft{left:15px}\n"], directives: [{ type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
InputTextComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.5", type: InputTextComponent, selector: "lct-input-text", inputs: { disabled: "disabled", icon: "icon", iconPosition: "iconPosition", pdaAutoEnter: "pdaAutoEnter", placeholder: "placeholder", showIcon: "showIcon", title: "title", type: "type" }, outputs: { enterEmitted: "enterEmitted", iconClick: "iconClick", inputClick: "inputClick" }, providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: InputTextComponent,
multi: true
}], viewQueries: [{ propertyName: "inputScan", first: true, predicate: ["inputScan"], descendants: true }, { propertyName: "iconDiv", first: true, predicate: ["iconDiv"], descendants: true }], ngImport: i0, template: "<div>\n <div class=\"title\">\n {{title}}\n </div>\n <div class=\"input-with-icon iconLeft\">\n <input [type]=\"type\"\n class=\"form-control\"\n #inputScan\n [disabled]=\"disabled\"\n [placeholder]=\"placeholder\"\n [(ngModel)]=\"inputValue\"\n (keydown.enter)=\"enterEmit()\"\n (keydown.tab)=\"enterEmit()\"\n (keyup)=\"onKeyUpHandler($event)\"\n (click)=\"clickInput()\"\n (ngModelChange)=\"lpnUpdate.next(inputScan.value);\"\n >\n <div class=\"icon\" #iconDiv *ngIf=\"showIcon\">\n <img [src]=\"icon\" [ngStyle]=\"{'cursor': disabled ? 'not-allowed' : 'pointer'}\" alt=\"\" (click)=\"click()\">\n </div>\n </div>\n</div>\n", styles: ["*{font-family:\"Barlow\",\"Open Sans\",\"Helvetica Neue\",\"Segoe UI\",\"Calibri\",\"Arial\",sans-serif}.title{color:#3c4149;font-size:12px;letter-spacing:0;line-height:15px;margin-left:2px;margin-bottom:5px}.input-with-icon{box-sizing:border-box;position:relative;height:40px}@media (max-width: 375px){.input-with-icon{height:50px}}.input-with-icon .form-control{height:100%;width:100%;border:1px solid #C2C2C2;border-radius:5px;background-color:#e0e5ee;box-sizing:border-box;color:#3c4149;font-size:14px;letter-spacing:0;line-height:17px;padding:12px 20px 12px 15px}.input-with-icon .form-control.iconLeft{padding:12px 20px 12px 60px}.input-with-icon .form-control:disabled{cursor:not-allowed;background-color:#c8ccd4}.input-with-icon .icon{position:absolute;right:1%;top:.01rem;width:2.6rem;height:2.6rem;border-radius:.3rem;display:flex;justify-content:center;align-items:center;box-sizing:border-box}.input-with-icon .icon :hover{cursor:pointer}@media (max-width: 375px){.input-with-icon .icon{top:.3rem}}.input-with-icon .icon.iconLeft{left:15px}\n"], directives: [{ type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: InputTextComponent, decorators: [{

@@ -339,3 +343,7 @@ type: Component,

styleUrls: ['./input-text.component.scss'],
providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR]
providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: InputTextComponent,
multi: true
}]
}]

@@ -395,11 +403,4 @@ }], ctorParameters: function () { return [{ type: i0.Renderer2 }]; }, propDecorators: { disabled: [{

const CUSTOM_SWITCH_CONTROL_VALUE_ACCESSOR = {
provide: NG_VALUE_ACCESSOR,
// tslint:disable-next-line: no-use-before-declare
useExisting: forwardRef(() => SwitchComponent),
multi: true
};
class SwitchComponent {
constructor(renderer) {
this.renderer = renderer;
constructor() {
this.checked = false;

@@ -413,22 +414,23 @@ this.disabled = false;

ngAfterViewInit() {
var _a, _b;
if ((this.checked === '' || this.checked === true || this.checked !== 'false') && this.checked !== false) {
this.renderer.setAttribute((_a = this.checkbox) === null || _a === void 0 ? void 0 : _a.nativeElement, 'checked', 'checked');
if ((typeof this.checked === 'string' && (this.checked.toLowerCase() === 'true' || this.checked.toLowerCase() === 'checked' || this.checked === '')) ||
(typeof this.checked === 'boolean' && this.checked)) {
console.log('entra al true check');
this.checked = true;
}
if ((this.disabled === '' || this.disabled === true || this.disabled !== 'false') && this.disabled !== false) {
this.renderer.setAttribute((_b = this.checkbox) === null || _b === void 0 ? void 0 : _b.nativeElement, 'disabled', 'disabled');
else {
this.checked = false;
}
}
toggle() {
var _a, _b, _c;
if ((_a = this.checkbox) === null || _a === void 0 ? void 0 : _a.nativeElement.checked) {
this.renderer.setAttribute((_b = this.checkbox) === null || _b === void 0 ? void 0 : _b.nativeElement, 'checked', 'checked');
if ((typeof this.disabled === 'string' && (this.disabled.toLowerCase() === 'true' || this.disabled.toLowerCase() === 'disabled' || this.disabled === '')) ||
(typeof this.disabled === 'boolean' && this.disabled)) {
this.disabled = true;
}
else {
this.renderer.removeAttribute((_c = this.checkbox) === null || _c === void 0 ? void 0 : _c.nativeElement, 'checked');
this.disabled = false;
}
}
toggle() {
this.checked = !this.checked;
this.onKeyUpHandler();
}
writeValue(value) {
console.log('value', value);
if (typeof value !== 'undefined') {

@@ -445,12 +447,17 @@ this.onKeyUpHandler(value);

onKeyUpHandler(event) {
var _a;
this.propagateChange((_a = this.checkbox) === null || _a === void 0 ? void 0 : _a.nativeElement.checked);
if (typeof event === 'boolean') {
this.checked = event;
}
this.propagateChange(this.checked);
}
enterEmit() {
var _a;
this.enterEmitted.emit((_a = this.checkbox) === null || _a === void 0 ? void 0 : _a.nativeElement.checked);
this.enterEmitted.emit(this.checked);
}
}
SwitchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: SwitchComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
SwitchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.5", type: SwitchComponent, selector: "lct-switch", inputs: { checked: "checked", disabled: "disabled" }, outputs: { enterEmitted: "enterEmitted" }, providers: [CUSTOM_SWITCH_CONTROL_VALUE_ACCESSOR], viewQueries: [{ propertyName: "checkbox", first: true, predicate: ["checkbox"], descendants: true }], ngImport: i0, template: "<label class=\"switch\" (click)=\"toggle()\">\n <input type=\"checkbox\" #checkbox >\n <span class=\"slider round\"></span>\n</label>\n", styles: [".switch{position:relative;display:inline-block;width:38px;height:20px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;border:1px solid #C8CCD4;transition:.4s}.slider:before{position:absolute;content:\"\";left:0%;right:50%;top:0%;bottom:0%;background-color:#e0e5ee;box-shadow:0 2px 2px #12245e26;transition:.4s}.slider:after{border:1px solid #C8CCD4;box-sizing:border-box}input:checked+.slider{background-color:#2a5aed;border:1px solid #2A5AED;box-sizing:border-box}input:disabled+.slider{background-color:#c8ccd4;cursor:not-allowed}input:checked+.slider:before{transform:translate(17px)}.slider.round{border-radius:100px}.slider.round:before{border-radius:50%}\n"] });
SwitchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: SwitchComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
SwitchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.5", type: SwitchComponent, selector: "lct-switch", inputs: { checked: "checked", disabled: "disabled" }, outputs: { enterEmitted: "enterEmitted" }, providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: SwitchComponent,
multi: true
}], ngImport: i0, template: "<label class=\"switch\">\n <input type=\"checkbox\" (click)=\"toggle()\" [checked]=\"checked\" [disabled]=\"disabled\">\n <span class=\"slider round\"></span>\n</label>\n", styles: [".switch{position:relative;display:inline-block;width:38px;height:20px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;border:1px solid #C8CCD4;transition:.4s}.slider:before{position:absolute;content:\"\";left:0%;right:50%;top:0%;bottom:0%;background-color:#e0e5ee;box-shadow:0 2px 2px #12245e26;transition:.4s}.slider:after{border:1px solid #C8CCD4;box-sizing:border-box}input:checked+.slider{background-color:#2a5aed;border:1px solid #2A5AED;box-sizing:border-box}input:disabled+.slider{background-color:#c8ccd4;cursor:not-allowed}input:checked+.slider:before{transform:translate(17px)}.slider.round{border-radius:100px}.slider.round:before{border-radius:50%}\n"] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: SwitchComponent, decorators: [{

@@ -462,11 +469,12 @@ type: Component,

styleUrls: ['./switch.component.css'],
providers: [CUSTOM_SWITCH_CONTROL_VALUE_ACCESSOR]
providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: SwitchComponent,
multi: true
}]
}]
}], ctorParameters: function () { return [{ type: i0.Renderer2 }]; }, propDecorators: { checked: [{
}], ctorParameters: function () { return []; }, propDecorators: { checked: [{
type: Input
}], disabled: [{
type: Input
}], checkbox: [{
type: ViewChild,
args: ['checkbox']
}], enterEmitted: [{

@@ -533,3 +541,3 @@ type: Output

export { ButtonComponent, CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR, CUSTOM_SWITCH_CONTROL_VALUE_ACCESSOR, InputTextComponent, LctComponentsComponent, LctComponentsModule, LctComponentsService, LoadingComponent, SelectComponent, SelectMultipleComponent, SwitchComponent };
export { ButtonComponent, InputTextComponent, LctComponentsComponent, LctComponentsModule, LctComponentsService, LoadingComponent, SelectComponent, SelectMultipleComponent, SwitchComponent };
//# sourceMappingURL=lct-components.js.map

@@ -5,3 +5,2 @@ import { AfterViewInit, ElementRef, EventEmitter, OnInit, Renderer2 } from '@angular/core';

import * as i0 from "@angular/core";
export declare const CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any;
export declare class InputTextComponent implements ControlValueAccessor, OnInit, AfterViewInit {

@@ -26,8 +25,8 @@ private render;

constructor(render: Renderer2);
ngAfterViewInit(): void;
ngOnInit(): void;
writeValue(value: any): void;
registerOnChange(fn: any): void;
registerOnTouched(fn: any): void;
onKeyUpHandler(event?: KeyboardEvent): void;
ngAfterViewInit(): void;
ngOnInit(): void;
onKeyUpHandler(event?: KeyboardEvent | string): void;
click(): void;

@@ -34,0 +33,0 @@ clickInput(): void;

@@ -1,13 +0,10 @@

import { AfterViewInit, ElementRef, EventEmitter, OnInit, Renderer2 } from '@angular/core';
import { AfterViewInit, EventEmitter, OnInit } from '@angular/core';
import { ControlValueAccessor } from "@angular/forms";
import * as i0 from "@angular/core";
export declare const CUSTOM_SWITCH_CONTROL_VALUE_ACCESSOR: any;
export declare class SwitchComponent implements ControlValueAccessor, OnInit, AfterViewInit {
private renderer;
checked: boolean | string;
disabled: boolean | string;
checkbox: ElementRef | undefined;
enterEmitted: EventEmitter<string>;
enterEmitted: EventEmitter<boolean>;
propagateChange: (_: any) => void;
constructor(renderer: Renderer2);
constructor();
ngOnInit(): void;

@@ -19,3 +16,3 @@ ngAfterViewInit(): void;

registerOnTouched(fn: any): void;
onKeyUpHandler(event?: KeyboardEvent): void;
onKeyUpHandler(event?: KeyboardEvent | boolean): void;
enterEmit(): void;

@@ -22,0 +19,0 @@ static ɵfac: i0.ɵɵFactoryDeclaration<SwitchComponent, never>;

{
"name": "lct-components",
"version": "0.1.0",
"version": "0.1.1",
"description": "LCT basic components",

@@ -5,0 +5,0 @@ "keywords": [

@@ -23,2 +23,3 @@

[options]="['Select one', 'One Option']]"
>

@@ -34,9 +35,3 @@ </lct-select>

</lct-select-multiple>
```
#### Switch
```
<lct-switch
[(ngModel)]="yourVariable"
></lct-switch>
```
```
#### Input Text

@@ -96,4 +91,10 @@ ```

| Method | Description | Example |
|-- | -- | -- |
| show(): void | Show loading overlay | this.lctLoading.show() |
| dismiss(): void | Hide loading overlay | this.lctLoading.dismiss() |
|-- | -- | --|
| show(): void | show overlay | this.lctLoading.show() |
| dismiss(): void | hide overlay | this.lctLoading.dismiss()|
>Version 0.1.1
>
>[(ngModel)] only can be used for:
> > lct-input-text
> > lct-switch

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc