@gipisistemas/ng-core 1.1.3 → 1.1.5
Sign up to get free protection for your applications and to get access to all the features.
- package/assets/styles/colors.scss +5 -1
- package/bundles/gipisistemas-ng-core.umd.js +2098 -1285
- package/bundles/gipisistemas-ng-core.umd.js.map +1 -1
- package/bundles/gipisistemas-ng-core.umd.min.js +10 -9
- package/bundles/gipisistemas-ng-core.umd.min.js.map +1 -1
- package/core/gipi-components/models/sort.model.d.ts +3 -3
- package/core/utils/array.util.d.ts +2 -2
- package/core/utils/object.util.d.ts +3 -5
- package/core/utils/string.util.d.ts +4 -0
- package/esm2015/core/gipi-components/models/sort.model.js +1 -1
- package/esm2015/core/gipi-components/services/abstract-crud.service.js +18 -24
- package/esm2015/core/utils/array.util.js +4 -2
- package/esm2015/core/utils/object.util.js +5 -9
- package/esm2015/core/utils/string.util.js +27 -1
- package/esm2015/gipi-components.js +11 -1
- package/esm2015/shared/components/input/input.component.js +46 -23
- package/esm2015/shared/components/select-entity-paged/shared/select-search/select-search.component.js +2 -2
- package/esm2015/shared/components/table/table.component.js +1 -1
- package/esm2015/shared/gipi-components/abstract-form/abstract-form.component.js +1 -1
- package/esm2015/shared/gipi-components/button/button.component.js +18 -2
- package/esm2015/shared/gipi-components/card/card.component.js +113 -0
- package/esm2015/shared/gipi-components/datepicker/datepicker/datepicker.component.js +8 -3
- package/esm2015/shared/gipi-components/empty-state/empty-state.component.js +30 -0
- package/esm2015/shared/gipi-components/input-select-paged/input-search/input-search.component.js +2 -2
- package/esm2015/shared/gipi-components/layout-grid/col.directive.js +4 -4
- package/esm2015/shared/gipi-components/month-year-picker/month-year-picker.component.js +2 -2
- package/esm2015/shared/gipi-components/notification/notification.component.js +8 -3
- package/esm2015/shared/gipi-components/popover/shared/popover-trigger.js +4 -4
- package/esm2015/shared/gipi-components/sidebar/sidenav/sidenav.component.js +35 -3
- package/esm2015/shared/gipi-components/slide-toggle/slide-toggle.component.js +113 -0
- package/esm2015/shared/gipi-components/split-button/split-button.component.js +243 -0
- package/esm2015/shared/gipi-components/tabs/shared/dynamic-tab.directive.js +18 -0
- package/esm2015/shared/gipi-components/tabs/shared/tab.model.js +8 -0
- package/esm2015/shared/gipi-components/tabs/tab/tab.component.js +66 -0
- package/esm2015/shared/gipi-components/tabs/tab-group/tab-group.component.js +123 -0
- package/esm2015/shared/gipi-components/textarea/textarea.component.js +298 -0
- package/esm2015/shared/shared.module.js +22 -16
- package/esm2015/shared.js +1 -5
- package/esm5/core/gipi-components/models/sort.model.js +1 -1
- package/esm5/core/gipi-components/services/abstract-crud.service.js +18 -24
- package/esm5/core/utils/array.util.js +4 -3
- package/esm5/core/utils/object.util.js +5 -9
- package/esm5/core/utils/string.util.js +27 -1
- package/esm5/gipi-components.js +11 -1
- package/esm5/shared/components/input/input.component.js +46 -23
- package/esm5/shared/components/select-entity-paged/shared/select-search/select-search.component.js +2 -2
- package/esm5/shared/components/table/table.component.js +1 -1
- package/esm5/shared/gipi-components/abstract-form/abstract-form.component.js +1 -1
- package/esm5/shared/gipi-components/button/button.component.js +22 -2
- package/esm5/shared/gipi-components/card/card.component.js +135 -0
- package/esm5/shared/gipi-components/datepicker/datepicker/datepicker.component.js +8 -3
- package/esm5/shared/gipi-components/empty-state/empty-state.component.js +33 -0
- package/esm5/shared/gipi-components/input-select-paged/input-search/input-search.component.js +2 -2
- package/esm5/shared/gipi-components/layout-grid/col.directive.js +4 -4
- package/esm5/shared/gipi-components/month-year-picker/month-year-picker.component.js +2 -2
- package/esm5/shared/gipi-components/notification/notification.component.js +8 -3
- package/esm5/shared/gipi-components/popover/shared/popover-trigger.js +4 -4
- package/esm5/shared/gipi-components/sidebar/sidenav/sidenav.component.js +35 -3
- package/esm5/shared/gipi-components/slide-toggle/slide-toggle.component.js +127 -0
- package/esm5/shared/gipi-components/split-button/split-button.component.js +249 -0
- package/esm5/shared/gipi-components/tabs/shared/dynamic-tab.directive.js +19 -0
- package/esm5/shared/gipi-components/tabs/shared/tab.model.js +10 -0
- package/esm5/shared/gipi-components/tabs/tab/tab.component.js +67 -0
- package/esm5/shared/gipi-components/tabs/tab-group/tab-group.component.js +131 -0
- package/esm5/shared/gipi-components/textarea/textarea.component.js +352 -0
- package/esm5/shared/shared.module.js +22 -16
- package/esm5/shared.js +1 -5
- package/fesm2015/gipisistemas-ng-core.js +1991 -1274
- package/fesm2015/gipisistemas-ng-core.js.map +1 -1
- package/fesm5/gipisistemas-ng-core.js +2088 -1281
- package/fesm5/gipisistemas-ng-core.js.map +1 -1
- package/gipi-components.d.ts +9 -0
- package/gipisistemas-ng-core.metadata.json +1 -1
- package/package.json +1 -2
- package/shared/components/input/input.component.d.ts +13 -11
- package/shared/components/table/table.component.d.ts +3 -3
- package/shared/gipi-components/button/button.component.d.ts +14 -0
- package/shared/gipi-components/card/card.component.d.ts +23 -0
- package/shared/gipi-components/empty-state/empty-state.component.d.ts +5 -0
- package/shared/gipi-components/notification/notification.component.d.ts +1 -0
- package/shared/gipi-components/sidebar/sidenav/sidenav.component.d.ts +7 -0
- package/shared/gipi-components/slide-toggle/slide-toggle.component.d.ts +27 -0
- package/shared/gipi-components/split-button/split-button.component.d.ts +60 -0
- package/shared/{directives → gipi-components/tabs/shared}/dynamic-tab.directive.d.ts +1 -1
- package/shared/gipi-components/tabs/shared/tab.model.d.ts +12 -0
- package/shared/{components → gipi-components/tabs}/tab/tab.component.d.ts +4 -2
- package/shared/gipi-components/tabs/tab-group/tab-group.component.d.ts +22 -0
- package/shared/gipi-components/textarea/textarea.component.d.ts +68 -0
- package/shared.d.ts +0 -4
- package/esm2015/shared/components/select-button/select-button.component.js +0 -181
- package/esm2015/shared/components/tab/tab.component.js +0 -57
- package/esm2015/shared/components/tab-group/tab-group.component.js +0 -117
- package/esm2015/shared/directives/dynamic-tab.directive.js +0 -18
- package/esm5/shared/components/select-button/select-button.component.js +0 -195
- package/esm5/shared/components/tab/tab.component.js +0 -58
- package/esm5/shared/components/tab-group/tab-group.component.js +0 -125
- package/esm5/shared/directives/dynamic-tab.directive.js +0 -19
- package/shared/components/select-button/select-button.component.d.ts +0 -35
- package/shared/components/tab-group/tab-group.component.d.ts +0 -22
@@ -0,0 +1,243 @@
|
|
1
|
+
var GIPISplitButtonComponent_1;
|
2
|
+
import { __decorate, __metadata } from "tslib";
|
3
|
+
import { animate, state, style, transition, trigger } from '@angular/animations';
|
4
|
+
import { Component, ElementRef, EventEmitter, forwardRef, HostListener, Input, OnInit, Output, ViewChild } from '@angular/core';
|
5
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
6
|
+
import { GIPIPopoverTrigger } from '../popover/shared/popover-trigger';
|
7
|
+
import { ObjectUtil } from './../../../core/utils/object.util';
|
8
|
+
let nextUniqueId = 0;
|
9
|
+
let GIPISplitButtonComponent = GIPISplitButtonComponent_1 = class GIPISplitButtonComponent {
|
10
|
+
constructor(elementRef) {
|
11
|
+
this.elementRef = elementRef;
|
12
|
+
this._uniqueId = nextUniqueId++;
|
13
|
+
this._name = `gipi-split-button-${this._uniqueId}`;
|
14
|
+
this.idBtnDefault = `gipi-split-button-default-${this._uniqueId}`;
|
15
|
+
this.idBtnMenu = `gipi-split-button-menu-${this._uniqueId}`;
|
16
|
+
this.isSplitButtonPrimary = this._hasHostAttributes('gipi-primary');
|
17
|
+
this.isSplitButtonSecondary = this._hasHostAttributes('gipi-secondary');
|
18
|
+
this.isSplitButtonTertiary = this._hasHostAttributes('gipi-tertiary');
|
19
|
+
this.isSplitButtonAction = this._hasHostAttributes('gipi-action');
|
20
|
+
this.id = this._name;
|
21
|
+
this.name = this._name;
|
22
|
+
this.type = 'button';
|
23
|
+
this.ariaLabel = '';
|
24
|
+
this.title = '';
|
25
|
+
this.label = '';
|
26
|
+
this.disabled = false;
|
27
|
+
this.loading = false;
|
28
|
+
this.tooltip = '';
|
29
|
+
this.splitOptions = [];
|
30
|
+
this.onOpenPopover = new EventEmitter();
|
31
|
+
this.onClosePopover = new EventEmitter();
|
32
|
+
this.onClick = new EventEmitter(true);
|
33
|
+
this.onFocus = new EventEmitter(true);
|
34
|
+
this.onBlur = new EventEmitter(true);
|
35
|
+
}
|
36
|
+
ngOnInit() { }
|
37
|
+
ngOnDestroy() {
|
38
|
+
if (this.popoverTrigger) {
|
39
|
+
this.popoverTrigger.destroyPopover();
|
40
|
+
}
|
41
|
+
}
|
42
|
+
getHostElement() {
|
43
|
+
return this.elementRef.nativeElement;
|
44
|
+
}
|
45
|
+
_hasHostAttributes(...attributes) {
|
46
|
+
return attributes.some(attribute => this.getHostElement().hasAttribute(attribute));
|
47
|
+
}
|
48
|
+
btnIdAndName() {
|
49
|
+
const uniqueId = nextUniqueId++;
|
50
|
+
return {
|
51
|
+
btnDefault: `gipi-split-button-default-${uniqueId}`,
|
52
|
+
btnMenu: `gipi-split-button-menu-${uniqueId}`,
|
53
|
+
};
|
54
|
+
}
|
55
|
+
getInternalButtonClass(isBtnDefault) {
|
56
|
+
return {
|
57
|
+
'button-default': isBtnDefault,
|
58
|
+
'button-menu': !isBtnDefault,
|
59
|
+
'button-primary': this.isSplitButtonPrimary,
|
60
|
+
'button-secondary': this.isSplitButtonSecondary,
|
61
|
+
'button-tertiary': this.isSplitButtonTertiary,
|
62
|
+
'button-action': this.isSplitButtonAction,
|
63
|
+
};
|
64
|
+
}
|
65
|
+
showPopover() {
|
66
|
+
if (this.disabled || this.loading) {
|
67
|
+
return;
|
68
|
+
}
|
69
|
+
else {
|
70
|
+
this.popoverTrigger.openPopover();
|
71
|
+
}
|
72
|
+
}
|
73
|
+
closePopover() {
|
74
|
+
if (this.disabled || this.loading) {
|
75
|
+
return;
|
76
|
+
}
|
77
|
+
else {
|
78
|
+
this.popoverTrigger.closePopover();
|
79
|
+
}
|
80
|
+
}
|
81
|
+
handleClick(event) {
|
82
|
+
if (this.disabled || this.loading) {
|
83
|
+
return;
|
84
|
+
}
|
85
|
+
else {
|
86
|
+
this.onClick.emit(event);
|
87
|
+
this.closePopover();
|
88
|
+
event.stopPropagation();
|
89
|
+
}
|
90
|
+
}
|
91
|
+
handleFocus(event) {
|
92
|
+
if (this.disabled || this.loading) {
|
93
|
+
return;
|
94
|
+
}
|
95
|
+
else {
|
96
|
+
this.onFocus.emit(event);
|
97
|
+
event.stopPropagation();
|
98
|
+
}
|
99
|
+
}
|
100
|
+
handleBlur(event) {
|
101
|
+
if (this.disabled || this.loading) {
|
102
|
+
return;
|
103
|
+
}
|
104
|
+
else {
|
105
|
+
this.onBlur.emit(event);
|
106
|
+
event.stopPropagation();
|
107
|
+
}
|
108
|
+
}
|
109
|
+
handleClickBtnMenu(event) {
|
110
|
+
if (this.disabled || this.loading) {
|
111
|
+
return;
|
112
|
+
}
|
113
|
+
else {
|
114
|
+
if (!ObjectUtil.isNull(this.popoverTrigger)) {
|
115
|
+
this.popoverTrigger.togglePopover();
|
116
|
+
}
|
117
|
+
event.stopPropagation();
|
118
|
+
}
|
119
|
+
}
|
120
|
+
handleClickBtnSplitOption(option) {
|
121
|
+
if (this.disabled || this.loading || !option || option.disabled || !option.clickFn) {
|
122
|
+
return;
|
123
|
+
}
|
124
|
+
else {
|
125
|
+
option.clickFn();
|
126
|
+
this.closePopover();
|
127
|
+
}
|
128
|
+
}
|
129
|
+
onResize(event) {
|
130
|
+
if (this.popoverTrigger) {
|
131
|
+
this.popoverTrigger.closePopover();
|
132
|
+
event.stopPropagation();
|
133
|
+
}
|
134
|
+
}
|
135
|
+
};
|
136
|
+
GIPISplitButtonComponent.ctorParameters = () => [
|
137
|
+
{ type: ElementRef }
|
138
|
+
];
|
139
|
+
__decorate([
|
140
|
+
ViewChild(GIPIPopoverTrigger, { static: false }),
|
141
|
+
__metadata("design:type", GIPIPopoverTrigger)
|
142
|
+
], GIPISplitButtonComponent.prototype, "popoverTrigger", void 0);
|
143
|
+
__decorate([
|
144
|
+
Input(),
|
145
|
+
__metadata("design:type", String)
|
146
|
+
], GIPISplitButtonComponent.prototype, "id", void 0);
|
147
|
+
__decorate([
|
148
|
+
Input(),
|
149
|
+
__metadata("design:type", String)
|
150
|
+
], GIPISplitButtonComponent.prototype, "name", void 0);
|
151
|
+
__decorate([
|
152
|
+
Input(),
|
153
|
+
__metadata("design:type", String)
|
154
|
+
], GIPISplitButtonComponent.prototype, "type", void 0);
|
155
|
+
__decorate([
|
156
|
+
Input(),
|
157
|
+
__metadata("design:type", String)
|
158
|
+
], GIPISplitButtonComponent.prototype, "ariaLabel", void 0);
|
159
|
+
__decorate([
|
160
|
+
Input(),
|
161
|
+
__metadata("design:type", String)
|
162
|
+
], GIPISplitButtonComponent.prototype, "title", void 0);
|
163
|
+
__decorate([
|
164
|
+
Input(),
|
165
|
+
__metadata("design:type", String)
|
166
|
+
], GIPISplitButtonComponent.prototype, "label", void 0);
|
167
|
+
__decorate([
|
168
|
+
Input(),
|
169
|
+
__metadata("design:type", String)
|
170
|
+
], GIPISplitButtonComponent.prototype, "buttonClass", void 0);
|
171
|
+
__decorate([
|
172
|
+
Input(),
|
173
|
+
__metadata("design:type", Boolean)
|
174
|
+
], GIPISplitButtonComponent.prototype, "disabled", void 0);
|
175
|
+
__decorate([
|
176
|
+
Input(),
|
177
|
+
__metadata("design:type", Boolean)
|
178
|
+
], GIPISplitButtonComponent.prototype, "loading", void 0);
|
179
|
+
__decorate([
|
180
|
+
Input(),
|
181
|
+
__metadata("design:type", String)
|
182
|
+
], GIPISplitButtonComponent.prototype, "tooltip", void 0);
|
183
|
+
__decorate([
|
184
|
+
Input('options'),
|
185
|
+
__metadata("design:type", Array)
|
186
|
+
], GIPISplitButtonComponent.prototype, "splitOptions", void 0);
|
187
|
+
__decorate([
|
188
|
+
Output(),
|
189
|
+
__metadata("design:type", EventEmitter)
|
190
|
+
], GIPISplitButtonComponent.prototype, "onOpenPopover", void 0);
|
191
|
+
__decorate([
|
192
|
+
Output(),
|
193
|
+
__metadata("design:type", EventEmitter)
|
194
|
+
], GIPISplitButtonComponent.prototype, "onClosePopover", void 0);
|
195
|
+
__decorate([
|
196
|
+
Output('click'),
|
197
|
+
__metadata("design:type", EventEmitter)
|
198
|
+
], GIPISplitButtonComponent.prototype, "onClick", void 0);
|
199
|
+
__decorate([
|
200
|
+
Output('focus'),
|
201
|
+
__metadata("design:type", EventEmitter)
|
202
|
+
], GIPISplitButtonComponent.prototype, "onFocus", void 0);
|
203
|
+
__decorate([
|
204
|
+
Output('blur'),
|
205
|
+
__metadata("design:type", EventEmitter)
|
206
|
+
], GIPISplitButtonComponent.prototype, "onBlur", void 0);
|
207
|
+
__decorate([
|
208
|
+
HostListener('window:resize', ['$event']),
|
209
|
+
__metadata("design:type", Function),
|
210
|
+
__metadata("design:paramtypes", [UIEvent]),
|
211
|
+
__metadata("design:returntype", void 0)
|
212
|
+
], GIPISplitButtonComponent.prototype, "onResize", null);
|
213
|
+
GIPISplitButtonComponent = GIPISplitButtonComponent_1 = __decorate([
|
214
|
+
Component({
|
215
|
+
selector: `gipi-split-button[gipi-primary], gipi-split-button[gipi-secondary],
|
216
|
+
gipi-split-button[gipi-tertiary], gipi-split-button[gipi-action]`,
|
217
|
+
exportAs: 'gipiSplitButton',
|
218
|
+
template: "<div [matTooltip]=\"tooltip\"\n [class]=\"buttonClass || ''\"\n [class.button-base]=\"true\"\n [class.disabled]=\"disabled || loading\"\n #popoverTrigger=\"popoverTrigger\"\n [popoverTriggerFor]=\"btnPopover\"\n [popoverTriggerOn]=\"'none'\"\n [popoverBackdropCloseOnClick]=\"true\"\n (opened)=\"onOpenPopover.emit()\"\n (closed)=\"onClosePopover.emit()\">\n <button [attr.id]=\"idBtnDefault\"\n [attr.name]=\"idBtnDefault\"\n [attr.type]=\"type\"\n [attr.aria-label]=\"ariaLabel ? ariaLabel : label\"\n [attr.title]=\"title ? title : label\"\n [disabled]=\"disabled || loading\"\n [ngClass]=\"getInternalButtonClass(true)\"\n role=\"button\"\n (click)=\"handleClick($event)\"\n (focus)=\"handleFocus($event)\"\n (blur)=\"handleBlur($event)\">\n {{ label ? label : '' }}\n </button>\n <button [attr.id]=\"idBtnMenu\"\n [attr.name]=\"idBtnMenu\"\n [attr.type]=\"type\"\n [attr.aria-label]=\"ariaLabel ? ariaLabel : label\"\n [attr.title]=\"title ? title : label\"\n [disabled]=\"disabled || loading\"\n [ngClass]=\"getInternalButtonClass(false)\"\n role=\"button\"\n (click)=\"handleClickBtnMenu($event)\">\n <mat-icon [@indicatorRotate]=\"popoverTrigger?.popoverOpen ? 'opened': 'closed'\"> expand_more </mat-icon>\n </button>\n</div>\n\n<gipi-popover #btnPopover=\"gipiPopover\"\n [popoverOverlapTrigger]=\"false\"\n [popoverCloseOnClick]=\"false\"\n [popoverArrowWidth]=\"0\"\n [popoverOffsetY]=\"3\">\n <div class=\"btn-popover-content\">\n <button class=\"btn-split-option\"\n *ngFor=\"let option of splitOptions\"\n [disabled]=\"option?.disabled\"\n (click)=\"handleClickBtnSplitOption(option)\">\n {{ option.label }}\n </button>\n </div>\n</gipi-popover>",
|
219
|
+
providers: [
|
220
|
+
{
|
221
|
+
provide: NG_VALUE_ACCESSOR,
|
222
|
+
useExisting: forwardRef(() => GIPISplitButtonComponent_1),
|
223
|
+
multi: true
|
224
|
+
}
|
225
|
+
],
|
226
|
+
host: {
|
227
|
+
'class': 'gipi-split-button',
|
228
|
+
'[attr.id]': 'id',
|
229
|
+
'[attr.name]': 'name',
|
230
|
+
},
|
231
|
+
animations: [
|
232
|
+
trigger('indicatorRotate', [
|
233
|
+
state('closed', style({ transform: 'rotate(0deg)' })),
|
234
|
+
state('opened', style({ transform: 'rotate(-180deg)' })),
|
235
|
+
transition('opened <=> closed', animate('225ms cubic-bezier(0.4,0.0,0.2,1)')),
|
236
|
+
])
|
237
|
+
],
|
238
|
+
styles: [".button-base{display:flex;flex-direction:row;justify-content:center;border-radius:4px;font-weight:600;font-size:1.4rem;line-height:1.6rem;cursor:pointer;outline:0;white-space:nowrap;text-decoration:none;vertical-align:middle;text-align:center;box-shadow:1px 1px 5px 0 rgba(0,0,0,.1);transition:.2s;width:100%;max-height:4rem;border:1px solid transparent;position:relative;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.button-base.disabled{cursor:not-allowed!important;box-shadow:none}.button-base>button{display:flex;align-items:center;justify-content:center;border:none;outline:0;box-shadow:none;width:100%;height:40px;padding:12px 16px;overflow:hidden;border-radius:inherit;cursor:inherit;font-size:inherit;font-weight:inherit;white-space:nowrap;text-decoration:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;position:relative}.button-base>button:not(.disabled):active{opacity:.8}.button-base .button-default{border-top-right-radius:0!important;border-bottom-right-radius:0!important}.button-base .button-menu{max-width:-webkit-fit-content;max-width:-moz-fit-content;max-width:fit-content;border-top-left-radius:0!important;border-bottom-left-radius:0!important}.button-primary:not(:disabled),.button-primary:not(:disabled)>mat-icon{background-color:#e0313e;color:#fff;fill:#fff}.button-primary:not(:disabled).button-default,.button-primary:not(:disabled)>mat-icon.button-default{border-right:1px solid #9f232c}.button-primary:not(:disabled) svg,.button-primary:not(:disabled) svg g path,.button-primary:not(:disabled) svg path,.button-primary:not(:disabled)>mat-icon svg,.button-primary:not(:disabled)>mat-icon svg g path,.button-primary:not(:disabled)>mat-icon svg path{color:#fff;fill:#fff}.button-primary:disabled,.button-primary:disabled>mat-icon{background-color:#d1d2d4;color:#9a9da2;fill:#9a9da2}.button-primary:disabled.button-default,.button-primary:disabled>mat-icon.button-default{border-right:1px solid #9a9da2}.button-primary:disabled svg,.button-primary:disabled svg g path,.button-primary:disabled svg path,.button-primary:disabled>mat-icon svg,.button-primary:disabled>mat-icon svg g path,.button-primary:disabled>mat-icon svg path{color:#9a9da2;fill:#9a9da2}.button-primary:not(:disabled):hover,.button-primary:not(:disabled):hover>mat-icon{background-color:#cc2d38;color:#fff;fill:#fff}.button-primary:not(:disabled):hover svg,.button-primary:not(:disabled):hover svg g path,.button-primary:not(:disabled):hover svg path,.button-primary:not(:disabled):hover>mat-icon svg,.button-primary:not(:disabled):hover>mat-icon svg g path,.button-primary:not(:disabled):hover>mat-icon svg path{color:#fff;fill:#fff}.button-secondary{background-color:transparent}.button-secondary:not(:disabled),.button-secondary:not(:disabled)>mat-icon{border-color:#595959;color:#595959;fill:#595959}.button-secondary:not(:disabled).button-default,.button-secondary:not(:disabled)>mat-icon.button-default{border-right:1px solid #595959}.button-secondary:not(:disabled) svg,.button-secondary:not(:disabled) svg g path,.button-secondary:not(:disabled) svg path,.button-secondary:not(:disabled)>mat-icon svg,.button-secondary:not(:disabled)>mat-icon svg g path,.button-secondary:not(:disabled)>mat-icon svg path{color:#595959;fill:#595959}.button-secondary:disabled,.button-secondary:disabled>mat-icon{border-color:#d1d2d4;background-color:#d1d2d4;color:#9a9da2;fill:#9a9da2}.button-secondary:disabled.button-default,.button-secondary:disabled>mat-icon.button-default{border-right:1px solid #9a9da2}.button-secondary:disabled svg,.button-secondary:disabled svg g path,.button-secondary:disabled svg path,.button-secondary:disabled>mat-icon svg,.button-secondary:disabled>mat-icon svg g path,.button-secondary:disabled>mat-icon svg path{color:#9a9da2;fill:#9a9da2}.button-secondary:not(:disabled):hover,.button-secondary:not(:disabled):hover>mat-icon{border-color:#595959;background-color:#e0e1e2;color:#595959;fill:#595959}.button-secondary:not(:disabled):hover svg,.button-secondary:not(:disabled):hover svg g path,.button-secondary:not(:disabled):hover svg path,.button-secondary:not(:disabled):hover>mat-icon svg,.button-secondary:not(:disabled):hover>mat-icon svg g path,.button-secondary:not(:disabled):hover>mat-icon svg path{color:#595959;fill:#595959}.button-tertiary{background-color:#e7ebee;box-shadow:none}.button-tertiary:not(:disabled),.button-tertiary:not(:disabled)>mat-icon{color:#595959;fill:#595959}.button-tertiary:not(:disabled).button-default,.button-tertiary:not(:disabled)>mat-icon.button-default{border-right:1px solid #595959}.button-tertiary:not(:disabled) svg,.button-tertiary:not(:disabled) svg g path,.button-tertiary:not(:disabled) svg path,.button-tertiary:not(:disabled)>mat-icon svg,.button-tertiary:not(:disabled)>mat-icon svg g path,.button-tertiary:not(:disabled)>mat-icon svg path{color:#595959;fill:#595959}.button-tertiary:disabled,.button-tertiary:disabled>mat-icon{background-color:#d1d2d4;color:#9a9da2;fill:#9a9da2}.button-tertiary:disabled.button-default,.button-tertiary:disabled>mat-icon.button-default{border-right:1px solid #9a9da2}.button-tertiary:disabled svg,.button-tertiary:disabled svg g path,.button-tertiary:disabled svg path,.button-tertiary:disabled>mat-icon svg,.button-tertiary:disabled>mat-icon svg g path,.button-tertiary:disabled>mat-icon svg path{color:#9a9da2;fill:#9a9da2}.button-tertiary:not(:disabled):hover,.button-tertiary:not(:disabled):hover>mat-icon{background-color:#e0e1e2;color:#595959;fill:#595959}.button-tertiary:not(:disabled):hover svg,.button-tertiary:not(:disabled):hover svg g path,.button-tertiary:not(:disabled):hover svg path,.button-tertiary:not(:disabled):hover>mat-icon svg,.button-tertiary:not(:disabled):hover>mat-icon svg g path,.button-tertiary:not(:disabled):hover>mat-icon svg path{color:#595959;fill:#595959}.button-action{background-color:transparent;box-shadow:none;display:flex;justify-content:flex-start!important}.button-action:not(:disabled),.button-action:not(:disabled)>mat-icon{color:#262626;fill:#262626}.button-action:not(:disabled).button-default,.button-action:not(:disabled)>mat-icon.button-default{border-right:1px solid #262626}.button-action:not(:disabled) svg,.button-action:not(:disabled) svg g path,.button-action:not(:disabled) svg path,.button-action:not(:disabled)>mat-icon svg,.button-action:not(:disabled)>mat-icon svg g path,.button-action:not(:disabled)>mat-icon svg path{color:#262626;fill:#262626}.button-action:disabled,.button-action:disabled>mat-icon{color:#9a9da2;fill:#9a9da2}.button-action:disabled.button-default,.button-action:disabled>mat-icon.button-default{border-right:1px solid #9a9da2}.button-action:disabled svg,.button-action:disabled svg g path,.button-action:disabled svg path,.button-action:disabled>mat-icon svg,.button-action:disabled>mat-icon svg g path,.button-action:disabled>mat-icon svg path{color:#9a9da2;fill:#9a9da2}.button-action:not(:disabled):hover,.button-action:not(:disabled):hover>mat-icon{background-color:#f5f5f6;color:#262626;fill:#262626}.button-action:not(:disabled):hover svg,.button-action:not(:disabled):hover svg g path,.button-action:not(:disabled):hover svg path,.button-action:not(:disabled):hover>mat-icon svg,.button-action:not(:disabled):hover>mat-icon svg g path,.button-action:not(:disabled):hover>mat-icon svg path{color:#262626;fill:#262626}.disabled,:disabled{pointer-events:none!important}.btn-popover-content{display:flex;flex-direction:column;gap:.8rem;background-color:#fff;border-radius:4px;box-shadow:0 2px 4px -1px rgba(0,0,0,.2),0 4px 5px 0 rgba(0,0,0,.14),0 1px 10px 0 rgba(0,0,0,.12);padding:8px}.btn-split-option{width:100%;padding:.8rem;border-radius:.4rem;border:1px solid transparent;text-align:left;outline:0;background-color:transparent;cursor:pointer}.btn-split-option:not(:disabled){color:#595959}.btn-split-option:disabled{border-color:#d1d2d4;background-color:#d1d2d4;color:#9a9da2;cursor:not-allowed}.btn-split-option:not(:disabled):hover{border-color:#595959;background-color:#e0e1e2;color:#595959}"]
|
239
|
+
}),
|
240
|
+
__metadata("design:paramtypes", [ElementRef])
|
241
|
+
], GIPISplitButtonComponent);
|
242
|
+
export { GIPISplitButtonComponent };
|
243
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"split-button.component.js","sourceRoot":"ng://@gipisistemas/ng-core/","sources":["shared/gipi-components/split-button/split-button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations';\nimport { Component, ElementRef, EventEmitter, forwardRef, HostListener, Input, OnInit, Output, ViewChild } from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { GIPIPopoverTrigger } from '../popover/shared/popover-trigger';\nimport { ObjectUtil } from './../../../core/utils/object.util';\n\nexport interface SplitOptions {\n    label: string;\n    disabled: boolean;\n    clickFn: Function;\n}\n\nlet nextUniqueId = 0;\n\n@Component({\n    selector: `gipi-split-button[gipi-primary], gipi-split-button[gipi-secondary],\n               gipi-split-button[gipi-tertiary], gipi-split-button[gipi-action]`,\n    exportAs: 'gipiSplitButton',\n    templateUrl: './split-button.component.html',\n    styleUrls: ['./split-button.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => GIPISplitButtonComponent),\n            multi: true\n        }\n    ],\n    host: {\n        'class': 'gipi-split-button',\n        '[attr.id]': 'id',\n        '[attr.name]': 'name',\n    },\n    animations: [\n        trigger('indicatorRotate', [\n            state('closed', style({ transform: 'rotate(0deg)' })),\n            state('opened', style({ transform: 'rotate(-180deg)' })),\n            transition('opened <=> closed', animate('225ms cubic-bezier(0.4,0.0,0.2,1)')),\n        ])\n    ]\n})\nexport class GIPISplitButtonComponent implements OnInit {\n\n    private _uniqueId: number = nextUniqueId++;\n    private _name: string = `gipi-split-button-${this._uniqueId}`;\n\n    public idBtnDefault = `gipi-split-button-default-${this._uniqueId}`;\n    public idBtnMenu = `gipi-split-button-menu-${this._uniqueId}`;\n\n    readonly isSplitButtonPrimary: boolean = this._hasHostAttributes('gipi-primary');\n    readonly isSplitButtonSecondary: boolean = this._hasHostAttributes('gipi-secondary');\n    readonly isSplitButtonTertiary: boolean = this._hasHostAttributes('gipi-tertiary');\n    readonly isSplitButtonAction: boolean = this._hasHostAttributes('gipi-action');\n\n    @ViewChild(GIPIPopoverTrigger, { static: false }) popoverTrigger: GIPIPopoverTrigger;\n\n    @Input() id: string = this._name;\n\n    @Input() name: string = this._name;\n\n    @Input() type: 'button' | 'submit' | 'reset' = 'button';\n\n    @Input() ariaLabel: string = '';\n\n    @Input() title: string = '';\n\n    @Input() label: string = '';\n\n    @Input() buttonClass: string;\n\n    @Input() disabled: boolean = false;\n\n    @Input() loading: boolean = false;\n\n    @Input() tooltip: string = '';\n\n    @Input('options') splitOptions: SplitOptions[] = [];\n\n    @Output() onOpenPopover: EventEmitter<void> = new EventEmitter();\n    @Output() onClosePopover: EventEmitter<void> = new EventEmitter();\n    @Output('click') onClick: EventEmitter<MouseEvent> = new EventEmitter(true);\n    @Output('focus') onFocus: EventEmitter<MouseEvent> = new EventEmitter(true);\n    @Output('blur') onBlur: EventEmitter<MouseEvent> = new EventEmitter(true);\n\n    constructor(public elementRef: ElementRef) { }\n\n    ngOnInit(): void { }\n\n    ngOnDestroy(): void {\n        if (this.popoverTrigger) {\n            this.popoverTrigger.destroyPopover();\n        }\n    }\n\n    getHostElement(): any {\n        return this.elementRef.nativeElement;\n    }\n\n    private _hasHostAttributes(...attributes: string[]): boolean {\n        return attributes.some(attribute => this.getHostElement().hasAttribute(attribute));\n    }\n\n    public btnIdAndName(): { btnDefault: string, btnMenu: string } {\n        const uniqueId: number = nextUniqueId++;\n        return {\n            btnDefault: `gipi-split-button-default-${uniqueId}`,\n            btnMenu: `gipi-split-button-menu-${uniqueId}`,\n        }\n    }\n\n    public getInternalButtonClass(isBtnDefault: boolean) {\n        return {\n            'button-default': isBtnDefault,\n            'button-menu': !isBtnDefault,\n            'button-primary': this.isSplitButtonPrimary,\n            'button-secondary': this.isSplitButtonSecondary,\n            'button-tertiary': this.isSplitButtonTertiary,\n            'button-action': this.isSplitButtonAction,\n        };\n    }\n\n    public showPopover(): void {\n        if (this.disabled || this.loading) {\n            return;\n        } else {\n            this.popoverTrigger.openPopover();\n        }\n    }\n\n    public closePopover(): void {\n        if (this.disabled || this.loading) {\n            return;\n        } else {\n            this.popoverTrigger.closePopover();\n        }\n    }\n\n    public handleClick(event: MouseEvent): void {\n        if (this.disabled || this.loading) {\n            return;\n        } else {\n            this.onClick.emit(event);\n            this.closePopover();\n            event.stopPropagation();\n        }\n    }\n\n    public handleFocus(event: MouseEvent): void {\n        if (this.disabled || this.loading) {\n            return;\n        } else {\n            this.onFocus.emit(event);\n            event.stopPropagation();\n        }\n    }\n\n    public handleBlur(event: MouseEvent): void {\n        if (this.disabled || this.loading) {\n            return;\n        } else {\n            this.onBlur.emit(event);\n            event.stopPropagation();\n        }\n    }\n\n    public handleClickBtnMenu(event: MouseEvent): void {\n        if (this.disabled || this.loading) {\n            return;\n        } else {\n            if (!ObjectUtil.isNull(this.popoverTrigger)) {\n                this.popoverTrigger.togglePopover();\n            }\n            event.stopPropagation();\n        }\n    }\n\n    public handleClickBtnSplitOption(option: SplitOptions): void {\n        if (this.disabled || this.loading || !option || option.disabled || !option.clickFn) {\n            return;\n        } else {\n            option.clickFn();\n            this.closePopover();\n        }\n    }\n\n    @HostListener('window:resize', ['$event'])\n    onResize(event: UIEvent): void {\n        if (this.popoverTrigger) {\n            this.popoverTrigger.closePopover();\n            event.stopPropagation();\n        }\n    }\n\n}\n"]}
|
@@ -0,0 +1,18 @@
|
|
1
|
+
import { __decorate, __metadata } from "tslib";
|
2
|
+
import { Directive, ViewContainerRef } from '@angular/core';
|
3
|
+
let GIPIDynamicTabDirective = class GIPIDynamicTabDirective {
|
4
|
+
constructor(viewContainer) {
|
5
|
+
this.viewContainer = viewContainer;
|
6
|
+
}
|
7
|
+
};
|
8
|
+
GIPIDynamicTabDirective.ctorParameters = () => [
|
9
|
+
{ type: ViewContainerRef }
|
10
|
+
];
|
11
|
+
GIPIDynamicTabDirective = __decorate([
|
12
|
+
Directive({
|
13
|
+
selector: '[GIPIDynamicTab]'
|
14
|
+
}),
|
15
|
+
__metadata("design:paramtypes", [ViewContainerRef])
|
16
|
+
], GIPIDynamicTabDirective);
|
17
|
+
export { GIPIDynamicTabDirective };
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy10YWIuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGdpcGlzaXN0ZW1hcy9uZy1jb3JlLyIsInNvdXJjZXMiOlsic2hhcmVkL2dpcGktY29tcG9uZW50cy90YWJzL3NoYXJlZC9keW5hbWljLXRhYi5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFLNUQsSUFBYSx1QkFBdUIsR0FBcEMsTUFBYSx1QkFBdUI7SUFFaEMsWUFBbUIsYUFBK0I7UUFBL0Isa0JBQWEsR0FBYixhQUFhLENBQWtCO0lBQUksQ0FBQztDQUUxRCxDQUFBOztZQUZxQyxnQkFBZ0I7O0FBRnpDLHVCQUF1QjtJQUhuQyxTQUFTLENBQUM7UUFDUCxRQUFRLEVBQUUsa0JBQWtCO0tBQy9CLENBQUM7cUNBR29DLGdCQUFnQjtHQUZ6Qyx1QkFBdUIsQ0FJbkM7U0FKWSx1QkFBdUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbR0lQSUR5bmFtaWNUYWJdJ1xufSlcbmV4cG9ydCBjbGFzcyBHSVBJRHluYW1pY1RhYkRpcmVjdGl2ZSB7XG5cbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgdmlld0NvbnRhaW5lcjogVmlld0NvbnRhaW5lclJlZikgeyB9XG5cbn1cbiJdfQ==
|
@@ -0,0 +1,8 @@
|
|
1
|
+
export class TabModel {
|
2
|
+
constructor() {
|
3
|
+
this.active = false;
|
4
|
+
this.closeable = false;
|
5
|
+
this.disabled = false;
|
6
|
+
}
|
7
|
+
}
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLm1vZGVsLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGdpcGlzaXN0ZW1hcy9uZy1jb3JlLyIsInNvdXJjZXMiOlsic2hhcmVkL2dpcGktY29tcG9uZW50cy90YWJzL3NoYXJlZC90YWIubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxPQUFPLFFBQVE7SUFBckI7UUFJSSxXQUFNLEdBQUcsS0FBSyxDQUFDO1FBSWYsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUVsQixhQUFRLEdBQUcsS0FBSyxDQUFDO0lBVXJCLENBQUM7Q0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBjbGFzcyBUYWJNb2RlbCB7XG5cbiAgICBsYWJlbDogc3RyaW5nO1xuXG4gICAgYWN0aXZlID0gZmFsc2U7XG5cbiAgICB0ZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PjtcblxuICAgIGNsb3NlYWJsZSA9IGZhbHNlO1xuXG4gICAgZGlzYWJsZWQgPSBmYWxzZTtcblxuICAgIGRhdGE6IGFueTtcblxuICAgIGljb246IHN0cmluZztcblxuICAgIHN2Z0ljb246IHN0cmluZztcblxuICAgIGFjdGlvbjogKG9iajogYW55KSA9PiB2b2lkO1xuXG59XG4iXX0=
|
@@ -0,0 +1,66 @@
|
|
1
|
+
import { __decorate, __metadata } from "tslib";
|
2
|
+
import { Component, EventEmitter, Input, Output, TemplateRef } from '@angular/core';
|
3
|
+
let GIPITabComponent = class GIPITabComponent {
|
4
|
+
constructor() {
|
5
|
+
this.active = false;
|
6
|
+
this.closeable = false;
|
7
|
+
this.disabled = false;
|
8
|
+
this.selectionChange = new EventEmitter();
|
9
|
+
}
|
10
|
+
ngOnInit() { }
|
11
|
+
};
|
12
|
+
__decorate([
|
13
|
+
Input(),
|
14
|
+
__metadata("design:type", Number)
|
15
|
+
], GIPITabComponent.prototype, "index", void 0);
|
16
|
+
__decorate([
|
17
|
+
Input(),
|
18
|
+
__metadata("design:type", String)
|
19
|
+
], GIPITabComponent.prototype, "label", void 0);
|
20
|
+
__decorate([
|
21
|
+
Input(),
|
22
|
+
__metadata("design:type", Boolean)
|
23
|
+
], GIPITabComponent.prototype, "active", void 0);
|
24
|
+
__decorate([
|
25
|
+
Input(),
|
26
|
+
__metadata("design:type", TemplateRef)
|
27
|
+
], GIPITabComponent.prototype, "template", void 0);
|
28
|
+
__decorate([
|
29
|
+
Input(),
|
30
|
+
__metadata("design:type", Boolean)
|
31
|
+
], GIPITabComponent.prototype, "closeable", void 0);
|
32
|
+
__decorate([
|
33
|
+
Input(),
|
34
|
+
__metadata("design:type", Boolean)
|
35
|
+
], GIPITabComponent.prototype, "disabled", void 0);
|
36
|
+
__decorate([
|
37
|
+
Input(),
|
38
|
+
__metadata("design:type", Object)
|
39
|
+
], GIPITabComponent.prototype, "data", void 0);
|
40
|
+
__decorate([
|
41
|
+
Input(),
|
42
|
+
__metadata("design:type", String)
|
43
|
+
], GIPITabComponent.prototype, "icon", void 0);
|
44
|
+
__decorate([
|
45
|
+
Input(),
|
46
|
+
__metadata("design:type", String)
|
47
|
+
], GIPITabComponent.prototype, "svgIcon", void 0);
|
48
|
+
__decorate([
|
49
|
+
Output(),
|
50
|
+
__metadata("design:type", EventEmitter)
|
51
|
+
], GIPITabComponent.prototype, "selectionChange", void 0);
|
52
|
+
GIPITabComponent = __decorate([
|
53
|
+
Component({
|
54
|
+
selector: 'gipi-tab',
|
55
|
+
exportAs: 'gipiTab',
|
56
|
+
template: "<ng-container *ngIf=\"active\">\n <ng-content> </ng-content>\n <ng-container *ngIf=\"template\"\n [ngTemplateOutlet]=\"template\"\n [ngTemplateOutletContext]=\"{$implicit: data}\">\n </ng-container>\n</ng-container>",
|
57
|
+
host: {
|
58
|
+
'class': 'gipi-tab',
|
59
|
+
'[style.display]': '!active ? "none" : "block"',
|
60
|
+
},
|
61
|
+
styles: [":host{padding:1.6rem}"]
|
62
|
+
}),
|
63
|
+
__metadata("design:paramtypes", [])
|
64
|
+
], GIPITabComponent);
|
65
|
+
export { GIPITabComponent };
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BnaXBpc2lzdGVtYXMvbmctY29yZS8iLCJzb3VyY2VzIjpbInNoYXJlZC9naXBpLWNvbXBvbmVudHMvdGFicy90YWIvdGFiLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFZNUYsSUFBYSxnQkFBZ0IsR0FBN0IsTUFBYSxnQkFBZ0I7SUF1QnpCO1FBakJTLFdBQU0sR0FBWSxLQUFLLENBQUM7UUFJeEIsY0FBUyxHQUFZLEtBQUssQ0FBQztRQUUzQixhQUFRLEdBQVksS0FBSyxDQUFDO1FBU3pCLG9CQUFlLEdBQXNCLElBQUksWUFBWSxFQUFFLENBQUM7SUFFbEQsQ0FBQztJQUVqQixRQUFRLEtBQVcsQ0FBQztDQUV2QixDQUFBO0FBekJZO0lBQVIsS0FBSyxFQUFFOzsrQ0FBZTtBQUVkO0lBQVIsS0FBSyxFQUFFOzsrQ0FBZTtBQUVkO0lBQVIsS0FBSyxFQUFFOztnREFBeUI7QUFFeEI7SUFBUixLQUFLLEVBQUU7OEJBQVcsV0FBVztrREFBTTtBQUUzQjtJQUFSLEtBQUssRUFBRTs7bURBQTRCO0FBRTNCO0lBQVIsS0FBSyxFQUFFOztrREFBMkI7QUFFMUI7SUFBUixLQUFLLEVBQUU7OzhDQUFXO0FBRVY7SUFBUixLQUFLLEVBQUU7OzhDQUFjO0FBQ2I7SUFBUixLQUFLLEVBQUU7O2lEQUFpQjtBQUlmO0lBQVQsTUFBTSxFQUFFOzhCQUFrQixZQUFZO3lEQUEyQjtBQXJCekQsZ0JBQWdCO0lBVjVCLFNBQVMsQ0FBQztRQUNQLFFBQVEsRUFBRSxVQUFVO1FBQ3BCLFFBQVEsRUFBRSxTQUFTO1FBQ25CLDhRQUFtQztRQUVuQyxJQUFJLEVBQUU7WUFDRixPQUFPLEVBQUUsVUFBVTtZQUNuQixpQkFBaUIsRUFBRSw0QkFBNEI7U0FDbEQ7O0tBQ0osQ0FBQzs7R0FDVyxnQkFBZ0IsQ0EyQjVCO1NBM0JZLGdCQUFnQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQsIFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZ2lwaS10YWInLFxuICAgIGV4cG9ydEFzOiAnZ2lwaVRhYicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3RhYi5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vdGFiLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgaG9zdDoge1xuICAgICAgICAnY2xhc3MnOiAnZ2lwaS10YWInLFxuICAgICAgICAnW3N0eWxlLmRpc3BsYXldJzogJyFhY3RpdmUgPyBcIm5vbmVcIiA6IFwiYmxvY2tcIicsXG4gICAgfSxcbn0pXG5leHBvcnQgY2xhc3MgR0lQSVRhYkNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgICBASW5wdXQoKSBpbmRleDogbnVtYmVyO1xuXG4gICAgQElucHV0KCkgbGFiZWw6IHN0cmluZztcblxuICAgIEBJbnB1dCgpIGFjdGl2ZTogYm9vbGVhbiA9IGZhbHNlO1xuXG4gICAgQElucHV0KCkgdGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT47XG5cbiAgICBASW5wdXQoKSBjbG9zZWFibGU6IGJvb2xlYW4gPSBmYWxzZTtcblxuICAgIEBJbnB1dCgpIGRpc2FibGVkOiBib29sZWFuID0gZmFsc2U7XG5cbiAgICBASW5wdXQoKSBkYXRhOiBhbnk7XG5cbiAgICBASW5wdXQoKSBpY29uOiBzdHJpbmc7XG4gICAgQElucHV0KCkgc3ZnSWNvbjogc3RyaW5nO1xuXG4gICAgYWN0aW9uOiAob2JqOiBhbnkpID0+IHZvaWQ7XG5cbiAgICBAT3V0cHV0KCkgc2VsZWN0aW9uQ2hhbmdlOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICAgIGNvbnN0cnVjdG9yKCkgeyB9XG5cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHsgfVxuXG59XG4iXX0=
|
@@ -0,0 +1,123 @@
|
|
1
|
+
import { __decorate, __metadata } 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
|
+
let GIPITabGroupComponent = class GIPITabGroupComponent {
|
7
|
+
constructor(elementRef, _componentFactoryResolver) {
|
8
|
+
this.elementRef = elementRef;
|
9
|
+
this._componentFactoryResolver = _componentFactoryResolver;
|
10
|
+
this.dynamicTabs = [];
|
11
|
+
}
|
12
|
+
ngOnInit() { }
|
13
|
+
ngAfterContentInit() {
|
14
|
+
const activeTabs = this.tabQueryList.filter(tab => tab.active);
|
15
|
+
if (activeTabs.length === 0 && this.tabQueryList.length > 0) {
|
16
|
+
this.selectTab(this.tabQueryList.first);
|
17
|
+
}
|
18
|
+
}
|
19
|
+
openTab(label, template, data, closeable = false, disabled = false, action) {
|
20
|
+
const tab = new TabModel();
|
21
|
+
tab.label = label;
|
22
|
+
tab.template = template;
|
23
|
+
tab.data = data;
|
24
|
+
tab.closeable = closeable;
|
25
|
+
tab.disabled = disabled;
|
26
|
+
tab.action = action;
|
27
|
+
this._openTabs(Array(tab));
|
28
|
+
}
|
29
|
+
_openTabs(tabList) {
|
30
|
+
const tabsComponent = tabList.map(tab => this._getTabComponent(tab.label, tab.template, tab.data, tab.closeable, tab.disabled, tab.action));
|
31
|
+
this.dynamicTabs.push(...tabsComponent);
|
32
|
+
this.selectTab(this.dynamicTabs[0]);
|
33
|
+
}
|
34
|
+
_getTabComponent(label, template, data, closeable = false, disabled = false, action) {
|
35
|
+
const componentFactory = this._componentFactoryResolver.resolveComponentFactory(GIPITabComponent);
|
36
|
+
const componentRef = this.dynamicTabPlaceholder.viewContainer.createComponent(componentFactory);
|
37
|
+
const instance = componentRef.instance;
|
38
|
+
instance.label = label;
|
39
|
+
instance.template = template;
|
40
|
+
instance.data = data;
|
41
|
+
instance.closeable = closeable;
|
42
|
+
instance.disabled = disabled;
|
43
|
+
instance.action = action;
|
44
|
+
return componentRef.instance;
|
45
|
+
}
|
46
|
+
selectTab(tab) {
|
47
|
+
this.tabQueryList.toArray().forEach(t => (t.active = false));
|
48
|
+
this.dynamicTabs.forEach(t => (t.active = false));
|
49
|
+
tab.active = true;
|
50
|
+
tab.selectionChange.emit();
|
51
|
+
if (tab.action) {
|
52
|
+
tab.action(tab.data);
|
53
|
+
}
|
54
|
+
}
|
55
|
+
closeTab(tab) {
|
56
|
+
const index = this.dynamicTabs.indexOf(tab);
|
57
|
+
this.dynamicTabs.splice(index, 1);
|
58
|
+
const viewContainerRef = this.dynamicTabPlaceholder.viewContainer;
|
59
|
+
viewContainerRef.remove(index);
|
60
|
+
if (this.tabQueryList.length > 0) {
|
61
|
+
this.selectTab(this.tabQueryList.first);
|
62
|
+
}
|
63
|
+
}
|
64
|
+
closeActiveTab() {
|
65
|
+
const activeTabs = this.dynamicTabs.filter(tab => tab.active);
|
66
|
+
if (activeTabs.length > 0) {
|
67
|
+
this.closeTab(activeTabs[0]);
|
68
|
+
}
|
69
|
+
}
|
70
|
+
closeAllTabs() {
|
71
|
+
const tabs = Object.assign([], this.dynamicTabs);
|
72
|
+
if (tabs.length > 0) {
|
73
|
+
tabs.forEach(tab => this.closeTab(tab));
|
74
|
+
}
|
75
|
+
}
|
76
|
+
nextTab() {
|
77
|
+
const currentTab = this.tabQueryList.toArray().find(tab => tab.active);
|
78
|
+
const nextTab = this.tabQueryList.toArray()[this.tabQueryList.toArray().indexOf(currentTab) + 1];
|
79
|
+
if (nextTab != null) {
|
80
|
+
this.tabQueryList.toArray().forEach(t => (t.active = false));
|
81
|
+
this.dynamicTabs.forEach(t => (t.active = false));
|
82
|
+
nextTab.active = true;
|
83
|
+
nextTab.selectionChange.emit();
|
84
|
+
}
|
85
|
+
}
|
86
|
+
previousTab() {
|
87
|
+
const currentTab = this.tabQueryList.toArray().find(tab => tab.active);
|
88
|
+
const previousTab = this.tabQueryList.toArray()[this.tabQueryList.toArray().indexOf(currentTab) - 1];
|
89
|
+
if (previousTab != null) {
|
90
|
+
this.tabQueryList.toArray().forEach(t => (t.active = false));
|
91
|
+
this.dynamicTabs.forEach(t => (t.active = false));
|
92
|
+
previousTab.active = true;
|
93
|
+
previousTab.selectionChange.emit();
|
94
|
+
}
|
95
|
+
}
|
96
|
+
};
|
97
|
+
GIPITabGroupComponent.ctorParameters = () => [
|
98
|
+
{ type: ElementRef },
|
99
|
+
{ type: ComponentFactoryResolver }
|
100
|
+
];
|
101
|
+
__decorate([
|
102
|
+
ContentChildren(GIPITabComponent),
|
103
|
+
__metadata("design:type", QueryList)
|
104
|
+
], GIPITabGroupComponent.prototype, "tabQueryList", void 0);
|
105
|
+
__decorate([
|
106
|
+
ViewChild(GIPIDynamicTabDirective, { static: false }),
|
107
|
+
__metadata("design:type", GIPIDynamicTabDirective)
|
108
|
+
], GIPITabGroupComponent.prototype, "dynamicTabPlaceholder", void 0);
|
109
|
+
GIPITabGroupComponent = __decorate([
|
110
|
+
Component({
|
111
|
+
selector: 'gipi-tab-group',
|
112
|
+
exportAs: 'gipiTabGroup',
|
113
|
+
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>",
|
114
|
+
host: {
|
115
|
+
'class': 'gipi-tab-group',
|
116
|
+
},
|
117
|
+
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}"]
|
118
|
+
}),
|
119
|
+
__metadata("design:paramtypes", [ElementRef,
|
120
|
+
ComponentFactoryResolver])
|
121
|
+
], GIPITabGroupComponent);
|
122
|
+
export { GIPITabGroupComponent };
|
123
|
+
//# 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"]}
|