@gipisistemas/ng-core 1.1.3 → 1.1.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (86) hide show
  1. package/assets/styles/colors.scss +5 -1
  2. package/bundles/gipisistemas-ng-core.umd.js +8379 -7856
  3. package/bundles/gipisistemas-ng-core.umd.js.map +1 -1
  4. package/bundles/gipisistemas-ng-core.umd.min.js +10 -9
  5. package/bundles/gipisistemas-ng-core.umd.min.js.map +1 -1
  6. package/core/gipi-components/models/sort.model.d.ts +3 -3
  7. package/core/utils/array.util.d.ts +2 -2
  8. package/core/utils/object.util.d.ts +3 -5
  9. package/esm2015/core/gipi-components/models/sort.model.js +1 -1
  10. package/esm2015/core/gipi-components/services/abstract-crud.service.js +18 -24
  11. package/esm2015/core/utils/array.util.js +4 -2
  12. package/esm2015/core/utils/object.util.js +5 -9
  13. package/esm2015/gipi-components.js +10 -1
  14. package/esm2015/shared/components/input/input.component.js +46 -23
  15. package/esm2015/shared/components/table/table.component.js +1 -1
  16. package/esm2015/shared/gipi-components/abstract-form/abstract-form.component.js +1 -1
  17. package/esm2015/shared/gipi-components/button/button.component.js +2 -2
  18. package/esm2015/shared/gipi-components/card/card.component.js +113 -0
  19. package/esm2015/shared/gipi-components/datepicker/datepicker/datepicker.component.js +8 -3
  20. package/esm2015/shared/gipi-components/empty-state/empty-state.component.js +30 -0
  21. package/esm2015/shared/gipi-components/layout-grid/col.directive.js +4 -4
  22. package/esm2015/shared/gipi-components/month-year-picker/month-year-picker.component.js +2 -2
  23. package/esm2015/shared/gipi-components/notification/notification.component.js +8 -3
  24. package/esm2015/shared/gipi-components/sidebar/sidenav/sidenav.component.js +35 -3
  25. package/esm2015/shared/gipi-components/slide-toggle/slide-toggle.component.js +113 -0
  26. package/esm2015/shared/gipi-components/tabs/shared/dynamic-tab.directive.js +18 -0
  27. package/esm2015/shared/gipi-components/tabs/shared/tab.model.js +8 -0
  28. package/esm2015/shared/gipi-components/tabs/tab/tab.component.js +66 -0
  29. package/esm2015/shared/gipi-components/tabs/tab-group/tab-group.component.js +123 -0
  30. package/esm2015/shared/gipi-components/textarea/textarea.component.js +298 -0
  31. package/esm2015/shared/shared.module.js +20 -16
  32. package/esm2015/shared.js +1 -5
  33. package/esm5/core/gipi-components/models/sort.model.js +1 -1
  34. package/esm5/core/gipi-components/services/abstract-crud.service.js +18 -24
  35. package/esm5/core/utils/array.util.js +4 -3
  36. package/esm5/core/utils/object.util.js +5 -9
  37. package/esm5/gipi-components.js +10 -1
  38. package/esm5/shared/components/input/input.component.js +46 -23
  39. package/esm5/shared/components/table/table.component.js +1 -1
  40. package/esm5/shared/gipi-components/abstract-form/abstract-form.component.js +1 -1
  41. package/esm5/shared/gipi-components/button/button.component.js +2 -2
  42. package/esm5/shared/gipi-components/card/card.component.js +135 -0
  43. package/esm5/shared/gipi-components/datepicker/datepicker/datepicker.component.js +8 -3
  44. package/esm5/shared/gipi-components/empty-state/empty-state.component.js +33 -0
  45. package/esm5/shared/gipi-components/layout-grid/col.directive.js +4 -4
  46. package/esm5/shared/gipi-components/month-year-picker/month-year-picker.component.js +2 -2
  47. package/esm5/shared/gipi-components/notification/notification.component.js +8 -3
  48. package/esm5/shared/gipi-components/sidebar/sidenav/sidenav.component.js +35 -3
  49. package/esm5/shared/gipi-components/slide-toggle/slide-toggle.component.js +127 -0
  50. package/esm5/shared/gipi-components/tabs/shared/dynamic-tab.directive.js +19 -0
  51. package/esm5/shared/gipi-components/tabs/shared/tab.model.js +10 -0
  52. package/esm5/shared/gipi-components/tabs/tab/tab.component.js +67 -0
  53. package/esm5/shared/gipi-components/tabs/tab-group/tab-group.component.js +131 -0
  54. package/esm5/shared/gipi-components/textarea/textarea.component.js +352 -0
  55. package/esm5/shared/shared.module.js +20 -16
  56. package/esm5/shared.js +1 -5
  57. package/fesm2015/gipisistemas-ng-core.js +1741 -1303
  58. package/fesm2015/gipisistemas-ng-core.js.map +1 -1
  59. package/fesm5/gipisistemas-ng-core.js +8369 -7851
  60. package/fesm5/gipisistemas-ng-core.js.map +1 -1
  61. package/gipi-components.d.ts +8 -0
  62. package/gipisistemas-ng-core.metadata.json +1 -1
  63. package/package.json +1 -2
  64. package/shared/components/input/input.component.d.ts +13 -11
  65. package/shared/components/table/table.component.d.ts +3 -3
  66. package/shared/gipi-components/card/card.component.d.ts +23 -0
  67. package/shared/gipi-components/empty-state/empty-state.component.d.ts +5 -0
  68. package/shared/gipi-components/notification/notification.component.d.ts +1 -0
  69. package/shared/gipi-components/sidebar/sidenav/sidenav.component.d.ts +7 -0
  70. package/shared/gipi-components/slide-toggle/slide-toggle.component.d.ts +27 -0
  71. package/shared/{directives → gipi-components/tabs/shared}/dynamic-tab.directive.d.ts +1 -1
  72. package/shared/gipi-components/tabs/shared/tab.model.d.ts +12 -0
  73. package/shared/{components → gipi-components/tabs}/tab/tab.component.d.ts +4 -2
  74. package/shared/gipi-components/tabs/tab-group/tab-group.component.d.ts +22 -0
  75. package/shared/gipi-components/textarea/textarea.component.d.ts +68 -0
  76. package/shared.d.ts +0 -4
  77. package/esm2015/shared/components/select-button/select-button.component.js +0 -181
  78. package/esm2015/shared/components/tab/tab.component.js +0 -57
  79. package/esm2015/shared/components/tab-group/tab-group.component.js +0 -117
  80. package/esm2015/shared/directives/dynamic-tab.directive.js +0 -18
  81. package/esm5/shared/components/select-button/select-button.component.js +0 -195
  82. package/esm5/shared/components/tab/tab.component.js +0 -58
  83. package/esm5/shared/components/tab-group/tab-group.component.js +0 -125
  84. package/esm5/shared/directives/dynamic-tab.directive.js +0 -19
  85. package/shared/components/select-button/select-button.component.d.ts +0 -35
  86. package/shared/components/tab-group/tab-group.component.d.ts +0 -22
