keevo-components 2.0.46 → 2.0.48
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/keevo-components.mjs +5 -0
- package/esm2022/lib/api/base-components/base-component-button.mjs +39 -0
- package/esm2022/lib/api/base-components/base-component-chart.mjs +104 -0
- package/esm2022/lib/api/base-components/base-component-crud-form.mjs +308 -0
- package/esm2022/lib/api/base-components/base-component-crud-list.mjs +91 -0
- package/esm2022/lib/api/base-components/base-component-crud.mjs +80 -0
- package/esm2022/lib/api/base-components/base-component-dropdown-external.mjs +31 -0
- package/esm2022/lib/api/base-components/base-component-dropdown.mjs +238 -0
- package/esm2022/lib/api/base-components/base-component-input.mjs +101 -0
- package/esm2022/lib/api/base-components/base-component-multi-select.mjs +174 -0
- package/esm2022/lib/api/base-components/base-component-table.mjs +354 -0
- package/esm2022/lib/api/base-components/base-component.mjs +51 -0
- package/esm2022/lib/api/components/chart/chart.config.mjs +2 -0
- package/esm2022/lib/api/components/chart/chart.model.mjs +2 -0
- package/esm2022/lib/api/components/chart/orchart.config.mjs +2 -0
- package/esm2022/lib/api/components/chart/orchartnode.mjs +2 -0
- package/esm2022/lib/api/components/dropdown/filtro.combo.mjs +2 -0
- package/esm2022/lib/api/components/step/step.model.mjs +2 -0
- package/esm2022/lib/api/components/stepper/kv-stepperpanel.mjs +2 -0
- package/esm2022/lib/api/components/table/action-item.mjs +2 -0
- package/esm2022/lib/api/components/table/kv-menuitem.mjs +46 -0
- package/esm2022/lib/api/components/table/table-dropdown-control.mjs +2 -0
- package/esm2022/lib/api/components/table/table.config.column.mjs +2 -0
- package/esm2022/lib/api/components/table/table.config.mjs +2 -0
- package/esm2022/lib/api/components/table/table.paginate.mjs +10 -0
- package/esm2022/lib/api/components/table/tabledit.config.mjs +2 -0
- package/esm2022/lib/api/components/table/tableedit.config.column.mjs +2 -0
- package/esm2022/lib/api/components/tree-table/tree-table-keys.mjs +2 -0
- package/esm2022/lib/api/components/tree-table/tree-table.config.mjs +3 -0
- package/esm2022/lib/api/directives/directives.module.mjs +30 -0
- package/esm2022/lib/api/directives/drag/drag.directive.mjs +52 -0
- package/esm2022/lib/api/directives/stepper/dynamicinput.directive.mjs +31 -0
- package/esm2022/lib/api/directives/template/template.directive.mjs +24 -0
- package/esm2022/lib/api/helpers/component-providers.mjs +16 -0
- package/esm2022/lib/api/helpers/keevo-validators.mjs +144 -0
- package/esm2022/lib/api/helpers/translate-primeng.mjs +23 -0
- package/esm2022/lib/api/modules/primeng.module.mjs +283 -0
- package/esm2022/lib/api/pipes/capitalize.pipe.mjs +47 -0
- package/esm2022/lib/api/pipes/cpfcnpj.pipe.mjs +25 -0
- package/esm2022/lib/api/pipes/mask.pipe.mjs +29 -0
- package/esm2022/lib/api/pipes/pipes.module.mjs +39 -0
- package/esm2022/lib/api/pipes/telefone.pipe.mjs +45 -0
- package/esm2022/lib/api/services/base.api.service.mjs +74 -0
- package/esm2022/lib/api/services/breadcrumbs.service.mjs +62 -0
- package/esm2022/lib/api/services/chat.service.mjs +37 -0
- package/esm2022/lib/api/services/component.service.mjs +37 -0
- package/esm2022/lib/api/services/docs.service.mjs +129 -0
- package/esm2022/lib/api/services/form.service.mjs +95 -0
- package/esm2022/lib/api/services/image.cutter.service.mjs +191 -0
- package/esm2022/lib/api/services/imagens.service.mjs +28 -0
- package/esm2022/lib/api/services/notification.service.mjs +69 -0
- package/esm2022/lib/api/services/object.service.mjs +39 -0
- package/esm2022/lib/api/services/orgchart.service.mjs +64 -0
- package/esm2022/lib/api/types/breadcrumb.model.mjs +2 -0
- package/esm2022/lib/components/keevo-components.module.mjs +214 -0
- package/esm2022/lib/components/kv-avatar/kv-avatar.component.mjs +133 -0
- package/esm2022/lib/components/kv-avatar/kv-avatar.module.mjs +55 -0
- package/esm2022/lib/components/kv-button/kv-button.component.mjs +51 -0
- package/esm2022/lib/components/kv-button/kv-button.module.mjs +28 -0
- package/esm2022/lib/components/kv-buttons/kv-button-personalize/kv-button-personalize.component.mjs +25 -0
- package/esm2022/lib/components/kv-buttons/kv-button-popup/kv-button-popup.component.mjs +39 -0
- package/esm2022/lib/components/kv-buttons/kv-button-secondary/kv-button-secondary.component.mjs +17 -0
- package/esm2022/lib/components/kv-buttons/kv-button-success/kv-button-success.component.mjs +17 -0
- package/esm2022/lib/components/kv-buttons/kv-button.module.mjs +39 -0
- package/esm2022/lib/components/kv-card-selection/kv-card-selection.component.mjs +60 -0
- package/esm2022/lib/components/kv-card-selection/kv-card-selection.module.mjs +31 -0
- package/esm2022/lib/components/kv-carousel/kv-carousel.component.mjs +34 -0
- package/esm2022/lib/components/kv-carousel/kv-carousel.module.mjs +28 -0
- package/esm2022/lib/components/kv-chart/kv-chart.component.mjs +166 -0
- package/esm2022/lib/components/kv-chart/kv-chart.module.mjs +32 -0
- package/esm2022/lib/components/kv-content-viewer/kv-content-viewer.component.mjs +185 -0
- package/esm2022/lib/components/kv-content-viewer/kv-content-viewer.module.mjs +44 -0
- package/esm2022/lib/components/kv-error/kv-error.component.mjs +26 -0
- package/esm2022/lib/components/kv-error/kv-error.module.mjs +35 -0
- package/esm2022/lib/components/kv-file-upload/kv-file-upload.component.mjs +162 -0
- package/esm2022/lib/components/kv-file-upload/kv-file-upload.module.mjs +18 -0
- package/esm2022/lib/components/kv-file-viewer/kv-file-viewer.component.mjs +46 -0
- package/esm2022/lib/components/kv-file-viewer/kv-file-viewer.module.mjs +20 -0
- package/esm2022/lib/components/kv-file-viewer-novo/kv-file-viewer-novo.component.mjs +68 -0
- package/esm2022/lib/components/kv-file-viewer-novo/kv-file-viewer-novo.module.mjs +24 -0
- package/esm2022/lib/components/kv-filter-card/kv-filter-card.component.mjs +29 -0
- package/esm2022/lib/components/kv-filter-card/kv-filter-card.module.mjs +34 -0
- package/esm2022/lib/components/kv-filter-fieldset/kv-filter-fieldset.component.mjs +26 -0
- package/esm2022/lib/components/kv-filter-fieldset/kv-filter-fieldset.module.mjs +28 -0
- package/esm2022/lib/components/kv-g-icon/kv-g-icon.component.mjs +11 -0
- package/esm2022/lib/components/kv-g-icon/kv-g-icon.module.mjs +19 -0
- package/esm2022/lib/components/kv-home-card/kv-home-card.component.mjs +27 -0
- package/esm2022/lib/components/kv-home-card/kv-home-card.module.mjs +32 -0
- package/esm2022/lib/components/kv-image-upload/kv-image-upload.component.mjs +135 -0
- package/esm2022/lib/components/kv-image-upload/kv-image-upload.module.mjs +18 -0
- package/esm2022/lib/components/kv-inputs/kv-check/kv-check.component.mjs +29 -0
- package/esm2022/lib/components/kv-inputs/kv-dropdown/kv-dropdown.component.mjs +102 -0
- package/esm2022/lib/components/kv-inputs/kv-editor/kv-editor.component.mjs +181 -0
- package/esm2022/lib/components/kv-inputs/kv-input-calendar/kv-input-calendar.component.mjs +168 -0
- package/esm2022/lib/components/kv-inputs/kv-input-mask/kv-input-mask.component.mjs +30 -0
- package/esm2022/lib/components/kv-inputs/kv-input-number/kv-input-number.component.mjs +59 -0
- package/esm2022/lib/components/kv-inputs/kv-input-number-addon/kv-input-number-addon.component.mjs +66 -0
- package/esm2022/lib/components/kv-inputs/kv-input-password/kv-input-password.component.mjs +33 -0
- package/esm2022/lib/components/kv-inputs/kv-input-text/kv-input-text.component.mjs +38 -0
- package/esm2022/lib/components/kv-inputs/kv-input-text-addon/kv-input-text-addon.component.mjs +42 -0
- package/esm2022/lib/components/kv-inputs/kv-input-text-checkbox/kv-input-text-checkbox.component.mjs +50 -0
- package/esm2022/lib/components/kv-inputs/kv-input-textarea/kv-input-textarea.component.mjs +43 -0
- package/esm2022/lib/components/kv-inputs/kv-input-time/kv-input-time.component.mjs +24 -0
- package/esm2022/lib/components/kv-inputs/kv-inputs.module.mjs +141 -0
- package/esm2022/lib/components/kv-inputs/kv-multi-select/kv-multi-select.component.mjs +60 -0
- package/esm2022/lib/components/kv-inputs/kv-radio-group/kv-radio-group.component.mjs +60 -0
- package/esm2022/lib/components/kv-inputs/kv-select-button/kv-select-button.component.mjs +46 -0
- package/esm2022/lib/components/kv-inputs/kv-select-buttons/kv-select-buttons.component.mjs +37 -0
- package/esm2022/lib/components/kv-inputs/kv-switch/kv-switch.component.mjs +42 -0
- package/esm2022/lib/components/kv-inputs/kv-tree-multi-select/kv-tree-multi-select.component.mjs +58 -0
- package/esm2022/lib/components/kv-label/kv-label.component.mjs +15 -0
- package/esm2022/lib/components/kv-label/kv-label.module.mjs +24 -0
- package/esm2022/lib/components/kv-layout/dropdown-master/dropdown-master.component.mjs +28 -0
- package/esm2022/lib/components/kv-layout/kv-layout.module.mjs +72 -0
- package/esm2022/lib/components/kv-layout/layout/kv-layout.component.mjs +433 -0
- package/esm2022/lib/components/kv-layout/top-icons/top-icons.component.mjs +15 -0
- package/esm2022/lib/components/kv-loader/kv-loader.component.mjs +16 -0
- package/esm2022/lib/components/kv-loader/kv-loader.module.mjs +28 -0
- package/esm2022/lib/components/kv-loader/kv-loader.service.mjs +29 -0
- package/esm2022/lib/components/kv-login/kv-login.component.mjs +62 -0
- package/esm2022/lib/components/kv-login/kv-login.module.mjs +47 -0
- package/esm2022/lib/components/kv-modal/kv-modal.component.mjs +98 -0
- package/esm2022/lib/components/kv-modal/kv-modal.module.mjs +20 -0
- package/esm2022/lib/components/kv-orgchart/kv-orgchart.component.mjs +225 -0
- package/esm2022/lib/components/kv-orgchart/kv-orgchart.module.mjs +59 -0
- package/esm2022/lib/components/kv-page-form/kv-page-form.component.mjs +215 -0
- package/esm2022/lib/components/kv-page-form/kv-page-form.module.mjs +41 -0
- package/esm2022/lib/components/kv-page-stepper/kv-page-stepper.component.mjs +205 -0
- package/esm2022/lib/components/kv-page-stepper/kv-page-stepper.module.mjs +51 -0
- package/esm2022/lib/components/kv-pick-list/kv-pick-list.component.mjs +375 -0
- package/esm2022/lib/components/kv-pick-list/kv-pick-list.module.mjs +39 -0
- package/esm2022/lib/components/kv-progress-bar/kv-progress-bar.component.mjs +58 -0
- package/esm2022/lib/components/kv-progress-bar/kv-progress-bar.module.mjs +28 -0
- package/esm2022/lib/components/kv-progress-bar-alternative/kv-progress-bar-alternative.component.mjs +62 -0
- package/esm2022/lib/components/kv-progress-bar-alternative/kv-progress-bar-alternative.module.mjs +28 -0
- package/esm2022/lib/components/kv-report/kv-report.component.mjs +44 -0
- package/esm2022/lib/components/kv-report/kv-report.module.mjs +24 -0
- package/esm2022/lib/components/kv-stepper/kv-stepper.component.mjs +74 -0
- package/esm2022/lib/components/kv-stepper/kv-stepper.module.mjs +47 -0
- package/esm2022/lib/components/kv-steps/kv-steps.component.mjs +105 -0
- package/esm2022/lib/components/kv-table/kv-table.component.mjs +673 -0
- package/esm2022/lib/components/kv-table/kv-table.module.mjs +40 -0
- package/esm2022/lib/components/kv-table-edit/kv-table-edit.component.mjs +323 -0
- package/esm2022/lib/components/kv-table-edit/kv-table-edit.module.mjs +45 -0
- package/esm2022/lib/components/kv-table-expandable/kv-table-expandable.component.mjs +516 -0
- package/esm2022/lib/components/kv-table-expandable/kv-table-expandable.module.mjs +40 -0
- package/esm2022/lib/components/kv-tag/kv-tag.component.mjs +18 -0
- package/esm2022/lib/components/kv-tag/kv-tag.module.mjs +24 -0
- package/esm2022/lib/components/kv-tree-table/kv-tree-table.component.mjs +331 -0
- package/esm2022/lib/components/kv-tree-table/kv-tree-table.module.mjs +39 -0
- package/esm2022/lib/components/kv-tree-view/kv-tree-view.component.mjs +70 -0
- package/esm2022/lib/components/kv-tree-view/kv-tree-view.module.mjs +28 -0
- package/esm2022/lib/components/kv-workspace/empresa/kv-workspace-empresa.component.mjs +40 -0
- package/esm2022/lib/components/kv-workspace/kv-workspace.module.mjs +68 -0
- package/esm2022/lib/components/kv-workspace/logo/kv-workspace-logo.component.mjs +22 -0
- package/esm2022/lib/components/kv-workspace/master/kv-workspace-master.component.mjs +78 -0
- package/esm2022/lib/components/kv-workspace/workspace/kv-workspace.component.mjs +87 -0
- package/esm2022/public-api.mjs +269 -0
- package/fesm2022/keevo-components.mjs +250 -19
- package/fesm2022/keevo-components.mjs.map +1 -1
- package/lib/components/kv-button/kv-button.component.d.ts +1 -1
- package/lib/components/kv-pick-list/kv-pick-list.component.d.ts +21 -1
- package/lib/components/kv-tag/kv-tag.component.d.ts +1 -1
- package/package.json +3 -1
|
@@ -0,0 +1,375 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { PickList } from 'primeng/picklist';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/forms";
|
|
5
|
+
import * as i2 from "@angular/common";
|
|
6
|
+
import * as i3 from "primeng/api";
|
|
7
|
+
import * as i4 from "primeng/picklist";
|
|
8
|
+
import * as i5 from "../kv-inputs/kv-check/kv-check.component";
|
|
9
|
+
export class KvPickListComponent {
|
|
10
|
+
constructor(fb) {
|
|
11
|
+
this.fb = fb;
|
|
12
|
+
this.itemIdField = 'id';
|
|
13
|
+
this.breakpoint = "1400px";
|
|
14
|
+
this.dragdrop = true;
|
|
15
|
+
this.responsive = true;
|
|
16
|
+
this.sourceHeader = 'Título da lista de origem';
|
|
17
|
+
this.stripedRows = false;
|
|
18
|
+
this.targetHeader = 'Título de lista de destino';
|
|
19
|
+
this.showSourceControls = true;
|
|
20
|
+
this.showTargetControls = true;
|
|
21
|
+
this.showCheckBox = false;
|
|
22
|
+
this.onMoveToSource = new EventEmitter();
|
|
23
|
+
this.onMoveToTarget = new EventEmitter();
|
|
24
|
+
this.onMoveAllToSource = new EventEmitter();
|
|
25
|
+
this.onMoveAllToTarget = new EventEmitter();
|
|
26
|
+
this.onSourceSelect = new EventEmitter();
|
|
27
|
+
this.onTargetSelect = new EventEmitter();
|
|
28
|
+
this.ngModel = false;
|
|
29
|
+
this.selectedItems = {};
|
|
30
|
+
this.ultimoItemSelecionado = [];
|
|
31
|
+
this.lastDraggedItems = [];
|
|
32
|
+
this.draggedIds = [];
|
|
33
|
+
this.mouseX = 0;
|
|
34
|
+
this.mouseY = 0;
|
|
35
|
+
this.previewClones = [];
|
|
36
|
+
document.addEventListener('keydown', (event) => this.onKeyDown(event));
|
|
37
|
+
}
|
|
38
|
+
ngOnInit() {
|
|
39
|
+
document.addEventListener('mousemove', (event) => {
|
|
40
|
+
this.mouseX = event.clientX;
|
|
41
|
+
this.mouseY = event.clientY;
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
ngAfterViewInit() {
|
|
45
|
+
this.createDropOverlay();
|
|
46
|
+
}
|
|
47
|
+
createDropOverlay() {
|
|
48
|
+
this.dropOverlay = document.createElement('div');
|
|
49
|
+
this.dropOverlay.innerText = 'Soltar';
|
|
50
|
+
this.dropOverlay.style.position = 'fixed';
|
|
51
|
+
this.dropOverlay.style.background = '#BFDBFE'; // Azul claro visível
|
|
52
|
+
this.dropOverlay.style.color = '#1E3A8A'; // Azul escuro pro texto
|
|
53
|
+
this.dropOverlay.style.border = '9px #1E40AF'; // Borda azul escuro
|
|
54
|
+
this.dropOverlay.style.boxShadow = '0 2px 6px rgba(30, 58, 138, 0.2)'; // Shadow reduzida
|
|
55
|
+
this.dropOverlay.style.display = 'none';
|
|
56
|
+
this.dropOverlay.style.justifyContent = 'center';
|
|
57
|
+
this.dropOverlay.style.alignItems = 'center';
|
|
58
|
+
this.dropOverlay.style.zIndex = '9999';
|
|
59
|
+
this.dropOverlay.style.fontSize = '1.5rem';
|
|
60
|
+
this.dropOverlay.style.fontWeight = 'bold';
|
|
61
|
+
this.dropOverlay.style.pointerEvents = 'all';
|
|
62
|
+
this.dropOverlay.style.transition = 'all 0.2s ease';
|
|
63
|
+
// Encaixar no mesmo lugar do target
|
|
64
|
+
const targetListEl = document.querySelector('.p-picklist-target');
|
|
65
|
+
if (targetListEl) {
|
|
66
|
+
const rect = targetListEl.getBoundingClientRect();
|
|
67
|
+
this.dropOverlay.style.top = rect.top + 'px';
|
|
68
|
+
this.dropOverlay.style.left = rect.left + 'px';
|
|
69
|
+
this.dropOverlay.style.width = rect.width + 'px';
|
|
70
|
+
this.dropOverlay.style.height = rect.height + 'px';
|
|
71
|
+
}
|
|
72
|
+
this.dropOverlay.addEventListener('click', () => {
|
|
73
|
+
const selectedInSource = this.source.some(item => this.selectedItems[item[this.itemIdField]]);
|
|
74
|
+
const selectedInTarget = this.target.some(item => this.selectedItems[item[this.itemIdField]]);
|
|
75
|
+
if (selectedInSource) {
|
|
76
|
+
this.OnMoveToTarget({});
|
|
77
|
+
}
|
|
78
|
+
else if (selectedInTarget) {
|
|
79
|
+
this.OnMoveToSource({});
|
|
80
|
+
}
|
|
81
|
+
this.hideDropOverlay();
|
|
82
|
+
});
|
|
83
|
+
this.dropOverlay.addEventListener('mouseenter', () => {
|
|
84
|
+
this.dropOverlay.style.background = '#93C5FD'; // Azul um pouco mais escuro no hover
|
|
85
|
+
});
|
|
86
|
+
this.dropOverlay.addEventListener('mouseleave', () => {
|
|
87
|
+
this.dropOverlay.style.background = '#BFDBFE';
|
|
88
|
+
});
|
|
89
|
+
document.body.appendChild(this.dropOverlay);
|
|
90
|
+
}
|
|
91
|
+
handleMouseMove(event) {
|
|
92
|
+
this.mouseX = event.clientX;
|
|
93
|
+
this.mouseY = event.clientY;
|
|
94
|
+
}
|
|
95
|
+
clearPreviewClones() {
|
|
96
|
+
this.previewClones.forEach(clone => clone.remove());
|
|
97
|
+
this.previewClones = [];
|
|
98
|
+
}
|
|
99
|
+
OnMoveToSource(event) {
|
|
100
|
+
this.clearPreviewClones();
|
|
101
|
+
this.picklist.moveLeft();
|
|
102
|
+
this.onMoveToSource.emit(event);
|
|
103
|
+
this.selectedItems = {};
|
|
104
|
+
this.hideDropOverlay();
|
|
105
|
+
this.clearPreviewClones();
|
|
106
|
+
}
|
|
107
|
+
OnMoveToTarget(event) {
|
|
108
|
+
this.clearPreviewClones();
|
|
109
|
+
this.picklist.moveRight();
|
|
110
|
+
this.onMoveToTarget.emit(event);
|
|
111
|
+
this.selectedItems = {};
|
|
112
|
+
this.hideDropOverlay();
|
|
113
|
+
this.clearPreviewClones();
|
|
114
|
+
}
|
|
115
|
+
getSelectedItems() {
|
|
116
|
+
// Filtra os itens da lista de origem (source) com base nos itens selecionados
|
|
117
|
+
return this.source.filter(item => {
|
|
118
|
+
const itemId = item[this.itemIdField]; // Obtém o ID do item
|
|
119
|
+
return this.selectedItems[itemId] === true; // Verifica se está marcado como true
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
OnMoveAllToSource(event) {
|
|
123
|
+
this.onMoveToSource.emit(event);
|
|
124
|
+
this.selectedItems = {};
|
|
125
|
+
this.hideDropOverlay();
|
|
126
|
+
this.clearPreviewClones();
|
|
127
|
+
}
|
|
128
|
+
OnMoveAllToTarget(event) {
|
|
129
|
+
this.onMoveToTarget.emit(event);
|
|
130
|
+
this.selectedItems = {};
|
|
131
|
+
this.hideDropOverlay();
|
|
132
|
+
this.clearPreviewClones();
|
|
133
|
+
}
|
|
134
|
+
OnSourceSelect(event) {
|
|
135
|
+
const selectedItems = this.getSelectedItems();
|
|
136
|
+
// Primeiro remove todos os previews antigos
|
|
137
|
+
this.clearPreviewClones();
|
|
138
|
+
if (selectedItems.length === 0) {
|
|
139
|
+
this.hideDropOverlay();
|
|
140
|
+
this.onSourceSelect.emit(event);
|
|
141
|
+
return;
|
|
142
|
+
}
|
|
143
|
+
selectedItems.forEach((item, index) => {
|
|
144
|
+
const itemId = item[this.itemIdField];
|
|
145
|
+
// Se já existe um clone para esse item, não cria novamente
|
|
146
|
+
if (!document.getElementById('preview_' + itemId)) {
|
|
147
|
+
const original = document.getElementById('id_pick_list' + itemId);
|
|
148
|
+
if (original) {
|
|
149
|
+
const rect = original.getBoundingClientRect();
|
|
150
|
+
const clone = original.cloneNode(true);
|
|
151
|
+
clone.classList.add('drag-preview-clone');
|
|
152
|
+
clone.classList.add(`level-${index + 1}`);
|
|
153
|
+
clone.id = 'preview_' + itemId;
|
|
154
|
+
document.body.appendChild(clone);
|
|
155
|
+
this.previewClones.push(clone);
|
|
156
|
+
this.animateCloneToCursor(clone, rect);
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
});
|
|
160
|
+
this.showDropOverlay();
|
|
161
|
+
this.onSourceSelect.emit(event);
|
|
162
|
+
}
|
|
163
|
+
getItemId(item) {
|
|
164
|
+
return item?.[this.itemIdField];
|
|
165
|
+
}
|
|
166
|
+
showDropOverlay() {
|
|
167
|
+
const selectedInSource = this.source.some(item => this.selectedItems[item[this.itemIdField]]);
|
|
168
|
+
const selectedInTarget = this.target.some(item => this.selectedItems[item[this.itemIdField]]);
|
|
169
|
+
let targetListEl = null;
|
|
170
|
+
if (selectedInSource) {
|
|
171
|
+
// Itens selecionados na lista da esquerda → overlay no lado direito
|
|
172
|
+
targetListEl = document.querySelector('.p-picklist-target');
|
|
173
|
+
this.dropOverlay.innerText = 'Soltar aqui para mover';
|
|
174
|
+
}
|
|
175
|
+
else if (selectedInTarget) {
|
|
176
|
+
// Itens selecionados na lista da direita → overlay no lado esquerdo
|
|
177
|
+
targetListEl = document.querySelector('.p-picklist-source');
|
|
178
|
+
this.dropOverlay.innerText = 'Soltar aqui para retornar';
|
|
179
|
+
}
|
|
180
|
+
if (targetListEl) {
|
|
181
|
+
const rect = targetListEl.getBoundingClientRect();
|
|
182
|
+
this.dropOverlay.style.top = rect.top + 'px';
|
|
183
|
+
this.dropOverlay.style.left = rect.left + 'px';
|
|
184
|
+
this.dropOverlay.style.width = rect.width + 'px';
|
|
185
|
+
this.dropOverlay.style.height = rect.height + 'px';
|
|
186
|
+
this.dropOverlay.style.display = 'flex';
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
hideDropOverlay() {
|
|
190
|
+
if (this.dropOverlay) {
|
|
191
|
+
this.dropOverlay.style.display = 'none';
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
animateCloneToCursor(clone, originRect) {
|
|
195
|
+
// Começa exatamente da posição do original
|
|
196
|
+
let posX = originRect.left;
|
|
197
|
+
let posY = originRect.top;
|
|
198
|
+
clone.style.position = 'fixed';
|
|
199
|
+
clone.style.left = `${posX}px`;
|
|
200
|
+
clone.style.top = `${posY}px`;
|
|
201
|
+
clone.style.width = `${originRect.width}px`;
|
|
202
|
+
clone.style.height = `${originRect.height}px`;
|
|
203
|
+
clone.style.pointerEvents = 'none';
|
|
204
|
+
const animate = () => {
|
|
205
|
+
const dx = this.mouseX - posX;
|
|
206
|
+
const dy = this.mouseY - posY;
|
|
207
|
+
posX += dx * 0.15;
|
|
208
|
+
posY += dy * 0.15;
|
|
209
|
+
clone.style.left = `${posX}px`;
|
|
210
|
+
clone.style.top = `${posY}px`;
|
|
211
|
+
if (document.body.contains(clone)) {
|
|
212
|
+
requestAnimationFrame(animate);
|
|
213
|
+
}
|
|
214
|
+
};
|
|
215
|
+
animate();
|
|
216
|
+
}
|
|
217
|
+
OnTargetSelect(event) {
|
|
218
|
+
const selectedItems = this.target.filter(item => {
|
|
219
|
+
const itemId = item[this.itemIdField];
|
|
220
|
+
return this.selectedItems[itemId] === true;
|
|
221
|
+
});
|
|
222
|
+
// Limpa clones antigos
|
|
223
|
+
this.clearPreviewClones();
|
|
224
|
+
if (selectedItems.length === 0) {
|
|
225
|
+
this.hideDropOverlay();
|
|
226
|
+
this.onTargetSelect.emit(event);
|
|
227
|
+
return;
|
|
228
|
+
}
|
|
229
|
+
selectedItems.forEach((item, index) => {
|
|
230
|
+
const itemId = item[this.itemIdField];
|
|
231
|
+
if (!document.getElementById('preview_' + itemId)) {
|
|
232
|
+
const original = document.getElementById('id_pick_list' + itemId);
|
|
233
|
+
if (original) {
|
|
234
|
+
const rect = original.getBoundingClientRect();
|
|
235
|
+
const clone = original.cloneNode(true);
|
|
236
|
+
clone.classList.add('drag-preview-clone');
|
|
237
|
+
clone.classList.add(`level-${index + 1}`);
|
|
238
|
+
clone.id = 'preview_' + itemId;
|
|
239
|
+
document.body.appendChild(clone);
|
|
240
|
+
this.previewClones.push(clone);
|
|
241
|
+
this.animateCloneToCursor(clone, rect);
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
});
|
|
245
|
+
this.showDropOverlay();
|
|
246
|
+
this.onTargetSelect.emit(event);
|
|
247
|
+
}
|
|
248
|
+
onSelectAll() {
|
|
249
|
+
this.selectAllItems(true);
|
|
250
|
+
}
|
|
251
|
+
selectAllItems(isSelected) {
|
|
252
|
+
this.source.forEach(item => {
|
|
253
|
+
const itemId = item[this.itemIdField];
|
|
254
|
+
this.selectedItems[itemId] = isSelected;
|
|
255
|
+
});
|
|
256
|
+
this.target.forEach(item => {
|
|
257
|
+
const itemId = item[this.itemIdField];
|
|
258
|
+
this.selectedItems[itemId] = isSelected;
|
|
259
|
+
});
|
|
260
|
+
}
|
|
261
|
+
onKeyDown(event) {
|
|
262
|
+
if (event.ctrlKey && event.key === 'a') {
|
|
263
|
+
event.preventDefault();
|
|
264
|
+
this.onSelectAll();
|
|
265
|
+
}
|
|
266
|
+
else if (event.key === 'Enter') {
|
|
267
|
+
const sourceSelected = this.picklist.selectedItemsSource;
|
|
268
|
+
const selectedItemsIds = Object.entries(this.selectedItems)
|
|
269
|
+
.filter(([_, value]) => value === true)
|
|
270
|
+
.map(([key, _]) => Number(key));
|
|
271
|
+
const notInSelected = sourceSelected.find((item) => !selectedItemsIds.includes(item[this.itemIdField]));
|
|
272
|
+
const indexInSource = this.source.findIndex((item) => item[this.itemIdField] === notInSelected?.[this.itemIdField]);
|
|
273
|
+
const ultimoItemArray = {
|
|
274
|
+
item: notInSelected,
|
|
275
|
+
index: indexInSource,
|
|
276
|
+
};
|
|
277
|
+
const selectedIndexInSource = this.source.findIndex((sourceItem) => selectedItemsIds.includes(sourceItem[this.itemIdField]));
|
|
278
|
+
if (notInSelected === undefined) {
|
|
279
|
+
const beforeIds = this.ultimoItemSelecionado.map(i => i.item[this.itemIdField]);
|
|
280
|
+
const afterIds = this.picklist.selectedItemsSource.map(i => i[this.itemIdField]);
|
|
281
|
+
const removedId = beforeIds.find(id => !afterIds.includes(id));
|
|
282
|
+
if (removedId != null) {
|
|
283
|
+
const removedItem = this.source.find(item => item[this.itemIdField] === removedId);
|
|
284
|
+
if (removedItem) {
|
|
285
|
+
this.selectCheckBox(removedItem);
|
|
286
|
+
this.ultimoItemSelecionado = this.ultimoItemSelecionado.filter((i) => i.item[this.itemIdField] !== removedId);
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
else {
|
|
290
|
+
const enterIds = this.ultimoItemSelecionado.map(i => i.item[this.itemIdField]);
|
|
291
|
+
const selectedItemsIds = Object.entries(this.selectedItems)
|
|
292
|
+
.filter(([_, value]) => value === true)
|
|
293
|
+
.map(([key, _]) => Number(key));
|
|
294
|
+
const clickedIds = selectedItemsIds.filter(id => !enterIds.includes(id));
|
|
295
|
+
if (clickedIds.length > 0) {
|
|
296
|
+
const clickedItem = this.source.find(item => item[this.itemIdField] === clickedIds[0]);
|
|
297
|
+
if (clickedItem) {
|
|
298
|
+
this.selectCheckBox(clickedItem);
|
|
299
|
+
this.ultimoItemSelecionado = this.ultimoItemSelecionado.filter((i) => i.item[this.itemIdField] !== clickedIds[0]);
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
return;
|
|
304
|
+
}
|
|
305
|
+
this.selectCheckBox(notInSelected);
|
|
306
|
+
this.ultimoItemSelecionado = this.ultimoItemSelecionado.filter((item) => item.index !== indexInSource);
|
|
307
|
+
this.ultimoItemSelecionado.push(ultimoItemArray);
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
selectCheckBox(item) {
|
|
311
|
+
const itemId = item[this.itemIdField];
|
|
312
|
+
this.selectedPreview = item;
|
|
313
|
+
this.selectedItems[itemId] = this.selectedItems[itemId] !== undefined
|
|
314
|
+
? !this.selectedItems[itemId]
|
|
315
|
+
: true;
|
|
316
|
+
this.ngModel = this.selectedItems[itemId];
|
|
317
|
+
}
|
|
318
|
+
isItemSelected(item) {
|
|
319
|
+
return this.selectedPreview === item;
|
|
320
|
+
}
|
|
321
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvPickListComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
322
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvPickListComponent, selector: "kv-picklist", inputs: { itemIdField: "itemIdField", breakpoint: "breakpoint", dragdrop: "dragdrop", filterBy: "filterBy", itemTemplate: "itemTemplate", responsive: "responsive", source: "source", sourceHeader: "sourceHeader", sourceStyle: "sourceStyle", stripedRows: "stripedRows", target: "target", targetHeader: "targetHeader", targetStyle: "targetStyle", showSourceControls: "showSourceControls", showTargetControls: "showTargetControls", showCheckBox: "showCheckBox" }, outputs: { onMoveToSource: "onMoveToSource", onMoveToTarget: "onMoveToTarget", onMoveAllToSource: "onMoveAllToSource", onMoveAllToTarget: "onMoveAllToTarget", onSourceSelect: "onSourceSelect", onTargetSelect: "onTargetSelect" }, viewQueries: [{ propertyName: "picklist", first: true, predicate: PickList, descendants: true }], ngImport: i0, template: "<p-pickList\r\n [source]=\"source\"\r\n [sourceHeader]=\"sourceHeader\"\r\n [sourceStyle]=\"sourceStyle\"\r\n [target]=\"target\" \r\n [targetHeader]=\"targetHeader\"\r\n [targetStyle]=\"targetStyle\"\r\n [dragdrop]=\"dragdrop\"\r\n [responsive]=\"responsive\"\r\n [filterBy]=\"filterBy\"\r\n [breakpoint]=\"breakpoint\"\r\n [stripedRows]=\"stripedRows\"\r\n [showSourceControls]=\"showSourceControls\"\r\n [showTargetControls]=\"showTargetControls\"\r\n (onMoveToSource)=\"OnMoveToSource($event)\"\r\n (onMoveToTarget)=\"OnMoveToTarget($event)\"\r\n (onMoveAllToSource)=\"OnMoveAllToSource($event)\"\r\n (onMoveAllToTarget)=\"OnMoveAllToTarget($event)\"\r\n (onSourceSelect)=\"OnSourceSelect($event)\"\r\n (onTargetSelect)=\"OnTargetSelect($event)\"\r\n>\r\n <ng-template let-item pTemplate=\"item\" *ngIf=\"itemTemplate\" >\r\n <div (click)=\"selectCheckBox(item)\" class=\"flex mr-5\" [id]=\"'id_pick_list' + getItemId(item)\"\r\n >\r\n <ng-container [ngTemplateOutlet]=\"itemTemplate\" [ngTemplateOutletContext]=\"{ $implicit: item }\">\r\n @if(showCheckBox) {\r\n <kv-check (onCheckChange)=\"selectCheckBox(item)\" [(ngModel)]=\"selectedItems[item[itemIdField]]\" class=\"mr-1\"></kv-check>\r\n }\r\n </ng-container>\r\n </div> \r\n </ng-template>\r\n</p-pickList>\r\n", styles: ["@charset \"UTF-8\";:host ::ng-deep .p-picklist .p-picklist-filter-container{position:sticky!important;top:0!important;z-index:99!important}:host ::ng-deep .p-picklist .p-picklist-filter-container{border-left:0px;border-right:0px}.item-with-checkbox{display:flex;align-items:center}.item-with-checkbox kv-check{margin-right:8px}@keyframes shake-base{0%{transform:translate(0)}25%{transform:translate(1px,-1px)}50%{transform:translate(-1px,1px)}75%{transform:translate(1px,1px)}to{transform:translate(-1px,-1px)}}.drag-preview-clone{animation-name:shake-base;animation-duration:.25s;animation-iteration-count:infinite;animation-timing-function:ease-in-out;position:fixed;z-index:9999;opacity:.85;pointer-events:none;transition:transform .1s ease;box-shadow:0 10px 20px #0003;border-radius:6px;padding:8px;background-color:#fff}.drag-preview-clone.level-1{margin-top:.5rem}.drag-preview-clone.level-2{margin-bottom:1rem}.drag-preview-clone.level-3{margin-left:.5rem}\n", "@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,400,0,0\";::ng-deep :root{--kv-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255;--kv-primary-color: 41, 185, 45;--kv-secondary-color: 0, 37, 66;--kv-tertiary-color: 165, 165, 165}::ng-deep .padrao{--kv-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-keevocenter{--kv-color-system: 88,25,153;--kv-color-system-cta: 0, 116, 217;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-holos{--kv-color-system: 241,90,36;--kv-color-system-cta: 224, 168, 35;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 240,240,240;--kv-background-card: 2255,255,255}.system-color{color:rgb(var(--kv-color-system),1)}.bg-system-100{background:rgb(var(--kv-color-system),1)}.bg-system-75{background:rgb(var(--kv-color-system),.75)}.bg-system-50{background:rgb(var(--kv-color-system),.5)}.bg-system-25{background:rgb(var(--kv-color-system),.25)}.material-symbols-outlined{font-family:Material Symbols Outlined!important}*{font-family:Inter,Inter var,sans-serif!important}::ng-deep .p-accordion,::ng-deep .p-accordion-header,::ng-deep .p-accordion-content,::ng-deep .p-badge,::ng-deep .p-overlay-badge,::ng-deep .p-breadcrumb,::ng-deep .p-breadcrumb-item,::ng-deep .p-breadcrumb-link,::ng-deep .p-button,::ng-deep .p-calendar,::ng-deep .p-card,::ng-deep .p-card-title,::ng-deep .p-card-subtitle,::ng-deep .p-card-content,::ng-deep .p-checkbox,::ng-deep .p-chip,::ng-deep .p-confirm-dialog,::ng-deep .p-confirm-dialog-message,::ng-deep .p-contextmenu,::ng-deep .p-contextmenu-item,::ng-deep .p-dataview,::ng-deep .p-dataview-content,::ng-deep .p-dialog,::ng-deep .p-dialog-title,::ng-deep .p-dialog-content,::ng-deep .p-dropdown,::ng-deep .p-dropdown-label,::ng-deep .p-dropdown-item,::ng-deep .p-dynamic-dialog,::ng-deep .p-dynamic-dialog-title,::ng-deep .p-dynamic-dialog-content,::ng-deep .p-editor,::ng-deep .p-fieldset,::ng-deep .p-fieldset-legend,::ng-deep .p-fieldset-content,::ng-deep .p-fileupload,::ng-deep .p-inputmask,::ng-deep .p-inputnumber,::ng-deep .p-inputtextarea,::ng-deep .p-inputtext,::ng-deep .p-menu,::ng-deep .p-menuitem,::ng-deep .p-menuitem-text,::ng-deep .p-message,::ng-deep .p-messages,::ng-deep .p-multiselect,::ng-deep .p-multiselect-label,::ng-deep .p-multiselect-item,::ng-deep .p-panelmenu,::ng-deep .p-panelmenu-header,::ng-deep .p-panelmenu-content,::ng-deep .p-panel,::ng-deep .p-panel-header,::ng-deep .p-panel-content,::ng-deep .p-password,::ng-deep .p-picklist,::ng-deep .p-progressbar,::ng-deep .p-radiobutton,::ng-deep .p-rating,::ng-deep .p-sidebar,::ng-deep .p-splitbutton,::ng-deep .p-steps,::ng-deep .p-step,::ng-deep .p-table,::ng-deep .p-datatable,::ng-deep .p-tabview,::ng-deep .p-tabpanel,::ng-deep .p-tag,::ng-deep .p-toast,::ng-deep .p-toolbar,::ng-deep .p-tooltip,::ng-deep .p-tree,::ng-deep .p-treetable,::ng-deep .p-selectbutton,::ng-deep .p-stepper,::ng-deep .p-inputgroup,::ng-deep .p-inputgroup-addon,::ng-deep .p-text{font-family:Inter,Inter var,sans-serif!important}::ng-deep .p-icon,svg{height:.6rem}:host ::ng-deep .inputs{height:1.875rem}:host ::ng-deep .inputs,.p-inputtext,.p-inputtextarea{font-size:.875rem}::ng-deep .p-dialog .p-dialog-header{color:rgb(var(--kv-color-text))!important;background:linear-gradient(0deg,#00000005 .44%,#0000 49.5%),#fff!important;display:flex!important;flex-wrap:wrap;word-wrap:break-word;border-bottom:1px solid rgb(var(--kv-color-text),.15)}::ng-deep .p-dialog .p-dialog-content{padding-top:1rem}::ng-deep .p-dialog{min-width:320px}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-content::-webkit-scrollbar{width:8px}::ng-deep .p-dialog-content::-webkit-scrollbar:hover{background-color:#dededebf}::ng-deep .p-dialog-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}::ng-deep .p-dialog-content:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}::ng-deep .p-dialog-content::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}::ng-deep .p-dialog-footer{display:flex;justify-content:flex-end;padding:10px;gap:10px}::ng-deep .p-dialog .p-dialog-header .p-dialog-header-icon{display:none}::ng-deep .p-tooltip{font-size:.825rem!important}::ng-deep svg.p-icon{width:.65rem;height:.65rem}::ng-deep .p-checkbox .p-checkbox-box.p-highlight{border-color:#004172;background:#004172}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:hover{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:active{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:disabled{background-color:#002542;opacity:.4;cursor:auto}input{height:1.75rem}::ng-deep .p-checkbox .p-checkbox-box{width:1.125rem;height:1.125rem;border:1.5px solid #d1d5db}::ng-deep p-tablecheckbox p-tableheadercheckbox .p-checkbox{display:flex!important;align-items:center!important;justify-content:right}::ng-deep .p-checkbox{display:flex!important;align-items:center!important;justify-content:center}::ng-deep .p-checkbox-label{font-size:.875rem}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i4.PickList, selector: "p-pickList", inputs: ["source", "target", "sourceHeader", "tabindex", "rightButtonAriaLabel", "leftButtonAriaLabel", "allRightButtonAriaLabel", "allLeftButtonAriaLabel", "upButtonAriaLabel", "downButtonAriaLabel", "topButtonAriaLabel", "bottomButtonAriaLabel", "targetHeader", "responsive", "filterBy", "filterLocale", "trackBy", "sourceTrackBy", "targetTrackBy", "showSourceFilter", "showTargetFilter", "metaKeySelection", "dragdrop", "style", "styleClass", "sourceStyle", "targetStyle", "showSourceControls", "showTargetControls", "sourceFilterPlaceholder", "targetFilterPlaceholder", "disabled", "ariaSourceFilterLabel", "ariaTargetFilterLabel", "filterMatchMode", "stripedRows", "keepSelection", "breakpoint"], outputs: ["onMoveToSource", "onMoveAllToSource", "onMoveAllToTarget", "onMoveToTarget", "onSourceReorder", "onTargetReorder", "onSourceSelect", "onTargetSelect", "onSourceFilter", "onTargetFilter", "onFocus", "onBlur"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.KvCheckComponent, selector: "kv-check", outputs: ["onCheckChange"] }] }); }
|
|
323
|
+
}
|
|
324
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvPickListComponent, decorators: [{
|
|
325
|
+
type: Component,
|
|
326
|
+
args: [{ selector: 'kv-picklist', template: "<p-pickList\r\n [source]=\"source\"\r\n [sourceHeader]=\"sourceHeader\"\r\n [sourceStyle]=\"sourceStyle\"\r\n [target]=\"target\" \r\n [targetHeader]=\"targetHeader\"\r\n [targetStyle]=\"targetStyle\"\r\n [dragdrop]=\"dragdrop\"\r\n [responsive]=\"responsive\"\r\n [filterBy]=\"filterBy\"\r\n [breakpoint]=\"breakpoint\"\r\n [stripedRows]=\"stripedRows\"\r\n [showSourceControls]=\"showSourceControls\"\r\n [showTargetControls]=\"showTargetControls\"\r\n (onMoveToSource)=\"OnMoveToSource($event)\"\r\n (onMoveToTarget)=\"OnMoveToTarget($event)\"\r\n (onMoveAllToSource)=\"OnMoveAllToSource($event)\"\r\n (onMoveAllToTarget)=\"OnMoveAllToTarget($event)\"\r\n (onSourceSelect)=\"OnSourceSelect($event)\"\r\n (onTargetSelect)=\"OnTargetSelect($event)\"\r\n>\r\n <ng-template let-item pTemplate=\"item\" *ngIf=\"itemTemplate\" >\r\n <div (click)=\"selectCheckBox(item)\" class=\"flex mr-5\" [id]=\"'id_pick_list' + getItemId(item)\"\r\n >\r\n <ng-container [ngTemplateOutlet]=\"itemTemplate\" [ngTemplateOutletContext]=\"{ $implicit: item }\">\r\n @if(showCheckBox) {\r\n <kv-check (onCheckChange)=\"selectCheckBox(item)\" [(ngModel)]=\"selectedItems[item[itemIdField]]\" class=\"mr-1\"></kv-check>\r\n }\r\n </ng-container>\r\n </div> \r\n </ng-template>\r\n</p-pickList>\r\n", styles: ["@charset \"UTF-8\";:host ::ng-deep .p-picklist .p-picklist-filter-container{position:sticky!important;top:0!important;z-index:99!important}:host ::ng-deep .p-picklist .p-picklist-filter-container{border-left:0px;border-right:0px}.item-with-checkbox{display:flex;align-items:center}.item-with-checkbox kv-check{margin-right:8px}@keyframes shake-base{0%{transform:translate(0)}25%{transform:translate(1px,-1px)}50%{transform:translate(-1px,1px)}75%{transform:translate(1px,1px)}to{transform:translate(-1px,-1px)}}.drag-preview-clone{animation-name:shake-base;animation-duration:.25s;animation-iteration-count:infinite;animation-timing-function:ease-in-out;position:fixed;z-index:9999;opacity:.85;pointer-events:none;transition:transform .1s ease;box-shadow:0 10px 20px #0003;border-radius:6px;padding:8px;background-color:#fff}.drag-preview-clone.level-1{margin-top:.5rem}.drag-preview-clone.level-2{margin-bottom:1rem}.drag-preview-clone.level-3{margin-left:.5rem}\n", "@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,400,0,0\";::ng-deep :root{--kv-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255;--kv-primary-color: 41, 185, 45;--kv-secondary-color: 0, 37, 66;--kv-tertiary-color: 165, 165, 165}::ng-deep .padrao{--kv-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-keevocenter{--kv-color-system: 88,25,153;--kv-color-system-cta: 0, 116, 217;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-holos{--kv-color-system: 241,90,36;--kv-color-system-cta: 224, 168, 35;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 240,240,240;--kv-background-card: 2255,255,255}.system-color{color:rgb(var(--kv-color-system),1)}.bg-system-100{background:rgb(var(--kv-color-system),1)}.bg-system-75{background:rgb(var(--kv-color-system),.75)}.bg-system-50{background:rgb(var(--kv-color-system),.5)}.bg-system-25{background:rgb(var(--kv-color-system),.25)}.material-symbols-outlined{font-family:Material Symbols Outlined!important}*{font-family:Inter,Inter var,sans-serif!important}::ng-deep .p-accordion,::ng-deep .p-accordion-header,::ng-deep .p-accordion-content,::ng-deep .p-badge,::ng-deep .p-overlay-badge,::ng-deep .p-breadcrumb,::ng-deep .p-breadcrumb-item,::ng-deep .p-breadcrumb-link,::ng-deep .p-button,::ng-deep .p-calendar,::ng-deep .p-card,::ng-deep .p-card-title,::ng-deep .p-card-subtitle,::ng-deep .p-card-content,::ng-deep .p-checkbox,::ng-deep .p-chip,::ng-deep .p-confirm-dialog,::ng-deep .p-confirm-dialog-message,::ng-deep .p-contextmenu,::ng-deep .p-contextmenu-item,::ng-deep .p-dataview,::ng-deep .p-dataview-content,::ng-deep .p-dialog,::ng-deep .p-dialog-title,::ng-deep .p-dialog-content,::ng-deep .p-dropdown,::ng-deep .p-dropdown-label,::ng-deep .p-dropdown-item,::ng-deep .p-dynamic-dialog,::ng-deep .p-dynamic-dialog-title,::ng-deep .p-dynamic-dialog-content,::ng-deep .p-editor,::ng-deep .p-fieldset,::ng-deep .p-fieldset-legend,::ng-deep .p-fieldset-content,::ng-deep .p-fileupload,::ng-deep .p-inputmask,::ng-deep .p-inputnumber,::ng-deep .p-inputtextarea,::ng-deep .p-inputtext,::ng-deep .p-menu,::ng-deep .p-menuitem,::ng-deep .p-menuitem-text,::ng-deep .p-message,::ng-deep .p-messages,::ng-deep .p-multiselect,::ng-deep .p-multiselect-label,::ng-deep .p-multiselect-item,::ng-deep .p-panelmenu,::ng-deep .p-panelmenu-header,::ng-deep .p-panelmenu-content,::ng-deep .p-panel,::ng-deep .p-panel-header,::ng-deep .p-panel-content,::ng-deep .p-password,::ng-deep .p-picklist,::ng-deep .p-progressbar,::ng-deep .p-radiobutton,::ng-deep .p-rating,::ng-deep .p-sidebar,::ng-deep .p-splitbutton,::ng-deep .p-steps,::ng-deep .p-step,::ng-deep .p-table,::ng-deep .p-datatable,::ng-deep .p-tabview,::ng-deep .p-tabpanel,::ng-deep .p-tag,::ng-deep .p-toast,::ng-deep .p-toolbar,::ng-deep .p-tooltip,::ng-deep .p-tree,::ng-deep .p-treetable,::ng-deep .p-selectbutton,::ng-deep .p-stepper,::ng-deep .p-inputgroup,::ng-deep .p-inputgroup-addon,::ng-deep .p-text{font-family:Inter,Inter var,sans-serif!important}::ng-deep .p-icon,svg{height:.6rem}:host ::ng-deep .inputs{height:1.875rem}:host ::ng-deep .inputs,.p-inputtext,.p-inputtextarea{font-size:.875rem}::ng-deep .p-dialog .p-dialog-header{color:rgb(var(--kv-color-text))!important;background:linear-gradient(0deg,#00000005 .44%,#0000 49.5%),#fff!important;display:flex!important;flex-wrap:wrap;word-wrap:break-word;border-bottom:1px solid rgb(var(--kv-color-text),.15)}::ng-deep .p-dialog .p-dialog-content{padding-top:1rem}::ng-deep .p-dialog{min-width:320px}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-content::-webkit-scrollbar{width:8px}::ng-deep .p-dialog-content::-webkit-scrollbar:hover{background-color:#dededebf}::ng-deep .p-dialog-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}::ng-deep .p-dialog-content:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}::ng-deep .p-dialog-content::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}::ng-deep .p-dialog-footer{display:flex;justify-content:flex-end;padding:10px;gap:10px}::ng-deep .p-dialog .p-dialog-header .p-dialog-header-icon{display:none}::ng-deep .p-tooltip{font-size:.825rem!important}::ng-deep svg.p-icon{width:.65rem;height:.65rem}::ng-deep .p-checkbox .p-checkbox-box.p-highlight{border-color:#004172;background:#004172}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:hover{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:active{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:disabled{background-color:#002542;opacity:.4;cursor:auto}input{height:1.75rem}::ng-deep .p-checkbox .p-checkbox-box{width:1.125rem;height:1.125rem;border:1.5px solid #d1d5db}::ng-deep p-tablecheckbox p-tableheadercheckbox .p-checkbox{display:flex!important;align-items:center!important;justify-content:right}::ng-deep .p-checkbox{display:flex!important;align-items:center!important;justify-content:center}::ng-deep .p-checkbox-label{font-size:.875rem}\n"] }]
|
|
327
|
+
}], ctorParameters: () => [{ type: i1.FormBuilder }], propDecorators: { picklist: [{
|
|
328
|
+
type: ViewChild,
|
|
329
|
+
args: [PickList]
|
|
330
|
+
}], itemIdField: [{
|
|
331
|
+
type: Input
|
|
332
|
+
}], breakpoint: [{
|
|
333
|
+
type: Input
|
|
334
|
+
}], dragdrop: [{
|
|
335
|
+
type: Input
|
|
336
|
+
}], filterBy: [{
|
|
337
|
+
type: Input
|
|
338
|
+
}], itemTemplate: [{
|
|
339
|
+
type: Input
|
|
340
|
+
}], responsive: [{
|
|
341
|
+
type: Input
|
|
342
|
+
}], source: [{
|
|
343
|
+
type: Input
|
|
344
|
+
}], sourceHeader: [{
|
|
345
|
+
type: Input
|
|
346
|
+
}], sourceStyle: [{
|
|
347
|
+
type: Input
|
|
348
|
+
}], stripedRows: [{
|
|
349
|
+
type: Input
|
|
350
|
+
}], target: [{
|
|
351
|
+
type: Input
|
|
352
|
+
}], targetHeader: [{
|
|
353
|
+
type: Input
|
|
354
|
+
}], targetStyle: [{
|
|
355
|
+
type: Input
|
|
356
|
+
}], showSourceControls: [{
|
|
357
|
+
type: Input
|
|
358
|
+
}], showTargetControls: [{
|
|
359
|
+
type: Input
|
|
360
|
+
}], showCheckBox: [{
|
|
361
|
+
type: Input
|
|
362
|
+
}], onMoveToSource: [{
|
|
363
|
+
type: Output
|
|
364
|
+
}], onMoveToTarget: [{
|
|
365
|
+
type: Output
|
|
366
|
+
}], onMoveAllToSource: [{
|
|
367
|
+
type: Output
|
|
368
|
+
}], onMoveAllToTarget: [{
|
|
369
|
+
type: Output
|
|
370
|
+
}], onSourceSelect: [{
|
|
371
|
+
type: Output
|
|
372
|
+
}], onTargetSelect: [{
|
|
373
|
+
type: Output
|
|
374
|
+
}] } });
|
|
375
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-pick-list.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-pick-list/kv-pick-list.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-pick-list/kv-pick-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  TemplateRef,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { FormBuilder, FormGroup } from '@angular/forms';\r\nimport { PickList } from 'primeng/picklist';\r\n\r\n@Component({\r\n  selector: 'kv-picklist',\r\n  templateUrl: './kv-pick-list.component.html',\r\n  styleUrls: [\r\n    './kv-pick-list.component.scss',\r\n    '../keevo-components-styles.scss'\r\n  ]\r\n})\r\nexport class KvPickListComponent implements OnInit {\r\n\r\n  @ViewChild(PickList) picklist!: PickList;\r\n\r\n  form!: FormGroup;\r\n\r\n  constructor(private fb: FormBuilder) {\r\n    document.addEventListener('keydown', (event) => this.onKeyDown(event));\r\n  }\r\n\r\n  @Input() itemIdField: string = 'id';\r\n  @Input() breakpoint: string = \"1400px\";\r\n  @Input() dragdrop: boolean = true;\r\n  @Input() filterBy!: string;\r\n  @Input() itemTemplate!: TemplateRef<any>;\r\n  @Input() responsive: boolean = true;\r\n  @Input() source!: any[];\r\n  @Input() sourceHeader: string = 'Título da lista de origem';\r\n  @Input() sourceStyle!: any;\r\n  @Input() stripedRows: boolean = false;\r\n  @Input() target!: any[];\r\n  @Input() targetHeader: string = 'Título de lista de destino';\r\n  @Input() targetStyle!: any;\r\n  @Input() showSourceControls: boolean = true;\r\n  @Input() showTargetControls: boolean = true;\r\n  @Input() showCheckBox: boolean = false;\r\n\r\n  @Output() onMoveToSource: EventEmitter<any> = new EventEmitter();\r\n  @Output() onMoveToTarget: EventEmitter<any> = new EventEmitter();\r\n  @Output() onMoveAllToSource: EventEmitter<any> = new EventEmitter();\r\n  @Output() onMoveAllToTarget: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSourceSelect: EventEmitter<any> = new EventEmitter();\r\n  @Output() onTargetSelect: EventEmitter<any> = new EventEmitter();\r\n\r\n  selectedPreview!: any;\r\n  ngModel: boolean = false;\r\n  selectedItems: { [key: number]: boolean } = {};\r\n  ultimoItemSelecionado: { item: any, index: number }[] = [];\r\n  lastDraggedItems: any[] = [];\r\n  draggedIds: number[] = [];\r\n\r\n  mouseX = 0;\r\n  mouseY = 0;\r\n  previewClones: HTMLElement[] = [];\r\n\r\nngOnInit() {\r\n  document.addEventListener('mousemove', (event: MouseEvent) => {\r\n    this.mouseX = event.clientX;\r\n    this.mouseY = event.clientY;\r\n  });\r\n}\r\n\r\nngAfterViewInit() {\r\n  this.createDropOverlay();\r\n}\r\n\r\n  dropOverlay!: HTMLDivElement;\r\n\r\n  createDropOverlay() {\r\n    this.dropOverlay = document.createElement('div');\r\n    this.dropOverlay.innerText = 'Soltar';\r\n    this.dropOverlay.style.position = 'fixed';\r\n    this.dropOverlay.style.background = '#BFDBFE'; // Azul claro visível\r\n    this.dropOverlay.style.color = '#1E3A8A'; // Azul escuro pro texto\r\n    this.dropOverlay.style.border = '9px #1E40AF'; // Borda azul escuro\r\n    this.dropOverlay.style.boxShadow = '0 2px 6px rgba(30, 58, 138, 0.2)'; // Shadow reduzida\r\n    this.dropOverlay.style.display = 'none';\r\n    this.dropOverlay.style.justifyContent = 'center';\r\n    this.dropOverlay.style.alignItems = 'center';\r\n    this.dropOverlay.style.zIndex = '9999';\r\n    this.dropOverlay.style.fontSize = '1.5rem';\r\n    this.dropOverlay.style.fontWeight = 'bold';\r\n    this.dropOverlay.style.pointerEvents = 'all';\r\n    this.dropOverlay.style.transition = 'all 0.2s ease';\r\n\r\n\r\n    // Encaixar no mesmo lugar do target\r\n    const targetListEl = document.querySelector('.p-picklist-target') as HTMLElement;\r\n    if (targetListEl) {\r\n      const rect = targetListEl.getBoundingClientRect();\r\n      this.dropOverlay.style.top = rect.top + 'px';\r\n      this.dropOverlay.style.left = rect.left + 'px';\r\n      this.dropOverlay.style.width = rect.width + 'px';\r\n      this.dropOverlay.style.height = rect.height + 'px';\r\n    }\r\n\r\n    this.dropOverlay.addEventListener('click', () => {\r\n      const selectedInSource = this.source.some(item => this.selectedItems[item[this.itemIdField]]);\r\n      const selectedInTarget = this.target.some(item => this.selectedItems[item[this.itemIdField]]);\r\n    \r\n      if (selectedInSource) {\r\n        this.OnMoveToTarget({});\r\n      } else if (selectedInTarget) {\r\n        this.OnMoveToSource({});\r\n      }\r\n    \r\n      this.hideDropOverlay();\r\n    });\r\n    \r\n\r\n    this.dropOverlay.addEventListener('mouseenter', () => {\r\n      this.dropOverlay.style.background = '#93C5FD'; // Azul um pouco mais escuro no hover\r\n    });\r\n    this.dropOverlay.addEventListener('mouseleave', () => {\r\n      this.dropOverlay.style.background = '#BFDBFE';\r\n    });\r\n    \r\n\r\n    document.body.appendChild(this.dropOverlay);\r\n  }\r\n\r\n\r\n  handleMouseMove(event: MouseEvent) {\r\n    this.mouseX = event.clientX;\r\n    this.mouseY = event.clientY;\r\n  }\r\n\r\n  clearPreviewClones() {\r\n    this.previewClones.forEach(clone => clone.remove());\r\n    this.previewClones = [];\r\n  }\r\n  \r\n  OnMoveToSource(event: any) {\r\n    this.clearPreviewClones();\r\n    this.picklist.moveLeft();\r\n    this.onMoveToSource.emit(event);\r\n    this.selectedItems = {};\r\n    this.hideDropOverlay()\r\n    this.clearPreviewClones();\r\n  }\r\n  \r\n  OnMoveToTarget(event: any) {\r\n    this.clearPreviewClones();\r\n    this.picklist.moveRight();\r\n    this.onMoveToTarget.emit(event);\r\n    this.selectedItems = {};\r\n    this.hideDropOverlay()\r\n    this.clearPreviewClones();\r\n  }\r\n  \r\n\r\n  getSelectedItems(): any[] {\r\n    // Filtra os itens da lista de origem (source) com base nos itens selecionados\r\n    return this.source.filter(item => {\r\n      const itemId = item[this.itemIdField]; // Obtém o ID do item\r\n      return this.selectedItems[itemId] === true; // Verifica se está marcado como true\r\n    });\r\n  }\r\n\r\n  OnMoveAllToSource(event: any) {\r\n    this.onMoveToSource.emit(event);\r\n    this.selectedItems = {};\r\n    this.hideDropOverlay()\r\n    this.clearPreviewClones();\r\n  }\r\n\r\n  OnMoveAllToTarget(event: any) {\r\n    this.onMoveToTarget.emit(event);\r\n    this.selectedItems = {};\r\n    this.hideDropOverlay()\r\n    this.clearPreviewClones();\r\n  }\r\n\r\n  OnSourceSelect(event: any) {\r\n    const selectedItems = this.getSelectedItems();\r\n  \r\n    // Primeiro remove todos os previews antigos\r\n    this.clearPreviewClones();\r\n  \r\n    if (selectedItems.length === 0) {\r\n      this.hideDropOverlay();\r\n      this.onSourceSelect.emit(event);\r\n      return;\r\n    }\r\n  \r\n    selectedItems.forEach((item: any, index: number) => {\r\n      const itemId = item[this.itemIdField];\r\n  \r\n      // Se já existe um clone para esse item, não cria novamente\r\n      if (!document.getElementById('preview_' + itemId)) {\r\n        const original = document.getElementById('id_pick_list' + itemId);\r\n        if (original) {\r\n          const rect = original.getBoundingClientRect();\r\n          const clone = original.cloneNode(true) as HTMLElement;\r\n          clone.classList.add('drag-preview-clone');\r\n          clone.classList.add(`level-${index + 1}`);\r\n          clone.id = 'preview_' + itemId;\r\n          document.body.appendChild(clone);\r\n          this.previewClones.push(clone);\r\n          this.animateCloneToCursor(clone, rect);\r\n        }\r\n      }\r\n    });\r\n  \r\n    this.showDropOverlay();\r\n    this.onSourceSelect.emit(event);\r\n  }\r\n  \r\n  getItemId(item: any): string {\r\n    return item?.[this.itemIdField];\r\n  }\r\n  \r\n\r\n  showDropOverlay() {\r\n    const selectedInSource = this.source.some(item => this.selectedItems[item[this.itemIdField]]);\r\n    const selectedInTarget = this.target.some(item => this.selectedItems[item[this.itemIdField]]);\r\n  \r\n    let targetListEl: HTMLElement | null = null;\r\n  \r\n    if (selectedInSource) {\r\n      // Itens selecionados na lista da esquerda → overlay no lado direito\r\n      targetListEl = document.querySelector('.p-picklist-target') as HTMLElement;\r\n      this.dropOverlay.innerText = 'Soltar aqui para mover';\r\n    } else if (selectedInTarget) {\r\n      // Itens selecionados na lista da direita → overlay no lado esquerdo\r\n      targetListEl = document.querySelector('.p-picklist-source') as HTMLElement;\r\n      this.dropOverlay.innerText = 'Soltar aqui para retornar';\r\n    }\r\n  \r\n    if (targetListEl) {\r\n      const rect = targetListEl.getBoundingClientRect();\r\n      this.dropOverlay.style.top = rect.top + 'px';\r\n      this.dropOverlay.style.left = rect.left + 'px';\r\n      this.dropOverlay.style.width = rect.width + 'px';\r\n      this.dropOverlay.style.height = rect.height + 'px';\r\n      this.dropOverlay.style.display = 'flex';\r\n    }\r\n  }\r\n  \r\n  \r\n  hideDropOverlay() {\r\n    if (this.dropOverlay) {\r\n      this.dropOverlay.style.display = 'none';\r\n    }\r\n  }\r\n  \r\n  \r\n  animateCloneToCursor(clone: HTMLElement, originRect: DOMRect) {\r\n    // Começa exatamente da posição do original\r\n    let posX = originRect.left;\r\n    let posY = originRect.top;\r\n  \r\n    clone.style.position = 'fixed';\r\n    clone.style.left = `${posX}px`;\r\n    clone.style.top = `${posY}px`;\r\n    clone.style.width = `${originRect.width}px`;\r\n    clone.style.height = `${originRect.height}px`;\r\n    clone.style.pointerEvents = 'none';\r\n  \r\n    const animate = () => {\r\n      const dx = this.mouseX - posX;\r\n      const dy = this.mouseY - posY;\r\n  \r\n      posX += dx * 0.15;\r\n      posY += dy * 0.15;\r\n  \r\n      clone.style.left = `${posX}px`;\r\n      clone.style.top = `${posY}px`;\r\n  \r\n      if (document.body.contains(clone)) {\r\n        requestAnimationFrame(animate);\r\n      }\r\n    };\r\n  \r\n    animate();\r\n  }\r\n  \r\n  \r\n\r\n  OnTargetSelect(event: any) {\r\n    const selectedItems = this.target.filter(item => {\r\n      const itemId = item[this.itemIdField];\r\n      return this.selectedItems[itemId] === true;\r\n    });\r\n  \r\n    // Limpa clones antigos\r\n    this.clearPreviewClones();\r\n  \r\n    if (selectedItems.length === 0) {\r\n      this.hideDropOverlay();\r\n      this.onTargetSelect.emit(event);\r\n      return;\r\n    }\r\n  \r\n    selectedItems.forEach((item: any, index: number) => {\r\n      const itemId = item[this.itemIdField];\r\n  \r\n      if (!document.getElementById('preview_' + itemId)) {\r\n        const original = document.getElementById('id_pick_list' + itemId);\r\n        if (original) {\r\n          const rect = original.getBoundingClientRect();\r\n          const clone = original.cloneNode(true) as HTMLElement;\r\n          clone.classList.add('drag-preview-clone');\r\n          clone.classList.add(`level-${index + 1}`);\r\n          clone.id = 'preview_' + itemId;\r\n          document.body.appendChild(clone);\r\n          this.previewClones.push(clone);\r\n          this.animateCloneToCursor(clone, rect); \r\n        }\r\n      }\r\n    });\r\n  \r\n    this.showDropOverlay();\r\n    this.onTargetSelect.emit(event);\r\n  }\r\n  \r\n\r\n  onSelectAll() {\r\n    this.selectAllItems(true);\r\n  }\r\n\r\n  selectAllItems(isSelected: boolean) {\r\n    this.source.forEach(item => {\r\n      const itemId = item[this.itemIdField];\r\n      this.selectedItems[itemId] = isSelected;\r\n    });\r\n\r\n    this.target.forEach(item => {\r\n      const itemId = item[this.itemIdField];\r\n      this.selectedItems[itemId] = isSelected;\r\n    });\r\n  }\r\n\r\n  onKeyDown(event: KeyboardEvent) {\r\n    if (event.ctrlKey && event.key === 'a') {\r\n      event.preventDefault();\r\n      this.onSelectAll();\r\n    } else if (event.key === 'Enter') {\r\n  \r\n      const sourceSelected = this.picklist.selectedItemsSource;\r\n  \r\n      const selectedItemsIds = Object.entries(this.selectedItems)\r\n        .filter(([_, value]) => value === true)\r\n        .map(([key, _]) => Number(key));\r\n  \r\n      const notInSelected = sourceSelected.find(\r\n        (item: { [key: string]: any }) =>\r\n          !selectedItemsIds.includes(item[this.itemIdField])\r\n      );\r\n  \r\n      const indexInSource = this.source.findIndex(\r\n        (item: { [key: string]: any }) =>\r\n          item[this.itemIdField] === notInSelected?.[this.itemIdField]\r\n      );\r\n  \r\n      const ultimoItemArray = {\r\n        item: notInSelected,\r\n        index: indexInSource,\r\n      };\r\n  \r\n      const selectedIndexInSource = this.source.findIndex((sourceItem: any) =>\r\n        selectedItemsIds.includes(sourceItem[this.itemIdField])\r\n      );\r\n  \r\n      if (notInSelected === undefined) {\r\n        const beforeIds = this.ultimoItemSelecionado.map(i => i.item[this.itemIdField]);\r\n        const afterIds = this.picklist.selectedItemsSource.map(i => i[this.itemIdField]);\r\n      \r\n        const removedId = beforeIds.find(id => !afterIds.includes(id));\r\n      \r\n      \r\n        if (removedId != null) {\r\n          const removedItem = this.source.find(item => item[this.itemIdField] === removedId);\r\n          if (removedItem) {\r\n            this.selectCheckBox(removedItem);\r\n            this.ultimoItemSelecionado = this.ultimoItemSelecionado.filter(\r\n              (i) => i.item[this.itemIdField] !== removedId\r\n            );\r\n          }\r\n        } else {\r\n          const enterIds = this.ultimoItemSelecionado.map(i => i.item[this.itemIdField]);\r\n\r\n          const selectedItemsIds = Object.entries(this.selectedItems)\r\n            .filter(([_, value]) => value === true)\r\n            .map(([key, _]) => Number(key));\r\n          \r\n          const clickedIds = selectedItemsIds.filter(id => !enterIds.includes(id));\r\n          \r\n          if (clickedIds.length > 0) {\r\n            const clickedItem = this.source.find(item => item[this.itemIdField] === clickedIds[0]);\r\n            if (clickedItem) {\r\n              this.selectCheckBox(clickedItem);\r\n              this.ultimoItemSelecionado = this.ultimoItemSelecionado.filter(\r\n                (i) => i.item[this.itemIdField] !== clickedIds[0]\r\n              );\r\n            }\r\n          }\r\n          \r\n        }\r\n      \r\n        return;\r\n      }\r\n      \r\n      \r\n  \r\n      this.selectCheckBox(notInSelected);\r\n  \r\n      this.ultimoItemSelecionado = this.ultimoItemSelecionado.filter(\r\n        (item) => item.index !== indexInSource\r\n      );\r\n  \r\n      this.ultimoItemSelecionado.push(ultimoItemArray);\r\n  \r\n    }\r\n  }\r\n  \r\n\r\n  selectCheckBox(item: any) {\r\n    const itemId = item[this.itemIdField];\r\n\r\n\r\n    this.selectedPreview = item;\r\n\r\n    this.selectedItems[itemId] = this.selectedItems[itemId] !== undefined\r\n      ? !this.selectedItems[itemId]\r\n      : true;\r\n\r\n\r\n    this.ngModel = this.selectedItems[itemId];\r\n\r\n  }\r\n\r\n  isItemSelected(item: any): boolean {\r\n    return this.selectedPreview === item;\r\n  }\r\n}\r\n","<p-pickList\r\n  [source]=\"source\"\r\n  [sourceHeader]=\"sourceHeader\"\r\n  [sourceStyle]=\"sourceStyle\"\r\n  [target]=\"target\" \r\n  [targetHeader]=\"targetHeader\"\r\n  [targetStyle]=\"targetStyle\"\r\n  [dragdrop]=\"dragdrop\"\r\n  [responsive]=\"responsive\"\r\n  [filterBy]=\"filterBy\"\r\n  [breakpoint]=\"breakpoint\"\r\n  [stripedRows]=\"stripedRows\"\r\n  [showSourceControls]=\"showSourceControls\"\r\n  [showTargetControls]=\"showTargetControls\"\r\n  (onMoveToSource)=\"OnMoveToSource($event)\"\r\n  (onMoveToTarget)=\"OnMoveToTarget($event)\"\r\n  (onMoveAllToSource)=\"OnMoveAllToSource($event)\"\r\n  (onMoveAllToTarget)=\"OnMoveAllToTarget($event)\"\r\n  (onSourceSelect)=\"OnSourceSelect($event)\"\r\n  (onTargetSelect)=\"OnTargetSelect($event)\"\r\n>\r\n  <ng-template  let-item pTemplate=\"item\" *ngIf=\"itemTemplate\" >\r\n      <div (click)=\"selectCheckBox(item)\" class=\"flex mr-5\" [id]=\"'id_pick_list' + getItemId(item)\"\r\n      >\r\n      <ng-container [ngTemplateOutlet]=\"itemTemplate\" [ngTemplateOutletContext]=\"{ $implicit: item }\">\r\n        @if(showCheckBox) {\r\n            <kv-check (onCheckChange)=\"selectCheckBox(item)\" [(ngModel)]=\"selectedItems[item[itemIdField]]\" class=\"mr-1\"></kv-check>\r\n        }\r\n        </ng-container>\r\n    </div> \r\n  </ng-template>\r\n</p-pickList>\r\n"]}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
3
|
+
import { NgModule } from "@angular/core";
|
|
4
|
+
import { KvPickListComponent } from './kv-pick-list.component';
|
|
5
|
+
import { PrimeNgModule } from '../../api/modules/primeng.module';
|
|
6
|
+
import { KvInputsModule } from "../kv-inputs/kv-inputs.module";
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export class KvPickListModule {
|
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvPickListModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
10
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.8", ngImport: i0, type: KvPickListModule, declarations: [KvPickListComponent], imports: [CommonModule,
|
|
11
|
+
PrimeNgModule,
|
|
12
|
+
FormsModule,
|
|
13
|
+
KvInputsModule,
|
|
14
|
+
ReactiveFormsModule], exports: [KvPickListComponent] }); }
|
|
15
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvPickListModule, imports: [CommonModule,
|
|
16
|
+
PrimeNgModule,
|
|
17
|
+
FormsModule,
|
|
18
|
+
KvInputsModule,
|
|
19
|
+
ReactiveFormsModule] }); }
|
|
20
|
+
}
|
|
21
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvPickListModule, decorators: [{
|
|
22
|
+
type: NgModule,
|
|
23
|
+
args: [{
|
|
24
|
+
declarations: [
|
|
25
|
+
KvPickListComponent
|
|
26
|
+
],
|
|
27
|
+
imports: [
|
|
28
|
+
CommonModule,
|
|
29
|
+
PrimeNgModule,
|
|
30
|
+
FormsModule,
|
|
31
|
+
KvInputsModule,
|
|
32
|
+
ReactiveFormsModule
|
|
33
|
+
],
|
|
34
|
+
exports: [
|
|
35
|
+
KvPickListComponent
|
|
36
|
+
]
|
|
37
|
+
}]
|
|
38
|
+
}] });
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3YtcGljay1saXN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2t2LXBpY2stbGlzdC9rdi1waWNrLWxpc3QubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMvRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDakUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLCtCQUErQixDQUFDOztBQWlCL0QsTUFBTSxPQUFPLGdCQUFnQjs4R0FBaEIsZ0JBQWdCOytHQUFoQixnQkFBZ0IsaUJBYnpCLG1CQUFtQixhQUduQixZQUFZO1lBQ1osYUFBYTtZQUNiLFdBQVc7WUFDWCxjQUFjO1lBQ2QsbUJBQW1CLGFBR25CLG1CQUFtQjsrR0FHVixnQkFBZ0IsWUFWekIsWUFBWTtZQUNaLGFBQWE7WUFDYixXQUFXO1lBQ1gsY0FBYztZQUNkLG1CQUFtQjs7MkZBTVYsZ0JBQWdCO2tCQWY1QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWixtQkFBbUI7cUJBQ3BCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGFBQWE7d0JBQ2IsV0FBVzt3QkFDWCxjQUFjO3dCQUNkLG1CQUFtQjtxQkFDdEI7b0JBQ0MsT0FBTyxFQUFFO3dCQUNQLG1CQUFtQjtxQkFDcEI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5cclxuaW1wb3J0IHsgS3ZQaWNrTGlzdENvbXBvbmVudCB9IGZyb20gJy4va3YtcGljay1saXN0LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFByaW1lTmdNb2R1bGUgfSBmcm9tICcuLi8uLi9hcGkvbW9kdWxlcy9wcmltZW5nLm1vZHVsZSc7XHJcbmltcG9ydCB7IEt2SW5wdXRzTW9kdWxlIH0gZnJvbSBcIi4uL2t2LWlucHV0cy9rdi1pbnB1dHMubW9kdWxlXCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgS3ZQaWNrTGlzdENvbXBvbmVudFxyXG4gIF0sXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgUHJpbWVOZ01vZHVsZSxcclxuICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgS3ZJbnB1dHNNb2R1bGUsXHJcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlXHJcbl0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgS3ZQaWNrTGlzdENvbXBvbmVudFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEt2UGlja0xpc3RNb2R1bGUgeyB9XHJcbiJdfQ==
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
export class ProgressBarComponent {
|
|
5
|
+
constructor() {
|
|
6
|
+
/**
|
|
7
|
+
* Whether to display the progress bar value.
|
|
8
|
+
* @group Props
|
|
9
|
+
*/
|
|
10
|
+
this.showValue = true;
|
|
11
|
+
/**
|
|
12
|
+
* Whether to display the progress bar value.
|
|
13
|
+
* @group Props
|
|
14
|
+
*/
|
|
15
|
+
this.showLabel = true;
|
|
16
|
+
/**
|
|
17
|
+
* Unit sign appended to the value.
|
|
18
|
+
* @group Props
|
|
19
|
+
*/
|
|
20
|
+
this.unit = '%';
|
|
21
|
+
/**
|
|
22
|
+
* Defines the mode of the progress
|
|
23
|
+
* @group Props
|
|
24
|
+
*/
|
|
25
|
+
this.mode = 'determinate';
|
|
26
|
+
}
|
|
27
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: ProgressBarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
28
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: ProgressBarComponent, selector: "kv-progress-bar", inputs: { value: "value", maxValue: "maxValue", label: "label", showValue: "showValue", showLabel: "showLabel", styleClass: "styleClass", labelStyleClass: "labelStyleClass", barStyleClass: "barStyleClass", style: "style", unit: "unit", mode: "mode", color: "color" }, ngImport: i0, template: "<div\r\n role=\"progressbar\"\r\n [class]=\"styleClass ? styleClass : ''\"\r\n [ngStyle]=\"style\"\r\n [attr.aria-valuemin]=\"0\"\r\n [attr.aria-valuenow]=\"value\"\r\n [attr.aria-valuemax]=\"100\"\r\n [attr.data-pc-name]=\"'progressbar'\"\r\n [attr.data-pc-section]=\"'root'\"\r\n [ngClass]=\"{'p-progressbar p-component': true, 'p-progressbar-determinate': mode === 'determinate', 'p-progressbar-indeterminate': mode === 'indeterminate'}\"\r\n>\r\n @if(mode === 'determinate') {\r\n <div class=\"p-progressbar-value p-progressbar-value-animate {{ barStyleClass }} font-semibold\"\r\n [style.width]=\"maxValue && value ? (value / maxValue) * 100 + '%' : value + '%'\"\r\n [attr.data-pc-section]=\"'value'\"\r\n ></div>\r\n\r\n <div\r\n class=\"p-progressbar-label {{ labelStyleClass }} w-full\"\r\n [attr.data-pc-section]=\"'label'\"\r\n >\r\n <label *ngIf=\"showValue && maxValue\">{{ value }}/{{ maxValue }}</label>\r\n <label *ngIf=\"showValue && !maxValue\">{{ value }}%</label>\r\n <label *ngIf=\"showLabel\">{{ label }}</label>\r\n </div>\r\n } @if(mode === 'indeterminate') {\r\n <div\r\n class=\"p-progressbar-indeterminate-container\"\r\n [attr.data-pc-section]=\"'container'\"\r\n >\r\n <div\r\n class=\"p-progressbar-value p-progressbar-value-animate\"\r\n [style.background]=\"color\"\r\n [attr.data-pc-section]=\"'value'\"\r\n ></div>\r\n </div>\r\n }\r\n</div>\r\n", styles: ["@layer primeng{.p-progressbar{background-color:#adadad!important;position:relative;overflow:hidden;height:.875rem}.p-progressbar-determinate .p-progressbar-value{height:100%;width:0%;position:absolute;display:none;border:0 none;display:flex;align-items:center;justify-content:center;overflow:hidden}.p-progressbar-determinate .p-progressbar-label{font-size:.75rem;color:#fff!important;font-weight:400;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;justify-content:center;align-items:center}.p-progressbar-determinate .p-progressbar-value-animate{background-color:#004172!important;transition:width 1s ease-in-out}.p-progressbar-indeterminate .p-progressbar-value:before{background-color:#004172!important;content:\"\";position:absolute;background-color:inherit;top:0;left:0;bottom:0;will-change:left,right;-webkit-animation:p-progressbar-indeterminate-anim 2.1s cubic-bezier(.65,.815,.735,.395) infinite;animation:p-progressbar-indeterminate-anim 2.1s cubic-bezier(.65,.815,.735,.395) infinite}.p-progressbar-indeterminate .p-progressbar-value:after{background-color:#004172!important;content:\"\";position:absolute;background-color:inherit;top:0;left:0;bottom:0;will-change:left,right;-webkit-animation:p-progressbar-indeterminate-anim-short 2.1s cubic-bezier(.165,.84,.44,1) infinite;animation:p-progressbar-indeterminate-anim-short 2.1s cubic-bezier(.165,.84,.44,1) infinite;-webkit-animation-delay:1.15s;animation-delay:1.15s}}@-webkit-keyframes p-progressbar-indeterminate-anim{0%{left:-35%;right:100%}60%{left:100%;right:-90%}to{left:100%;right:-90%}}@keyframes p-progressbar-indeterminate-anim{0%{left:-35%;right:100%}60%{left:100%;right:-90%}to{left:100%;right:-90%}}@-webkit-keyframes p-progressbar-indeterminate-anim-short{0%{left:-200%;right:100%}60%{left:107%;right:-8%}to{left:107%;right:-8%}}@keyframes p-progressbar-indeterminate-anim-short{0%{left:-200%;right:100%}60%{left:107%;right:-8%}to{left:107%;right:-8%}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
|
|
29
|
+
}
|
|
30
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: ProgressBarComponent, decorators: [{
|
|
31
|
+
type: Component,
|
|
32
|
+
args: [{ selector: 'kv-progress-bar', template: "<div\r\n role=\"progressbar\"\r\n [class]=\"styleClass ? styleClass : ''\"\r\n [ngStyle]=\"style\"\r\n [attr.aria-valuemin]=\"0\"\r\n [attr.aria-valuenow]=\"value\"\r\n [attr.aria-valuemax]=\"100\"\r\n [attr.data-pc-name]=\"'progressbar'\"\r\n [attr.data-pc-section]=\"'root'\"\r\n [ngClass]=\"{'p-progressbar p-component': true, 'p-progressbar-determinate': mode === 'determinate', 'p-progressbar-indeterminate': mode === 'indeterminate'}\"\r\n>\r\n @if(mode === 'determinate') {\r\n <div class=\"p-progressbar-value p-progressbar-value-animate {{ barStyleClass }} font-semibold\"\r\n [style.width]=\"maxValue && value ? (value / maxValue) * 100 + '%' : value + '%'\"\r\n [attr.data-pc-section]=\"'value'\"\r\n ></div>\r\n\r\n <div\r\n class=\"p-progressbar-label {{ labelStyleClass }} w-full\"\r\n [attr.data-pc-section]=\"'label'\"\r\n >\r\n <label *ngIf=\"showValue && maxValue\">{{ value }}/{{ maxValue }}</label>\r\n <label *ngIf=\"showValue && !maxValue\">{{ value }}%</label>\r\n <label *ngIf=\"showLabel\">{{ label }}</label>\r\n </div>\r\n } @if(mode === 'indeterminate') {\r\n <div\r\n class=\"p-progressbar-indeterminate-container\"\r\n [attr.data-pc-section]=\"'container'\"\r\n >\r\n <div\r\n class=\"p-progressbar-value p-progressbar-value-animate\"\r\n [style.background]=\"color\"\r\n [attr.data-pc-section]=\"'value'\"\r\n ></div>\r\n </div>\r\n }\r\n</div>\r\n", styles: ["@layer primeng{.p-progressbar{background-color:#adadad!important;position:relative;overflow:hidden;height:.875rem}.p-progressbar-determinate .p-progressbar-value{height:100%;width:0%;position:absolute;display:none;border:0 none;display:flex;align-items:center;justify-content:center;overflow:hidden}.p-progressbar-determinate .p-progressbar-label{font-size:.75rem;color:#fff!important;font-weight:400;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;justify-content:center;align-items:center}.p-progressbar-determinate .p-progressbar-value-animate{background-color:#004172!important;transition:width 1s ease-in-out}.p-progressbar-indeterminate .p-progressbar-value:before{background-color:#004172!important;content:\"\";position:absolute;background-color:inherit;top:0;left:0;bottom:0;will-change:left,right;-webkit-animation:p-progressbar-indeterminate-anim 2.1s cubic-bezier(.65,.815,.735,.395) infinite;animation:p-progressbar-indeterminate-anim 2.1s cubic-bezier(.65,.815,.735,.395) infinite}.p-progressbar-indeterminate .p-progressbar-value:after{background-color:#004172!important;content:\"\";position:absolute;background-color:inherit;top:0;left:0;bottom:0;will-change:left,right;-webkit-animation:p-progressbar-indeterminate-anim-short 2.1s cubic-bezier(.165,.84,.44,1) infinite;animation:p-progressbar-indeterminate-anim-short 2.1s cubic-bezier(.165,.84,.44,1) infinite;-webkit-animation-delay:1.15s;animation-delay:1.15s}}@-webkit-keyframes p-progressbar-indeterminate-anim{0%{left:-35%;right:100%}60%{left:100%;right:-90%}to{left:100%;right:-90%}}@keyframes p-progressbar-indeterminate-anim{0%{left:-35%;right:100%}60%{left:100%;right:-90%}to{left:100%;right:-90%}}@-webkit-keyframes p-progressbar-indeterminate-anim-short{0%{left:-200%;right:100%}60%{left:107%;right:-8%}to{left:107%;right:-8%}}@keyframes p-progressbar-indeterminate-anim-short{0%{left:-200%;right:100%}60%{left:107%;right:-8%}to{left:107%;right:-8%}}\n"] }]
|
|
33
|
+
}], propDecorators: { value: [{
|
|
34
|
+
type: Input
|
|
35
|
+
}], maxValue: [{
|
|
36
|
+
type: Input
|
|
37
|
+
}], label: [{
|
|
38
|
+
type: Input
|
|
39
|
+
}], showValue: [{
|
|
40
|
+
type: Input
|
|
41
|
+
}], showLabel: [{
|
|
42
|
+
type: Input
|
|
43
|
+
}], styleClass: [{
|
|
44
|
+
type: Input
|
|
45
|
+
}], labelStyleClass: [{
|
|
46
|
+
type: Input
|
|
47
|
+
}], barStyleClass: [{
|
|
48
|
+
type: Input
|
|
49
|
+
}], style: [{
|
|
50
|
+
type: Input
|
|
51
|
+
}], unit: [{
|
|
52
|
+
type: Input
|
|
53
|
+
}], mode: [{
|
|
54
|
+
type: Input
|
|
55
|
+
}], color: [{
|
|
56
|
+
type: Input
|
|
57
|
+
}] } });
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3YtcHJvZ3Jlc3MtYmFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2t2LXByb2dyZXNzLWJhci9rdi1wcm9ncmVzcy1iYXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMva3YtcHJvZ3Jlc3MtYmFyL2t2LXByb2dyZXNzLWJhci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBT2pELE1BQU0sT0FBTyxvQkFBb0I7SUFMakM7UUF3QkU7OztXQUdHO1FBQ00sY0FBUyxHQUFZLElBQUksQ0FBQztRQUNuQzs7O1dBR0c7UUFDTSxjQUFTLEdBQVksSUFBSSxDQUFDO1FBd0JuQzs7O1dBR0c7UUFDTSxTQUFJLEdBQVcsR0FBRyxDQUFDO1FBQzVCOzs7V0FHRztRQUNNLFNBQUksR0FBb0MsYUFBYSxDQUFDO0tBTWhFOzhHQW5FWSxvQkFBb0I7a0dBQXBCLG9CQUFvQixtVUNQakMseTZDQXNDQTs7MkZEL0JhLG9CQUFvQjtrQkFMaEMsU0FBUzsrQkFDRSxpQkFBaUI7OEJBU2xCLEtBQUs7c0JBQWIsS0FBSztnQkFNRyxRQUFRO3NCQUFoQixLQUFLO2dCQU1HLEtBQUs7c0JBQWIsS0FBSztnQkFNRyxTQUFTO3NCQUFqQixLQUFLO2dCQUtHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBS0csVUFBVTtzQkFBbEIsS0FBSztnQkFNRyxlQUFlO3NCQUF2QixLQUFLO2dCQU1HLGFBQWE7c0JBQXJCLEtBQUs7Z0JBTUcsS0FBSztzQkFBYixLQUFLO2dCQUtHLElBQUk7c0JBQVosS0FBSztnQkFLRyxJQUFJO3NCQUFaLEtBQUs7Z0JBS0csS0FBSztzQkFBYixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdrdi1wcm9ncmVzcy1iYXInLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9rdi1wcm9ncmVzcy1iYXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2t2LXByb2dyZXNzLWJhci5jb21wb25lbnQuc2NzcyddLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgUHJvZ3Jlc3NCYXJDb21wb25lbnQge1xyXG4gIC8qKlxyXG4gICAqIEN1cnJlbnQgdmFsdWUgb2YgdGhlIHByb2dyZXNzLlxyXG4gICAqIEBncm91cCBQcm9wc1xyXG4gICAqL1xyXG4gIEBJbnB1dCgpIHZhbHVlOiBudW1iZXIgfCB1bmRlZmluZWQ7XHJcblxyXG4gIC8qKlxyXG4gICAqIE1heCB2YWx1ZSBvZiB0aGUgcHJvZ3Jlc3MuXHJcbiAgICogQGdyb3VwIFByb3BzXHJcbiAgICovXHJcbiAgQElucHV0KCkgbWF4VmFsdWU6IG51bWJlciB8IHVuZGVmaW5lZDtcclxuXHJcbiAgLyoqXHJcbiAgICogTGFiZWwgdmFsdWUgb2YgdGhlIHByb2dyZXNzLlxyXG4gICAqIEBncm91cCBQcm9wc1xyXG4gICAqL1xyXG4gIEBJbnB1dCgpIGxhYmVsOiBzdHJpbmcgfCB1bmRlZmluZWQ7XHJcblxyXG4gIC8qKlxyXG4gICAqIFdoZXRoZXIgdG8gZGlzcGxheSB0aGUgcHJvZ3Jlc3MgYmFyIHZhbHVlLlxyXG4gICAqIEBncm91cCBQcm9wc1xyXG4gICAqL1xyXG4gIEBJbnB1dCgpIHNob3dWYWx1ZTogYm9vbGVhbiA9IHRydWU7XHJcbiAgLyoqXHJcbiAgICogV2hldGhlciB0byBkaXNwbGF5IHRoZSBwcm9ncmVzcyBiYXIgdmFsdWUuXHJcbiAgICogQGdyb3VwIFByb3BzXHJcbiAgICovXHJcbiAgQElucHV0KCkgc2hvd0xhYmVsOiBib29sZWFuID0gdHJ1ZTtcclxuICAvKipcclxuICAgKiBDbGFzcyBvZiB0aGUgZWxlbWVudC5cclxuICAgKiBAZ3JvdXAgUHJvcHNcclxuICAgKi9cclxuICBASW5wdXQoKSBzdHlsZUNsYXNzOiBzdHJpbmcgfCB1bmRlZmluZWQ7XHJcblxyXG4gIC8qKlxyXG4gICAqIENsYXNzIG9mIHRoZSBlbGVtZW50LlxyXG4gICAqIEBncm91cCBQcm9wc1xyXG4gICAqL1xyXG4gIEBJbnB1dCgpIGxhYmVsU3R5bGVDbGFzczogc3RyaW5nIHwgdW5kZWZpbmVkO1xyXG5cclxuICAvKipcclxuICAgKiBDbGFzcyBvZiB0aGUgZWxlbWVudC5cclxuICAgKiBAZ3JvdXAgUHJvcHNcclxuICAgKi9cclxuICBASW5wdXQoKSBiYXJTdHlsZUNsYXNzOiBzdHJpbmcgfCB1bmRlZmluZWQ7XHJcblxyXG4gIC8qKlxyXG4gICAqIElubGluZSBzdHlsZSBvZiB0aGUgZWxlbWVudC5cclxuICAgKiBAZ3JvdXAgUHJvcHNcclxuICAgKi9cclxuICBASW5wdXQoKSBzdHlsZTogeyBba2xhc3M6IHN0cmluZ106IGFueSB9IHwgbnVsbCB8IHVuZGVmaW5lZDtcclxuICAvKipcclxuICAgKiBVbml0IHNpZ24gYXBwZW5kZWQgdG8gdGhlIHZhbHVlLlxyXG4gICAqIEBncm91cCBQcm9wc1xyXG4gICAqL1xyXG4gIEBJbnB1dCgpIHVuaXQ6IHN0cmluZyA9ICclJztcclxuICAvKipcclxuICAgKiBEZWZpbmVzIHRoZSBtb2RlIG9mIHRoZSBwcm9ncmVzc1xyXG4gICAqIEBncm91cCBQcm9wc1xyXG4gICAqL1xyXG4gIEBJbnB1dCgpIG1vZGU6ICdkZXRlcm1pbmF0ZScgfCAnaW5kZXRlcm1pbmF0ZScgPSAnZGV0ZXJtaW5hdGUnO1xyXG4gIC8qKlxyXG4gICAqIENvbG9yIGZvciB0aGUgYmFja2dyb3VuZCBvZiB0aGUgcHJvZ3Jlc3MuXHJcbiAgICogQGdyb3VwIFByb3BzXHJcbiAgICovXHJcbiAgQElucHV0KCkgY29sb3I6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxufVxyXG4iLCI8ZGl2XHJcbiAgcm9sZT1cInByb2dyZXNzYmFyXCJcclxuICBbY2xhc3NdPVwic3R5bGVDbGFzcyA/IHN0eWxlQ2xhc3MgOiAnJ1wiXHJcbiAgW25nU3R5bGVdPVwic3R5bGVcIlxyXG4gIFthdHRyLmFyaWEtdmFsdWVtaW5dPVwiMFwiXHJcbiAgW2F0dHIuYXJpYS12YWx1ZW5vd109XCJ2YWx1ZVwiXHJcbiAgW2F0dHIuYXJpYS12YWx1ZW1heF09XCIxMDBcIlxyXG4gIFthdHRyLmRhdGEtcGMtbmFtZV09XCIncHJvZ3Jlc3NiYXInXCJcclxuICBbYXR0ci5kYXRhLXBjLXNlY3Rpb25dPVwiJ3Jvb3QnXCJcclxuICBbbmdDbGFzc109XCJ7J3AtcHJvZ3Jlc3NiYXIgcC1jb21wb25lbnQnOiB0cnVlLCAncC1wcm9ncmVzc2Jhci1kZXRlcm1pbmF0ZSc6IG1vZGUgPT09ICdkZXRlcm1pbmF0ZScsICdwLXByb2dyZXNzYmFyLWluZGV0ZXJtaW5hdGUnOiBtb2RlID09PSAnaW5kZXRlcm1pbmF0ZSd9XCJcclxuPlxyXG4gIEBpZihtb2RlID09PSAnZGV0ZXJtaW5hdGUnKSB7XHJcbiAgPGRpdiBjbGFzcz1cInAtcHJvZ3Jlc3NiYXItdmFsdWUgcC1wcm9ncmVzc2Jhci12YWx1ZS1hbmltYXRlIHt7IGJhclN0eWxlQ2xhc3MgfX0gZm9udC1zZW1pYm9sZFwiXHJcbiAgICBbc3R5bGUud2lkdGhdPVwibWF4VmFsdWUgJiYgdmFsdWUgPyAodmFsdWUgLyBtYXhWYWx1ZSkgKiAxMDAgKyAnJScgOiB2YWx1ZSArICclJ1wiXHJcbiAgICBbYXR0ci5kYXRhLXBjLXNlY3Rpb25dPVwiJ3ZhbHVlJ1wiXHJcbiAgPjwvZGl2PlxyXG5cclxuICA8ZGl2XHJcbiAgICBjbGFzcz1cInAtcHJvZ3Jlc3NiYXItbGFiZWwge3sgbGFiZWxTdHlsZUNsYXNzIH19IHctZnVsbFwiXHJcbiAgICBbYXR0ci5kYXRhLXBjLXNlY3Rpb25dPVwiJ2xhYmVsJ1wiXHJcbiAgPlxyXG4gICAgPGxhYmVsICpuZ0lmPVwic2hvd1ZhbHVlICYmIG1heFZhbHVlXCI+e3sgdmFsdWUgfX0ve3sgbWF4VmFsdWUgfX08L2xhYmVsPlxyXG4gICAgPGxhYmVsICpuZ0lmPVwic2hvd1ZhbHVlICYmICFtYXhWYWx1ZVwiPnt7IHZhbHVlIH19JTwvbGFiZWw+XHJcbiAgICA8bGFiZWwgKm5nSWY9XCJzaG93TGFiZWxcIj57eyBsYWJlbCB9fTwvbGFiZWw+XHJcbiAgPC9kaXY+XHJcbiAgfSBAaWYobW9kZSA9PT0gJ2luZGV0ZXJtaW5hdGUnKSB7XHJcbiAgPGRpdlxyXG4gICAgY2xhc3M9XCJwLXByb2dyZXNzYmFyLWluZGV0ZXJtaW5hdGUtY29udGFpbmVyXCJcclxuICAgIFthdHRyLmRhdGEtcGMtc2VjdGlvbl09XCInY29udGFpbmVyJ1wiXHJcbiAgPlxyXG4gICAgPGRpdlxyXG4gICAgICBjbGFzcz1cInAtcHJvZ3Jlc3NiYXItdmFsdWUgcC1wcm9ncmVzc2Jhci12YWx1ZS1hbmltYXRlXCJcclxuICAgICAgW3N0eWxlLmJhY2tncm91bmRdPVwiY29sb3JcIlxyXG4gICAgICBbYXR0ci5kYXRhLXBjLXNlY3Rpb25dPVwiJ3ZhbHVlJ1wiXHJcbiAgICA+PC9kaXY+XHJcbiAgPC9kaXY+XHJcbiAgfVxyXG48L2Rpdj5cclxuIl19
|