keevo-components 2.0.274 → 2.0.276
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/lib/components/kv-instruction-page/kv-instruction-page.component.mjs +57 -11
- package/esm2022/lib/components/kv-table/kv-table.component.mjs +3 -3
- package/fesm2022/keevo-components.mjs +57 -9
- package/fesm2022/keevo-components.mjs.map +1 -1
- package/lib/components/kv-instruction-page/kv-instruction-page.component.d.ts +13 -4
- package/package.json +1 -1
|
@@ -1,29 +1,75 @@
|
|
|
1
|
-
import { Component, computed, input } from '@angular/core';
|
|
1
|
+
import { Component, computed, input, HostListener, signal, ChangeDetectionStrategy } from '@angular/core';
|
|
2
2
|
import { KvButtonModule } from '../kv-button/kv-button.module';
|
|
3
3
|
import { DividerModule } from 'primeng/divider';
|
|
4
4
|
import { KvCardsInstructionComponent } from './components/cards-instruction/kv-cards-instruction.component';
|
|
5
|
-
import { SidebarModule } from 'primeng/sidebar';
|
|
6
5
|
import * as i0 from "@angular/core";
|
|
7
6
|
import * as i1 from "../kv-button/kv-button.component";
|
|
8
|
-
import * as i2 from "primeng/sidebar";
|
|
9
7
|
export class KvInstructionPageComponent {
|
|
10
8
|
constructor() {
|
|
11
9
|
this.actions = input([]);
|
|
12
10
|
this.camposObrigatorios = input(false);
|
|
11
|
+
// Define se o painel inicia aberto (true) ou fechado (false). Por padrão é true no desktop.
|
|
12
|
+
this.startExpanded = input(true);
|
|
13
13
|
this.whiteCard = input(undefined);
|
|
14
14
|
this.blackCard = input();
|
|
15
|
-
this.
|
|
15
|
+
this.isMobile = signal(false);
|
|
16
|
+
this.userToggledPanel = signal(null);
|
|
17
|
+
this.isPanelExpanded = computed(() => {
|
|
18
|
+
// 1. Respeita a interação manual do usuário primeiro
|
|
19
|
+
const toggled = this.userToggledPanel();
|
|
20
|
+
if (toggled !== null)
|
|
21
|
+
return toggled;
|
|
22
|
+
// 2. Se for mobile, inicia sempre fechado como padrão por UX
|
|
23
|
+
if (this.isMobile())
|
|
24
|
+
return false;
|
|
25
|
+
// 3. Respeita a propriedade (true ou false) definida pelo desenvolvedor na tela via @Input
|
|
26
|
+
return this.startExpanded();
|
|
27
|
+
});
|
|
28
|
+
this.mainContentWidth = computed(() => {
|
|
29
|
+
if (!this.whiteCard() && !this.blackCard())
|
|
30
|
+
return '100%';
|
|
31
|
+
const expanded = this.isPanelExpanded();
|
|
32
|
+
const mobile = this.isMobile();
|
|
33
|
+
if (mobile)
|
|
34
|
+
return expanded ? '0%' : '100%';
|
|
35
|
+
return expanded ? 'calc(75% - 0.25rem)' : '100%';
|
|
36
|
+
});
|
|
37
|
+
this.panelWidth = computed(() => {
|
|
16
38
|
if (!this.whiteCard() && !this.blackCard())
|
|
17
|
-
return '
|
|
18
|
-
|
|
39
|
+
return '0%';
|
|
40
|
+
const expanded = this.isPanelExpanded();
|
|
41
|
+
const mobile = this.isMobile();
|
|
42
|
+
if (mobile)
|
|
43
|
+
return expanded ? '100%' : '0%';
|
|
44
|
+
return expanded ? 'calc(25% - 0.25rem)' : '0%';
|
|
19
45
|
});
|
|
20
|
-
|
|
46
|
+
}
|
|
47
|
+
ngOnInit() {
|
|
48
|
+
this.checkMobileState();
|
|
49
|
+
}
|
|
50
|
+
onResize() {
|
|
51
|
+
this.checkMobileState();
|
|
52
|
+
}
|
|
53
|
+
checkMobileState() {
|
|
54
|
+
if (typeof window !== 'undefined') {
|
|
55
|
+
const isMob = window.innerWidth < 1024;
|
|
56
|
+
// Atualiza o sinal apenas se houver mudança real, economiza ciclos do Change Detection
|
|
57
|
+
if (this.isMobile() !== isMob) {
|
|
58
|
+
this.isMobile.set(isMob);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
togglePanel() {
|
|
63
|
+
this.userToggledPanel.set(!this.isPanelExpanded());
|
|
21
64
|
}
|
|
22
65
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvInstructionPageComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
23
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvInstructionPageComponent, isStandalone: true, selector: "kv-instruction-page", inputs: { actions: { classPropertyName: "actions", publicName: "actions", isSignal: true, isRequired: false, transformFunction: null }, camposObrigatorios: { classPropertyName: "camposObrigatorios", publicName: "camposObrigatorios", isSignal: true, isRequired: false, transformFunction: null }, whiteCard: { classPropertyName: "whiteCard", publicName: "whiteCard", isSignal: true, isRequired: false, transformFunction: null }, blackCard: { classPropertyName: "blackCard", publicName: "blackCard", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"h-full flex flex-column overflow-hidden\">\
|
|
66
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvInstructionPageComponent, isStandalone: true, selector: "kv-instruction-page", inputs: { actions: { classPropertyName: "actions", publicName: "actions", isSignal: true, isRequired: false, transformFunction: null }, camposObrigatorios: { classPropertyName: "camposObrigatorios", publicName: "camposObrigatorios", isSignal: true, isRequired: false, transformFunction: null }, startExpanded: { classPropertyName: "startExpanded", publicName: "startExpanded", isSignal: true, isRequired: false, transformFunction: null }, whiteCard: { classPropertyName: "whiteCard", publicName: "whiteCard", isSignal: true, isRequired: false, transformFunction: null }, blackCard: { classPropertyName: "blackCard", publicName: "blackCard", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "window:resize": "onResize()" } }, ngImport: i0, template: "<div class=\"h-full flex flex-column overflow-hidden relative\">\n <div class=\"flex-1 min-h-0 flex flex-row p-2 justify-content-between relative overflow-hidden\">\n <!-- Main Content Container -->\n <div class=\"h-full max-h-full transition-all duration-300 ease-in-out overflow-y-auto flex-shrink-0\"\n [style.width]=\"mainContentWidth()\" [class.opacity-0]=\"isMobile() && isPanelExpanded()\">\n <ng-content select=\"[main-content]\"></ng-content>\n </div>\n\n <!-- Instruction Page Panel (Side) -->\n <div class=\"h-full transition-all duration-300 ease-in-out flex-shrink-0 overflow-y-auto\"\n [style.width]=\"panelWidth()\" [class.opacity-0]=\"!isPanelExpanded()\">\n <kv-cards-instruction [whiteCard]=\"whiteCard()\" [blackCard]=\"blackCard()\" class=\"block w-full h-full\">\n <div white-card-content class=\"h-full\">\n <ng-content select=\"[white-card-content]\"></ng-content>\n </div>\n <div black-card-content class=\"h-full\">\n <ng-content select=\"[black-card-content]\"></ng-content>\n </div>\n </kv-cards-instruction>\n </div>\n\n <!-- Floating Toggle Button -->\n @if (whiteCard() || blackCard()) {\n <kv-button [severity]=\"'secondary'\" [size]=\"'large'\" [type]=\"isPanelExpanded() ? 'text' : undefined\"\n [icon]=\"isPanelExpanded() ? 'close' : 'quick_reference'\"\n class=\"absolute z-50 transition-all duration-300 ease-in-out bg-white inline-flex border-round\"\n [style.top]=\"'1rem'\" [style.right]=\"'1rem'\" (onClick)=\"togglePanel()\">\n </kv-button>\n }\n </div>\n\n @if (actions().length > 0) {\n <div class=\"flex-initial flex-none flex flex-row justify-content-{{\n camposObrigatorios() ? 'between' : 'end'\n }} align-items-center p-2\">\n @if (camposObrigatorios()) {\n <span class=\"text-xs text-red-500 font-semibold\">* Preenchimento obrigat\u00F3rio</span>\n }\n\n <div class=\"flex flex-row justify-content-end gap-2\">\n @for (action of actions().slice().reverse(); track action.index) {\n <kv-button [label]=\"action.label || ''\" [severity]=\"action.severity || 'tertiary'\"\n [disabled]=\"action.disabled || false\" [type]=\"action.type\" [size]=\"action.size || 'small'\"\n [icon]=\"action.icon || ''\" [iconPosition]=\"action.iconPosition || 'left'\" [items]=\"action.items || []\"\n [popup]=\"action.popup || false\" [popupIcon]=\"action.popupIcon || false\" [fullWidth]=\"action.fullWidth || false\"\n (onClick)=\"action?.command($event)\"></kv-button>\n }\n </div>\n </div>\n }\n</div>", styles: [""], dependencies: [{ kind: "ngmodule", type: KvButtonModule }, { kind: "component", type: i1.KvButtonComponent, selector: "kv-button", inputs: ["fullWidth", "type", "loading", "severity", "size", "icon", "iconPosition", "label", "disabled", "items", "popup", "popupIcon"], outputs: ["iconChange", "onClick"] }, { kind: "ngmodule", type: DividerModule }, { kind: "component", type: KvCardsInstructionComponent, selector: "kv-cards-instruction", inputs: ["whiteCard", "blackCard"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
24
67
|
}
|
|
25
68
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvInstructionPageComponent, decorators: [{
|
|
26
69
|
type: Component,
|
|
27
|
-
args: [{ selector: 'kv-instruction-page', standalone: true, imports: [KvButtonModule, DividerModule, KvCardsInstructionComponent,
|
|
28
|
-
}]
|
|
29
|
-
|
|
70
|
+
args: [{ selector: 'kv-instruction-page', standalone: true, imports: [KvButtonModule, DividerModule, KvCardsInstructionComponent], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"h-full flex flex-column overflow-hidden relative\">\n <div class=\"flex-1 min-h-0 flex flex-row p-2 justify-content-between relative overflow-hidden\">\n <!-- Main Content Container -->\n <div class=\"h-full max-h-full transition-all duration-300 ease-in-out overflow-y-auto flex-shrink-0\"\n [style.width]=\"mainContentWidth()\" [class.opacity-0]=\"isMobile() && isPanelExpanded()\">\n <ng-content select=\"[main-content]\"></ng-content>\n </div>\n\n <!-- Instruction Page Panel (Side) -->\n <div class=\"h-full transition-all duration-300 ease-in-out flex-shrink-0 overflow-y-auto\"\n [style.width]=\"panelWidth()\" [class.opacity-0]=\"!isPanelExpanded()\">\n <kv-cards-instruction [whiteCard]=\"whiteCard()\" [blackCard]=\"blackCard()\" class=\"block w-full h-full\">\n <div white-card-content class=\"h-full\">\n <ng-content select=\"[white-card-content]\"></ng-content>\n </div>\n <div black-card-content class=\"h-full\">\n <ng-content select=\"[black-card-content]\"></ng-content>\n </div>\n </kv-cards-instruction>\n </div>\n\n <!-- Floating Toggle Button -->\n @if (whiteCard() || blackCard()) {\n <kv-button [severity]=\"'secondary'\" [size]=\"'large'\" [type]=\"isPanelExpanded() ? 'text' : undefined\"\n [icon]=\"isPanelExpanded() ? 'close' : 'quick_reference'\"\n class=\"absolute z-50 transition-all duration-300 ease-in-out bg-white inline-flex border-round\"\n [style.top]=\"'1rem'\" [style.right]=\"'1rem'\" (onClick)=\"togglePanel()\">\n </kv-button>\n }\n </div>\n\n @if (actions().length > 0) {\n <div class=\"flex-initial flex-none flex flex-row justify-content-{{\n camposObrigatorios() ? 'between' : 'end'\n }} align-items-center p-2\">\n @if (camposObrigatorios()) {\n <span class=\"text-xs text-red-500 font-semibold\">* Preenchimento obrigat\u00F3rio</span>\n }\n\n <div class=\"flex flex-row justify-content-end gap-2\">\n @for (action of actions().slice().reverse(); track action.index) {\n <kv-button [label]=\"action.label || ''\" [severity]=\"action.severity || 'tertiary'\"\n [disabled]=\"action.disabled || false\" [type]=\"action.type\" [size]=\"action.size || 'small'\"\n [icon]=\"action.icon || ''\" [iconPosition]=\"action.iconPosition || 'left'\" [items]=\"action.items || []\"\n [popup]=\"action.popup || false\" [popupIcon]=\"action.popupIcon || false\" [fullWidth]=\"action.fullWidth || false\"\n (onClick)=\"action?.command($event)\"></kv-button>\n }\n </div>\n </div>\n }\n</div>" }]
|
|
71
|
+
}], propDecorators: { onResize: [{
|
|
72
|
+
type: HostListener,
|
|
73
|
+
args: ['window:resize']
|
|
74
|
+
}] } });
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-instruction-page.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-instruction-page/kv-instruction-page.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-instruction-page/kv-instruction-page.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, input, HostListener, signal, ChangeDetectionStrategy, OnInit } from '@angular/core';\r\nimport { KvButtonModule } from '../kv-button/kv-button.module';\r\nimport { ButtonModel } from '../../api/components/button/button.model';\r\nimport { DividerModule } from 'primeng/divider';\r\nimport { KvCardsInstructionComponent } from './components/cards-instruction/kv-cards-instruction.component';\r\n\r\n@Component({\r\n  selector: 'kv-instruction-page',\r\n  standalone: true,\r\n  imports: [KvButtonModule, DividerModule, KvCardsInstructionComponent],\r\n  templateUrl: './kv-instruction-page.component.html',\r\n  styleUrl: './kv-instruction-page.component.scss',\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class KvInstructionPageComponent implements OnInit {\r\n\r\n  actions = input<ButtonModel[]>([]);\r\n  camposObrigatorios = input<boolean>(false);\r\n  \r\n  // Define se o painel inicia aberto (true) ou fechado (false). Por padrão é true no desktop.\r\n  startExpanded = input<boolean>(true); \r\n\r\n  whiteCard = input<{\r\n    title: string;\r\n    icon: string;\r\n    height: number;\r\n  } | undefined>(undefined);\r\n\r\n  blackCard = input<{\r\n    title: string;\r\n    icon: string;\r\n    height: number;\r\n  } | undefined>();\r\n\r\n  isMobile = signal<boolean>(false);\r\n  private userToggledPanel = signal<boolean | null>(null);\r\n\r\n  ngOnInit() {\r\n    this.checkMobileState();\r\n  }\r\n\r\n  @HostListener('window:resize')\r\n  onResize() {\r\n    this.checkMobileState();\r\n  }\r\n\r\n  private checkMobileState() {\r\n     if (typeof window !== 'undefined') {\r\n        const isMob = window.innerWidth < 1024;\r\n        // Atualiza o sinal apenas se houver mudança real, economiza ciclos do Change Detection\r\n        if (this.isMobile() !== isMob) {\r\n           this.isMobile.set(isMob);\r\n        }\r\n     }\r\n  }\r\n\r\n  isPanelExpanded = computed(() => {\r\n    // 1. Respeita a interação manual do usuário primeiro\r\n    const toggled = this.userToggledPanel();\r\n    if (toggled !== null) return toggled;\r\n    \r\n    // 2. Se for mobile, inicia sempre fechado como padrão por UX\r\n    if (this.isMobile()) return false;\r\n    \r\n    // 3. Respeita a propriedade (true ou false) definida pelo desenvolvedor na tela via @Input\r\n    return this.startExpanded();\r\n  });\r\n\r\n  togglePanel() {\r\n    this.userToggledPanel.set(!this.isPanelExpanded());\r\n  }\r\n\r\n  mainContentWidth = computed(() => {\r\n    if (!this.whiteCard() && !this.blackCard()) return '100%';\r\n    const expanded = this.isPanelExpanded();\r\n    const mobile = this.isMobile();\r\n    if (mobile) return expanded ? '0%' : '100%';\r\n    return expanded ? 'calc(75% - 0.25rem)' : '100%';\r\n  });\r\n\r\n  panelWidth = computed(() => {\r\n    if (!this.whiteCard() && !this.blackCard()) return '0%';\r\n    const expanded = this.isPanelExpanded();\r\n    const mobile = this.isMobile();\r\n    if (mobile) return expanded ? '100%' : '0%';\r\n    return expanded ? 'calc(25% - 0.25rem)' : '0%';\r\n  });\r\n\r\n}\r\n","<div class=\"h-full flex flex-column overflow-hidden relative\">\n  <div class=\"flex-1 min-h-0 flex flex-row p-2 justify-content-between relative overflow-hidden\">\n    <!-- Main Content Container -->\n    <div class=\"h-full max-h-full transition-all duration-300 ease-in-out overflow-y-auto flex-shrink-0\"\n      [style.width]=\"mainContentWidth()\" [class.opacity-0]=\"isMobile() && isPanelExpanded()\">\n      <ng-content select=\"[main-content]\"></ng-content>\n    </div>\n\n    <!-- Instruction Page Panel (Side) -->\n    <div class=\"h-full transition-all duration-300 ease-in-out flex-shrink-0 overflow-y-auto\"\n      [style.width]=\"panelWidth()\" [class.opacity-0]=\"!isPanelExpanded()\">\n      <kv-cards-instruction [whiteCard]=\"whiteCard()\" [blackCard]=\"blackCard()\" class=\"block w-full h-full\">\n        <div white-card-content class=\"h-full\">\n          <ng-content select=\"[white-card-content]\"></ng-content>\n        </div>\n        <div black-card-content class=\"h-full\">\n          <ng-content select=\"[black-card-content]\"></ng-content>\n        </div>\n      </kv-cards-instruction>\n    </div>\n\n    <!-- Floating Toggle Button -->\n    @if (whiteCard() || blackCard()) {\n    <kv-button [severity]=\"'secondary'\" [size]=\"'large'\" [type]=\"isPanelExpanded() ? 'text' : undefined\"\n      [icon]=\"isPanelExpanded() ? 'close' : 'quick_reference'\"\n      class=\"absolute z-50 transition-all duration-300 ease-in-out bg-white inline-flex border-round\"\n      [style.top]=\"'1rem'\" [style.right]=\"'1rem'\" (onClick)=\"togglePanel()\">\n    </kv-button>\n    }\n  </div>\n\n  @if (actions().length > 0) {\n  <div class=\"flex-initial flex-none flex flex-row justify-content-{{\n        camposObrigatorios() ? 'between' : 'end'\n      }} align-items-center p-2\">\n    @if (camposObrigatorios()) {\n    <span class=\"text-xs text-red-500 font-semibold\">* Preenchimento obrigatório</span>\n    }\n\n    <div class=\"flex flex-row justify-content-end gap-2\">\n      @for (action of actions().slice().reverse(); track action.index) {\n      <kv-button [label]=\"action.label || ''\" [severity]=\"action.severity || 'tertiary'\"\n        [disabled]=\"action.disabled || false\" [type]=\"action.type\" [size]=\"action.size || 'small'\"\n        [icon]=\"action.icon || ''\" [iconPosition]=\"action.iconPosition || 'left'\" [items]=\"action.items || []\"\n        [popup]=\"action.popup || false\" [popupIcon]=\"action.popupIcon || false\" [fullWidth]=\"action.fullWidth || false\"\n        (onClick)=\"action?.command($event)\"></kv-button>\n      }\n    </div>\n  </div>\n  }\n</div>"]}
|