@@ -0,0 +1,131 @@
1
+ import { __decorate, __metadata, __read, __spread } from "tslib";
2
+ import { AfterContentInit, Component, ComponentFactory, ComponentFactoryResolver, ComponentRef, ContentChildren, ElementRef, OnInit, QueryList, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';
3
+ import { GIPIDynamicTabDirective } from '../shared/dynamic-tab.directive';
4
+ import { TabModel } from '../shared/tab.model';
5
+ import { GIPITabComponent } from '../tab/tab.component';
6
+ var GIPITabGroupComponent = /** @class */ (function () {
7
+ function GIPITabGroupComponent(elementRef, _componentFactoryResolver) {
8
+ this.elementRef = elementRef;
9
+ this._componentFactoryResolver = _componentFactoryResolver;
10
+ this.dynamicTabs = [];
11
+ }
12
+ GIPITabGroupComponent.prototype.ngOnInit = function () { };
13
+ GIPITabGroupComponent.prototype.ngAfterContentInit = function () {
14
+ var activeTabs = this.tabQueryList.filter(function (tab) { return tab.active; });
15
+ if (activeTabs.length === 0 && this.tabQueryList.length > 0) {
16
+ this.selectTab(this.tabQueryList.first);
17
+ }
18
+ };
19
+ GIPITabGroupComponent.prototype.openTab = function (label, template, data, closeable, disabled, action) {
20
+ if (closeable === void 0) { closeable = false; }
21
+ if (disabled === void 0) { disabled = false; }
22
+ var tab = new TabModel();
23
+ tab.label = label;
24
+ tab.template = template;
25
+ tab.data = data;
26
+ tab.closeable = closeable;
27
+ tab.disabled = disabled;
28
+ tab.action = action;
29
+ this._openTabs(Array(tab));
30
+ };
31
+ GIPITabGroupComponent.prototype._openTabs = function (tabList) {
32
+ var _a;
33
+ var _this = this;
34
+ var tabsComponent = tabList.map(function (tab) { return _this._getTabComponent(tab.label, tab.template, tab.data, tab.closeable, tab.disabled, tab.action); });
35
+ (_a = this.dynamicTabs).push.apply(_a, __spread(tabsComponent));
36
+ this.selectTab(this.dynamicTabs[0]);
37
+ };
38
+ GIPITabGroupComponent.prototype._getTabComponent = function (label, template, data, closeable, disabled, action) {
39
+ if (closeable === void 0) { closeable = false; }
40
+ if (disabled === void 0) { disabled = false; }
41
+ var componentFactory = this._componentFactoryResolver.resolveComponentFactory(GIPITabComponent);
42
+ var componentRef = this.dynamicTabPlaceholder.viewContainer.createComponent(componentFactory);
43
+ var instance = componentRef.instance;
44
+ instance.label = label;
45
+ instance.template = template;
46
+ instance.data = data;
47
+ instance.closeable = closeable;
48
+ instance.disabled = disabled;
49
+ instance.action = action;
50
+ return componentRef.instance;
51
+ };
52
+ GIPITabGroupComponent.prototype.selectTab = function (tab) {
53
+ this.tabQueryList.toArray().forEach(function (t) { return (t.active = false); });
54
+ this.dynamicTabs.forEach(function (t) { return (t.active = false); });
55
+ tab.active = true;
56
+ tab.selectionChange.emit();
57
+ if (tab.action) {
58
+ tab.action(tab.data);
59
+ }
60
+ };
61
+ GIPITabGroupComponent.prototype.closeTab = function (tab) {
62
+ var index = this.dynamicTabs.indexOf(tab);
63
+ this.dynamicTabs.splice(index, 1);
64
+ var viewContainerRef = this.dynamicTabPlaceholder.viewContainer;
65
+ viewContainerRef.remove(index);
66
+ if (this.tabQueryList.length > 0) {
67
+ this.selectTab(this.tabQueryList.first);
68
+ }
69
+ };
70
+ GIPITabGroupComponent.prototype.closeActiveTab = function () {
71
+ var activeTabs = this.dynamicTabs.filter(function (tab) { return tab.active; });
72
+ if (activeTabs.length > 0) {
73
+ this.closeTab(activeTabs[0]);
74
+ }
75
+ };
76
+ GIPITabGroupComponent.prototype.closeAllTabs = function () {
77
+ var _this = this;
78
+ var tabs = Object.assign([], this.dynamicTabs);
79
+ if (tabs.length > 0) {
80
+ tabs.forEach(function (tab) { return _this.closeTab(tab); });
81
+ }
82
+ };
83
+ GIPITabGroupComponent.prototype.nextTab = function () {
84
+ var currentTab = this.tabQueryList.toArray().find(function (tab) { return tab.active; });
85
+ var nextTab = this.tabQueryList.toArray()[this.tabQueryList.toArray().indexOf(currentTab) + 1];
86
+ if (nextTab != null) {
87
+ this.tabQueryList.toArray().forEach(function (t) { return (t.active = false); });
88
+ this.dynamicTabs.forEach(function (t) { return (t.active = false); });
89
+ nextTab.active = true;
90
+ nextTab.selectionChange.emit();
91
+ }
92
+ };
93
+ GIPITabGroupComponent.prototype.previousTab = function () {
94
+ var currentTab = this.tabQueryList.toArray().find(function (tab) { return tab.active; });
95
+ var previousTab = this.tabQueryList.toArray()[this.tabQueryList.toArray().indexOf(currentTab) - 1];
96
+ if (previousTab != null) {
97
+ this.tabQueryList.toArray().forEach(function (t) { return (t.active = false); });
98
+ this.dynamicTabs.forEach(function (t) { return (t.active = false); });
99
+ previousTab.active = true;
100
+ previousTab.selectionChange.emit();
101
+ }
102
+ };
103
+ GIPITabGroupComponent.ctorParameters = function () { return [
104
+ { type: ElementRef },
105
+ { type: ComponentFactoryResolver }
106
+ ]; };
107
+ __decorate([
108
+ ContentChildren(GIPITabComponent),
109
+ __metadata("design:type", QueryList)
110
+ ], GIPITabGroupComponent.prototype, "tabQueryList", void 0);
111
+ __decorate([
112
+ ViewChild(GIPIDynamicTabDirective, { static: false }),
113
+ __metadata("design:type", GIPIDynamicTabDirective)
114
+ ], GIPITabGroupComponent.prototype, "dynamicTabPlaceholder", void 0);
115
+ GIPITabGroupComponent = __decorate([
116
+ Component({
117
+ selector: 'gipi-tab-group',
118
+ exportAs: 'gipiTabGroup',
119
+ template: "<nav mat-tab-nav-bar>\n <a mat-tab-link\n *ngFor=\"let tab of tabQueryList\"\n (click)=\"selectTab(tab)\"\n [class.active]=\"tab.active\"\n [disabled]=\"tab.disabled\">\n <mat-icon *ngIf=\"tab.icon || tab.svgIcon\"\n [svgIcon]=\"tab.svgIcon ? tab.svgIcon : ''\">\n {{ !tab.svgIcon && tab.icon ? tab.icon : '' }}\n </mat-icon>\n\n {{ tab.label }}\n </a>\n\n <a mat-tab-link\n *ngFor=\"let tab of dynamicTabs\"\n (click)=\"selectTab(tab)\"\n [class.active]=\"tab.active\"\n [disabled]=\"tab.disabled\">\n <mat-icon *ngIf=\"tab.icon || tab.svgIcon\"\n [svgIcon]=\"tab.svgIcon ? tab.svgIcon : ''\">\n {{ !tab.svgIcon && tab.icon ? tab.icon : '' }}\n </mat-icon>\n\n {{ tab.label }}\n </a>\n</nav>\n\n<ng-content> </ng-content>\n<ng-template dynamicTab\n #container>\n</ng-template>",
120
+ host: {
121
+ 'class': 'gipi-tab-group',
122
+ },
123
+ styles: [":host{display:block;flex:1;width:100%;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1)}:host ::ng-deep .mat-tab-nav-bar{background:#f5f5f6;border:none;border-radius:.4rem;padding:.4rem;box-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}:host ::ng-deep .mat-tab-links{display:flex;gap:1rem}:host ::ng-deep .mat-tab-link{height:auto!important;padding:1rem!important;opacity:1!important;border:none!important;border-radius:4px!important;transition:.2s!important;color:#595959!important;gap:1rem}:host ::ng-deep .mat-tab-link>mat-icon{width:2rem!important;height:2rem!important;font-size:2rem!important;color:#595959!important}:host ::ng-deep .mat-tab-link>mat-icon svg,:host ::ng-deep .mat-tab-link>mat-icon svg g path,:host ::ng-deep .mat-tab-link>mat-icon svg path{color:#595959!important;fill:#595959!important}:host ::ng-deep .mat-tab-link:not(.active):hover{background:#e0e1e2!important}:host ::ng-deep .mat-tab-link.active{background:#e0313e!important;color:#fff!important}:host ::ng-deep .mat-tab-link.active>mat-icon{color:#fff!important}:host ::ng-deep .mat-tab-link.active>mat-icon svg,:host ::ng-deep .mat-tab-link.active>mat-icon svg g path,:host ::ng-deep .mat-tab-link.active>mat-icon svg path{color:#fff!important;fill:#fff!important}:host ::ng-deep .mat-tab-link:disabled,:host ::ng-deep .mat-tab-link:disabled>mat-icon{color:#9a9da2!important;fill:#9a9da2!important}:host ::ng-deep .mat-tab-link:disabled svg,:host ::ng-deep .mat-tab-link:disabled svg g path,:host ::ng-deep .mat-tab-link:disabled svg path,:host ::ng-deep .mat-tab-link:disabled>mat-icon svg,:host ::ng-deep .mat-tab-link:disabled>mat-icon svg g path,:host ::ng-deep .mat-tab-link:disabled>mat-icon svg path{color:#9a9da2!important;fill:#9a9da2!important}:host ::ng-deep .mat-ink-bar{display:none!important}"]
124
+ }),
125
+ __metadata("design:paramtypes", [ElementRef,
126
+ ComponentFactoryResolver])
127
+ ], GIPITabGroupComponent);
128
+ return GIPITabGroupComponent;
129
+ }());
130
+ export { GIPITabGroupComponent };
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-group.component.js","sourceRoot":"ng://@gipisistemas/ng-core/","sources":["shared/gipi-components/tabs/tab-group/tab-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, Component, ComponentFactory, ComponentFactoryResolver, ComponentRef, ContentChildren, ElementRef, OnInit, QueryList, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\n\nimport { GIPIDynamicTabDirective } from '../shared/dynamic-tab.directive';\nimport { TabModel } from '../shared/tab.model';\nimport { GIPITabComponent } from '../tab/tab.component';\n\n@Component({\n    selector: 'gipi-tab-group',\n    exportAs: 'gipiTabGroup',\n    templateUrl: './tab-group.component.html',\n    styleUrls: ['./tab-group.component.scss'],\n    host: {\n        'class': 'gipi-tab-group',\n    },\n})\nexport class GIPITabGroupComponent implements AfterContentInit, OnInit {\n\n    @ContentChildren(GIPITabComponent) tabQueryList: QueryList<GIPITabComponent>;\n    @ViewChild(GIPIDynamicTabDirective, { static: false }) dynamicTabPlaceholder: GIPIDynamicTabDirective;\n\n    public dynamicTabs: GIPITabComponent[] = [];\n\n    constructor(\n        public elementRef: ElementRef,\n        private _componentFactoryResolver: ComponentFactoryResolver\n    ) { }\n\n    ngOnInit(): void { }\n\n    ngAfterContentInit() {\n        const activeTabs: GIPITabComponent[] = this.tabQueryList.filter(tab => tab.active);\n        if (activeTabs.length === 0 && this.tabQueryList.length > 0) {\n            this.selectTab(this.tabQueryList.first);\n        }\n    }\n\n    public openTab(label: string, template?: TemplateRef<any>, data?: any, closeable: boolean = false, disabled: boolean = false, action?: (obj: any) => void): void {\n        const tab: TabModel = new TabModel();\n        tab.label = label;\n        tab.template = template;\n        tab.data = data;\n        tab.closeable = closeable;\n        tab.disabled = disabled;\n        tab.action = action;\n        this._openTabs(Array(tab));\n    }\n\n    private _openTabs(tabList: TabModel[]): void {\n        const tabsComponent: GIPITabComponent[] = tabList.map(tab => this._getTabComponent(tab.label, tab.template, tab.data, tab.closeable, tab.disabled, tab.action));\n        this.dynamicTabs.push(...tabsComponent);\n        this.selectTab(this.dynamicTabs[0]);\n    }\n\n    private _getTabComponent(label: string, template?: TemplateRef<any>, data?: any, closeable: boolean = false, disabled: boolean = false, action?: (obj: any) => void): GIPITabComponent {\n        const componentFactory: ComponentFactory<GIPITabComponent> = this._componentFactoryResolver.resolveComponentFactory(GIPITabComponent);\n        const componentRef: ComponentRef<GIPITabComponent> = this.dynamicTabPlaceholder.viewContainer.createComponent(componentFactory);\n\n        const instance = componentRef.instance;\n        instance.label = label;\n        instance.template = template;\n        instance.data = data;\n        instance.closeable = closeable;\n        instance.disabled = disabled;\n        instance.action = action;\n\n        return componentRef.instance;\n    }\n\n    public selectTab(tab: GIPITabComponent): void {\n        this.tabQueryList.toArray().forEach(t => (t.active = false));\n        this.dynamicTabs.forEach(t => (t.active = false));\n        tab.active = true;\n        tab.selectionChange.emit();\n\n        if (tab.action) {\n            tab.action(tab.data);\n        }\n    }\n\n    public closeTab(tab: GIPITabComponent): void {\n        const index: number = this.dynamicTabs.indexOf(tab);\n        this.dynamicTabs.splice(index, 1);\n\n        const viewContainerRef: ViewContainerRef = this.dynamicTabPlaceholder.viewContainer;\n        viewContainerRef.remove(index);\n\n        if (this.tabQueryList.length > 0) {\n            this.selectTab(this.tabQueryList.first);\n        }\n    }\n\n    public closeActiveTab(): void {\n        const activeTabs = this.dynamicTabs.filter(tab => tab.active);\n        if (activeTabs.length > 0) {\n            this.closeTab(activeTabs[0]);\n        }\n    }\n\n    public closeAllTabs(): void {\n        const tabs = Object.assign([], this.dynamicTabs);\n        if (tabs.length > 0) {\n            tabs.forEach(tab => this.closeTab(tab));\n        }\n    }\n\n    public nextTab(): void {\n        const currentTab: GIPITabComponent = this.tabQueryList.toArray().find(tab => tab.active);\n        const nextTab: GIPITabComponent = this.tabQueryList.toArray()[this.tabQueryList.toArray().indexOf(currentTab) + 1];\n        if (nextTab != null) {\n            this.tabQueryList.toArray().forEach(t => (t.active = false));\n            this.dynamicTabs.forEach(t => (t.active = false));\n            nextTab.active = true;\n            nextTab.selectionChange.emit();\n        }\n    }\n\n    public previousTab(): void {\n        const currentTab: GIPITabComponent = this.tabQueryList.toArray().find(tab => tab.active);\n        const previousTab: GIPITabComponent = this.tabQueryList.toArray()[this.tabQueryList.toArray().indexOf(currentTab) - 1];\n        if (previousTab != null) {\n            this.tabQueryList.toArray().forEach(t => (t.active = false));\n            this.dynamicTabs.forEach(t => (t.active = false));\n            previousTab.active = true;\n            previousTab.selectionChange.emit();\n        }\n    }\n\n}\n\n"]}
@@ -0,0 +1,352 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { coerceBooleanProperty, coerceCssPixelValue } from '@angular/cdk/coercion';
3
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, forwardRef, Input, OnInit } from '@angular/core';
4
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
5
+ var nextUniqueId = 0;
6
+ var GIPITextareaComponent = /** @class */ (function () {
7
+ function GIPITextareaComponent(elementRef, _changeDetectorRef) {
8
+ this.elementRef = elementRef;
9
+ this._changeDetectorRef = _changeDetectorRef;
10
+ this._name = "gipi-textarea-" + nextUniqueId++;
11
+ this.id = this._name;
12
+ this.name = this._name;
13
+ this.label = '';
14
+ this.placeholder = '';
15
+ this.cols = 20;
16
+ this.rows = 4;
17
+ this.help = '';
18
+ this.maxlength = 254;
19
+ this.minlength = 0;
20
+ this._resize = 'horizontal';
21
+ this._minHeight = '60px';
22
+ this._height = '60px';
23
+ this._maxHeight = 'auto';
24
+ this._autocomplete = 'off';
25
+ this._autofocus = false;
26
+ this._readOnly = false;
27
+ this._required = false;
28
+ this._disabled = false;
29
+ this._lowerCase = false;
30
+ this._upperCase = false;
31
+ this._spaceDrop = false;
32
+ this.onChange = function () { };
33
+ this.onTouched = function () { };
34
+ }
35
+ GIPITextareaComponent_1 = GIPITextareaComponent;
36
+ Object.defineProperty(GIPITextareaComponent.prototype, "resize", {
37
+ get: function () {
38
+ return this._resize;
39
+ },
40
+ set: function (value) {
41
+ if (value !== this.resize) {
42
+ this._resize = value.toLowerCase();
43
+ this._changeDetectorRef.detectChanges();
44
+ }
45
+ },
46
+ enumerable: false,
47
+ configurable: true
48
+ });
49
+ Object.defineProperty(GIPITextareaComponent.prototype, "minHeight", {
50
+ get: function () {
51
+ return this._minHeight;
52
+ },
53
+ set: function (value) {
54
+ if (value.trim().toUpperCase() === 'AUTO') {
55
+ this._minHeight = 'auto';
56
+ }
57
+ else {
58
+ this._minHeight = coerceCssPixelValue(value);
59
+ }
60
+ },
61
+ enumerable: false,
62
+ configurable: true
63
+ });
64
+ Object.defineProperty(GIPITextareaComponent.prototype, "height", {
65
+ get: function () {
66
+ return this._height;
67
+ },
68
+ set: function (value) {
69
+ if (value.trim().toUpperCase() === 'AUTO') {
70
+ this._height = 'auto';
71
+ }
72
+ else {
73
+ this._height = coerceCssPixelValue(value);
74
+ }
75
+ },
76
+ enumerable: false,
77
+ configurable: true
78
+ });
79
+ Object.defineProperty(GIPITextareaComponent.prototype, "maxHeight", {
80
+ get: function () {
81
+ return this._maxHeight;
82
+ },
83
+ set: function (value) {
84
+ if (value.trim().toUpperCase() === 'AUTO') {
85
+ this._maxHeight = 'auto';
86
+ }
87
+ else {
88
+ this._maxHeight = coerceCssPixelValue(value);
89
+ }
90
+ },
91
+ enumerable: false,
92
+ configurable: true
93
+ });
94
+ Object.defineProperty(GIPITextareaComponent.prototype, "autocomplete", {
95
+ get: function () {
96
+ return this._autocomplete;
97
+ },
98
+ set: function (value) {
99
+ this._autocomplete = value;
100
+ },
101
+ enumerable: false,
102
+ configurable: true
103
+ });
104
+ Object.defineProperty(GIPITextareaComponent.prototype, "autofocus", {
105
+ get: function () {
106
+ return this._autofocus;
107
+ },
108
+ set: function (value) {
109
+ this._autofocus = coerceBooleanProperty(value);
110
+ },
111
+ enumerable: false,
112
+ configurable: true
113
+ });
114
+ Object.defineProperty(GIPITextareaComponent.prototype, "readOnly", {
115
+ get: function () {
116
+ return this._readOnly;
117
+ },
118
+ set: function (value) {
119
+ this._readOnly = coerceBooleanProperty(value);
120
+ },
121
+ enumerable: false,
122
+ configurable: true
123
+ });
124
+ Object.defineProperty(GIPITextareaComponent.prototype, "required", {
125
+ get: function () {
126
+ return this._required;
127
+ },
128
+ set: function (value) {
129
+ this._required = coerceBooleanProperty(value);
130
+ },
131
+ enumerable: false,
132
+ configurable: true
133
+ });
134
+ Object.defineProperty(GIPITextareaComponent.prototype, "disabled", {
135
+ get: function () {
136
+ return this._disabled;
137
+ },
138
+ set: function (value) {
139
+ this._disabled = coerceBooleanProperty(value);
140
+ },
141
+ enumerable: false,
142
+ configurable: true
143
+ });
144
+ Object.defineProperty(GIPITextareaComponent.prototype, "lowerCase", {
145
+ get: function () {
146
+ return this._lowerCase;
147
+ },
148
+ set: function (value) {
149
+ this._lowerCase = coerceBooleanProperty(value);
150
+ },
151
+ enumerable: false,
152
+ configurable: true
153
+ });
154
+ Object.defineProperty(GIPITextareaComponent.prototype, "upperCase", {
155
+ get: function () {
156
+ return this._upperCase;
157
+ },
158
+ set: function (value) {
159
+ this._upperCase = coerceBooleanProperty(value);
160
+ },
161
+ enumerable: false,
162
+ configurable: true
163
+ });
164
+ Object.defineProperty(GIPITextareaComponent.prototype, "spaceDrop", {
165
+ get: function () {
166
+ return this._spaceDrop;
167
+ },
168
+ set: function (value) {
169
+ this._spaceDrop = coerceBooleanProperty(value);
170
+ },
171
+ enumerable: false,
172
+ configurable: true
173
+ });
174
+ Object.defineProperty(GIPITextareaComponent.prototype, "value", {
175
+ get: function () {
176
+ return this._value;
177
+ },
178
+ set: function (value) {
179
+ var valueAux = value;
180
+ valueAux = this._checkSpaceDrop(valueAux);
181
+ valueAux = this._checkLowercase(valueAux);
182
+ valueAux = this._checkUppercase(valueAux);
183
+ this._value = valueAux;
184
+ this.onChange(this._value);
185
+ this.onTouched(this._value);
186
+ },
187
+ enumerable: false,
188
+ configurable: true
189
+ });
190
+ GIPITextareaComponent.prototype.ngOnInit = function () { };
191
+ GIPITextareaComponent.prototype.writeValue = function (value) {
192
+ this._value = value;
193
+ };
194
+ GIPITextareaComponent.prototype.registerOnChange = function (fn) {
195
+ this.onChange = fn;
196
+ };
197
+ GIPITextareaComponent.prototype.registerOnTouched = function (fn) {
198
+ this.onTouched = fn;
199
+ };
200
+ GIPITextareaComponent.prototype.setDisabledState = function (isDisabled) {
201
+ this.disabled = isDisabled;
202
+ this._changeDetectorRef.markForCheck();
203
+ };
204
+ GIPITextareaComponent.prototype._checkSpaceDrop = function (value) {
205
+ if (this.spaceDrop && value) {
206
+ return value.replace(/\s/g, '');
207
+ }
208
+ return value;
209
+ };
210
+ GIPITextareaComponent.prototype._checkUppercase = function (value) {
211
+ if (this.upperCase && value) {
212
+ return value.toUpperCase();
213
+ }
214
+ return value;
215
+ };
216
+ GIPITextareaComponent.prototype._checkLowercase = function (value) {
217
+ if (this.lowerCase && value) {
218
+ return value.toLowerCase();
219
+ }
220
+ return value;
221
+ };
222
+ var GIPITextareaComponent_1;
223
+ GIPITextareaComponent.ctorParameters = function () { return [
224
+ { type: ElementRef },
225
+ { type: ChangeDetectorRef }
226
+ ]; };
227
+ __decorate([
228
+ Input(),
229
+ __metadata("design:type", String)
230
+ ], GIPITextareaComponent.prototype, "id", void 0);
231
+ __decorate([
232
+ Input(),
233
+ __metadata("design:type", String)
234
+ ], GIPITextareaComponent.prototype, "name", void 0);
235
+ __decorate([
236
+ Input(),
237
+ __metadata("design:type", String)
238
+ ], GIPITextareaComponent.prototype, "label", void 0);
239
+ __decorate([
240
+ Input(),
241
+ __metadata("design:type", String)
242
+ ], GIPITextareaComponent.prototype, "placeholder", void 0);
243
+ __decorate([
244
+ Input(),
245
+ __metadata("design:type", Number)
246
+ ], GIPITextareaComponent.prototype, "cols", void 0);
247
+ __decorate([
248
+ Input(),
249
+ __metadata("design:type", Number)
250
+ ], GIPITextareaComponent.prototype, "rows", void 0);
251
+ __decorate([
252
+ Input(),
253
+ __metadata("design:type", String)
254
+ ], GIPITextareaComponent.prototype, "help", void 0);
255
+ __decorate([
256
+ Input(),
257
+ __metadata("design:type", Number)
258
+ ], GIPITextareaComponent.prototype, "maxlength", void 0);
259
+ __decorate([
260
+ Input(),
261
+ __metadata("design:type", Number)
262
+ ], GIPITextareaComponent.prototype, "minlength", void 0);
263
+ __decorate([
264
+ Input(),
265
+ __metadata("design:type", String),
266
+ __metadata("design:paramtypes", [String])
267
+ ], GIPITextareaComponent.prototype, "resize", null);
268
+ __decorate([
269
+ Input(),
270
+ __metadata("design:type", String),
271
+ __metadata("design:paramtypes", [String])
272
+ ], GIPITextareaComponent.prototype, "minHeight", null);
273
+ __decorate([
274
+ Input(),
275
+ __metadata("design:type", String),
276
+ __metadata("design:paramtypes", [String])
277
+ ], GIPITextareaComponent.prototype, "height", null);
278
+ __decorate([
279
+ Input(),
280
+ __metadata("design:type", String),
281
+ __metadata("design:paramtypes", [String])
282
+ ], GIPITextareaComponent.prototype, "maxHeight", null);
283
+ __decorate([
284
+ Input(),
285
+ __metadata("design:type", String),
286
+ __metadata("design:paramtypes", [String])
287
+ ], GIPITextareaComponent.prototype, "autocomplete", null);
288
+ __decorate([
289
+ Input(),
290
+ __metadata("design:type", Boolean),
291
+ __metadata("design:paramtypes", [Boolean])
292
+ ], GIPITextareaComponent.prototype, "autofocus", null);
293
+ __decorate([
294
+ Input(),
295
+ __metadata("design:type", Boolean),
296
+ __metadata("design:paramtypes", [Boolean])
297
+ ], GIPITextareaComponent.prototype, "readOnly", null);
298
+ __decorate([
299
+ Input(),
300
+ __metadata("design:type", Boolean),
301
+ __metadata("design:paramtypes", [Boolean])
302
+ ], GIPITextareaComponent.prototype, "required", null);
303
+ __decorate([
304
+ Input(),
305
+ __metadata("design:type", Boolean),
306
+ __metadata("design:paramtypes", [Boolean])
307
+ ], GIPITextareaComponent.prototype, "disabled", null);
308
+ __decorate([
309
+ Input(),
310
+ __metadata("design:type", Boolean),
311
+ __metadata("design:paramtypes", [Boolean])
312
+ ], GIPITextareaComponent.prototype, "lowerCase", null);
313
+ __decorate([
314
+ Input(),
315
+ __metadata("design:type", Boolean),
316
+ __metadata("design:paramtypes", [Boolean])
317
+ ], GIPITextareaComponent.prototype, "upperCase", null);
318
+ __decorate([
319
+ Input(),
320
+ __metadata("design:type", Boolean),
321
+ __metadata("design:paramtypes", [Boolean])
322
+ ], GIPITextareaComponent.prototype, "spaceDrop", null);
323
+ __decorate([
324
+ Input(),
325
+ __metadata("design:type", Object),
326
+ __metadata("design:paramtypes", [Object])
327
+ ], GIPITextareaComponent.prototype, "value", null);
328
+ GIPITextareaComponent = GIPITextareaComponent_1 = __decorate([
329
+ Component({
330
+ selector: 'gipi-textarea',
331
+ exportAs: 'gipiTextarea',
332
+ template: "<label class=\"textarea-label\"\n *ngIf=\"label\"\n [attr.for]=\"id\">\n {{ label }}\n <span *ngIf=\"required\"> * </span>\n</label>\n\n<textarea class=\"textarea-element\"\n [attr.id]=\"id\"\n [attr.name]=\"name\"\n [placeholder]=\"placeholder\"\n [cols]=\"cols\"\n [rows]=\"rows\"\n [class.resize-none]=\"resize === 'none'\"\n [class.resize-both]=\"resize === 'both'\"\n [class.resize-horizontal]=\"resize === 'horizontal'\"\n [class.resize-vertical]=\"resize === 'vertical'\"\n [style.min-height.px]=\"minHeight\"\n [style.height.px]=\"height\"\n [style.max-height.px]=\"maxHeight\"\n [minlength]=\"minlength\"\n [maxlength]=\"maxlength\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [readOnly]=\"readOnly\"\n [attr.autocomplete]=\"autocomplete\"\n [autofocus]=\"autofocus\"\n [(ngModel)]=\"value\"\n [value]=\"value\">\n </textarea>\n\n<small *ngIf=\"help\"\n class=\"textarea-help\">\n {{ help }}\n</small>",
333
+ providers: [
334
+ {
335
+ provide: NG_VALUE_ACCESSOR,
336
+ useExisting: forwardRef(function () { return GIPITextareaComponent_1; }),
337
+ multi: true
338
+ }
339
+ ],
340
+ host: {
341
+ 'class': 'gipi-textarea',
342
+ },
343
+ changeDetection: ChangeDetectionStrategy.OnPush,
344
+ styles: [":host{display:flex;flex-direction:column;gap:.8rem;font-size:1.4rem;color:#696969}:host .textarea-label{display:flex;align-items:center;gap:.4rem;color:#131313;line-height:1.6rem}:host .textarea-label>span{font-size:1.6rem;line-height:1.6rem;color:#d14014}:host .textarea-element{display:flex;font-family:inherit;font-size:inherit;color:inherit;padding:.75rem .8rem;background:#fff;border:1px solid rgba(0,0,0,.12);transition:background-color .2s,color .2s,border-color .2s,box-shadow .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:6px;caret-color:#696969;max-height:12rem;min-height:6rem;resize:vertical;outline:0;overflow:auto}:host .textarea-element:not(:disabled):hover{border-color:#6d6f73}:host .textarea-element:not(:disabled).ng-dirty.ng-invalid:enabled:hover,:host .textarea-element:not(:disabled):invalid:enabled:hover{border-color:#e07f62}:host .textarea-element:not(:disabled):enabled:focus{outline:0;outline-offset:0;box-shadow:0 0 0 .2rem #e0e1e2;border-color:#6d6f73}:host .textarea-element:not(:disabled).ng-dirty.ng-invalid:enabled,:host .textarea-element:not(:disabled):invalid:enabled{border-color:#d14014}:host .textarea-element:not(:disabled).ng-dirty.ng-invalid:enabled:focus,:host .textarea-element:not(:disabled):invalid:enabled:focus{outline:0;outline-offset:0;box-shadow:0 0 0 .2rem #f1c4b6;border-color:#d14014}:host .textarea-element:disabled{color:#bbbdc1!important;border-color:#e0e1e2!important;background-color:#f5f5f6!important;cursor:not-allowed}:host .textarea-element.resize-none{resize:none}:host .textarea-element.resize-both{resize:both}:host .textarea-element.resize-horizontal{resize:horizontal}:host .textarea-element.resize-vertical{resize:vertical}:host .textarea-help{flex:1;font-size:1rem;font-weight:500;margin-top:-.4rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::-webkit-input-placeholder{color:#bbbdc1}:-moz-placeholder{color:#bbbdc1}::-moz-placeholder{color:#bbbdc1}:-ms-input-placeholder{color:#bbbdc1}"]
345
+ }),
346
+ __metadata("design:paramtypes", [ElementRef,
347
+ ChangeDetectorRef])
348
+ ], GIPITextareaComponent);
349
+ return GIPITextareaComponent;
350
+ }());
351
+ export { GIPITextareaComponent };
352
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textarea.component.js","sourceRoot":"ng://@gipisistemas/ng-core/","sources":["shared/gipi-components/textarea/textarea.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty, coerceCssPixelValue } from '@angular/cdk/coercion';\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, forwardRef, Input, OnInit } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nlet nextUniqueId = 0;\n\ntype TextareaResize = 'both' | 'horizontal' | 'vertical' | 'none';\n\n@Component({\n    selector: 'gipi-textarea',\n    exportAs: 'gipiTextarea',\n    templateUrl: './textarea.component.html',\n    styleUrls: ['./textarea.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => GIPITextareaComponent),\n            multi: true\n        }\n    ],\n    host: {\n        'class': 'gipi-textarea',\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class GIPITextareaComponent implements OnInit, ControlValueAccessor {\n\n    private _name: string = `gipi-textarea-${nextUniqueId++}`;\n\n    @Input() id: string = this._name;\n\n    @Input() name: string = this._name;\n\n    @Input() label: string = '';\n\n    @Input() placeholder: string = '';\n\n    @Input() cols: number = 20;\n\n    @Input() rows: number = 4;\n\n    @Input() help: string = '';\n\n    @Input() maxlength: number = 254;\n\n    @Input() minlength: number = 0;\n\n    private _resize: TextareaResize = 'horizontal';\n    @Input() get resize(): TextareaResize {\n        return this._resize;\n    }\n    set resize(value: TextareaResize) {\n        if (value !== this.resize) {\n            this._resize = (value.toLowerCase() as TextareaResize);\n            this._changeDetectorRef.detectChanges();\n        }\n    }\n\n    private _minHeight: string = '60px';\n    @Input() get minHeight(): string {\n        return this._minHeight;\n    }\n    set minHeight(value: string) {\n        if (value.trim().toUpperCase() === 'AUTO') {\n            this._minHeight = 'auto';\n        } else {\n            this._minHeight = coerceCssPixelValue(value);\n        }\n    }\n\n    private _height: string = '60px';\n    @Input() get height(): string {\n        return this._height;\n    }\n    set height(value: string) {\n        if (value.trim().toUpperCase() === 'AUTO') {\n            this._height = 'auto';\n        } else {\n            this._height = coerceCssPixelValue(value);\n        }\n    }\n\n    private _maxHeight: string = 'auto';\n    @Input() get maxHeight(): string {\n        return this._maxHeight;\n    }\n    set maxHeight(value: string) {\n        if (value.trim().toUpperCase() === 'AUTO') {\n            this._maxHeight = 'auto';\n        } else {\n            this._maxHeight = coerceCssPixelValue(value);\n        }\n    }\n\n    private _autocomplete: 'on' | 'off' = 'off';\n    @Input() get autocomplete(): 'on' | 'off' {\n        return this._autocomplete;\n    }\n    set autocomplete(value: 'on' | 'off') {\n        this._autocomplete = value;\n    }\n\n    private _autofocus: boolean = false;\n    @Input() get autofocus(): boolean {\n        return this._autofocus;\n    }\n    set autofocus(value: boolean) {\n        this._autofocus = coerceBooleanProperty(value);\n    }\n\n    private _readOnly: boolean = false;\n    @Input() get readOnly(): boolean {\n        return this._readOnly;\n    }\n    set readOnly(value: boolean) {\n        this._readOnly = coerceBooleanProperty(value);\n    }\n\n    private _required: boolean = false;\n    @Input() get required(): boolean {\n        return this._required;\n    }\n    set required(value: boolean) {\n        this._required = coerceBooleanProperty(value);\n    }\n\n    private _disabled: boolean = false;\n    @Input() get disabled(): boolean {\n        return this._disabled;\n    }\n    set disabled(value: boolean) {\n        this._disabled = coerceBooleanProperty(value);\n    }\n\n    private _lowerCase: boolean = false;\n    @Input() get lowerCase(): boolean {\n        return this._lowerCase;\n    }\n    set lowerCase(value: boolean) {\n        this._lowerCase = coerceBooleanProperty(value);\n    }\n\n    private _upperCase: boolean = false;\n    @Input() get upperCase(): boolean {\n        return this._upperCase;\n    }\n    set upperCase(value: boolean) {\n        this._upperCase = coerceBooleanProperty(value);\n    }\n\n    private _spaceDrop: boolean = false;\n    @Input() get spaceDrop(): boolean {\n        return this._spaceDrop;\n    }\n    set spaceDrop(value: boolean) {\n        this._spaceDrop = coerceBooleanProperty(value);\n    }\n\n    private _value!: any;\n    @Input()\n    get value(): any {\n        return this._value;\n    }\n    set value(value: any) {\n        let valueAux: any = value;\n        valueAux = this._checkSpaceDrop(valueAux);\n        valueAux = this._checkLowercase(valueAux);\n        valueAux = this._checkUppercase(valueAux);\n        this._value = valueAux;\n\n        this.onChange(this._value);\n        this.onTouched(this._value);\n    }\n\n    onChange: Function = () => { };\n\n    onTouched: Function = () => { };\n\n    constructor(\n        public elementRef: ElementRef<HTMLElement>,\n        private _changeDetectorRef: ChangeDetectorRef,\n    ) { }\n\n    ngOnInit(): void { }\n\n    writeValue(value: any): void {\n        this._value = value;\n    }\n\n    registerOnChange(fn: Function): void {\n        this.onChange = fn;\n    }\n\n    registerOnTouched(fn: Function): void {\n        this.onTouched = fn;\n    }\n\n    setDisabledState?(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n        this._changeDetectorRef.markForCheck();\n    }\n\n    private _checkSpaceDrop(value: any): any {\n        if (this.spaceDrop && value) {\n            return value.replace(/\\s/g, '');\n        }\n        return value;\n    }\n\n    private _checkUppercase(value: any): any {\n        if (this.upperCase && value) {\n            return value.toUpperCase();\n        }\n        return value;\n    }\n\n    private _checkLowercase(value: any): any {\n        if (this.lowerCase && value) {\n            return value.toLowerCase();\n        }\n        return value;\n    }\n\n}\n"]}