@piying-lib/angular-daisyui 1.0.0
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/README.md +64 -0
- package/extension/index.d.ts +449 -0
- package/fesm2022/piying-lib-angular-daisyui-extension.mjs +1356 -0
- package/fesm2022/piying-lib-angular-daisyui-extension.mjs.map +1 -0
- package/fesm2022/piying-lib-angular-daisyui-field-control-props.directive-C5mF89PX.mjs +27 -0
- package/fesm2022/piying-lib-angular-daisyui-field-control-props.directive-C5mF89PX.mjs.map +1 -0
- package/fesm2022/piying-lib-angular-daisyui-field-control.mjs +616 -0
- package/fesm2022/piying-lib-angular-daisyui-field-control.mjs.map +1 -0
- package/fesm2022/piying-lib-angular-daisyui-field-group.mjs +345 -0
- package/fesm2022/piying-lib-angular-daisyui-field-group.mjs.map +1 -0
- package/fesm2022/piying-lib-angular-daisyui-non-field-control.mjs +452 -0
- package/fesm2022/piying-lib-angular-daisyui-non-field-control.mjs.map +1 -0
- package/fesm2022/piying-lib-angular-daisyui-pipe.mjs +55 -0
- package/fesm2022/piying-lib-angular-daisyui-pipe.mjs.map +1 -0
- package/fesm2022/piying-lib-angular-daisyui-service.mjs +115 -0
- package/fesm2022/piying-lib-angular-daisyui-service.mjs.map +1 -0
- package/fesm2022/piying-lib-angular-daisyui-wrapper.mjs +75 -0
- package/fesm2022/piying-lib-angular-daisyui-wrapper.mjs.map +1 -0
- package/fesm2022/piying-lib-angular-daisyui.mjs +4 -0
- package/fesm2022/piying-lib-angular-daisyui.mjs.map +1 -0
- package/field-control/index.d.ts +204 -0
- package/field-group/index.d.ts +162 -0
- package/index.d.ts +2 -0
- package/non-field-control/index.d.ts +255 -0
- package/package.json +54 -0
- package/pipe/index.d.ts +25 -0
- package/preset-css/css/style.css +1 -0
- package/preset-css/css/style.split.css +126 -0
- package/preset-css/json/manifest.json +739 -0
- package/preset-css/ts/accordion.ts +9 -0
- package/preset-css/ts/alert.ts +12 -0
- package/preset-css/ts/avatar.ts +7 -0
- package/preset-css/ts/badge.ts +20 -0
- package/preset-css/ts/breadcrumbs.ts +1 -0
- package/preset-css/ts/browser-mockup.ts +1 -0
- package/preset-css/ts/button.ts +27 -0
- package/preset-css/ts/calendar.ts +1 -0
- package/preset-css/ts/card.ts +15 -0
- package/preset-css/ts/carousel.ts +9 -0
- package/preset-css/ts/chat-bubble.ts +17 -0
- package/preset-css/ts/checkbox.ts +16 -0
- package/preset-css/ts/code-mockup.ts +1 -0
- package/preset-css/ts/collapse.ts +9 -0
- package/preset-css/ts/countdown.ts +1 -0
- package/preset-css/ts/diff.ts +1 -0
- package/preset-css/ts/divider.ts +15 -0
- package/preset-css/ts/dock.ts +10 -0
- package/preset-css/ts/drawer-sidebar.ts +11 -0
- package/preset-css/ts/dropdown.ts +13 -0
- package/preset-css/ts/fab-speed-dial.ts +1 -0
- package/preset-css/ts/fieldset.ts +1 -0
- package/preset-css/ts/file-input.ts +17 -0
- package/preset-css/ts/filter.ts +1 -0
- package/preset-css/ts/footer.ts +7 -0
- package/preset-css/ts/hero.ts +1 -0
- package/preset-css/ts/hover-gallery.ts +1 -0
- package/preset-css/ts/index.ts +63 -0
- package/preset-css/ts/indicator.ts +10 -0
- package/preset-css/ts/join.ts +1 -0
- package/preset-css/ts/kbd.ts +1 -0
- package/preset-css/ts/label.ts +1 -0
- package/preset-css/ts/link.ts +12 -0
- package/preset-css/ts/list.ts +1 -0
- package/preset-css/ts/loading.ts +14 -0
- package/preset-css/ts/mask.ts +20 -0
- package/preset-css/ts/menu.ts +17 -0
- package/preset-css/ts/modal.ts +13 -0
- package/preset-css/ts/navbar.ts +1 -0
- package/preset-css/ts/pagination.ts +1 -0
- package/preset-css/ts/phone-mockup.ts +5 -0
- package/preset-css/ts/progress.ts +11 -0
- package/preset-css/ts/radial-progress.ts +1 -0
- package/preset-css/ts/radio.ts +16 -0
- package/preset-css/ts/range-slider.ts +16 -0
- package/preset-css/ts/rating.ts +10 -0
- package/preset-css/ts/select.ts +17 -0
- package/preset-css/ts/skeleton.ts +1 -0
- package/preset-css/ts/stack.ts +1 -0
- package/preset-css/ts/stat.ts +11 -0
- package/preset-css/ts/status.ts +16 -0
- package/preset-css/ts/steps.ts +15 -0
- package/preset-css/ts/swap.ts +9 -0
- package/preset-css/ts/table.ts +11 -0
- package/preset-css/ts/tabs.ts +17 -0
- package/preset-css/ts/text-input.ts +17 -0
- package/preset-css/ts/textarea.ts +17 -0
- package/preset-css/ts/theme-controller.ts +1 -0
- package/preset-css/ts/timeline.ts +11 -0
- package/preset-css/ts/toast.ts +9 -0
- package/preset-css/ts/toggle.ts +16 -0
- package/preset-css/ts/tooltip.ts +17 -0
- package/preset-css/ts/validator.ts +1 -0
- package/preset-css/ts/window-mockup.ts +1 -0
- package/service/index.d.ts +42 -0
- package/wrapper/index.d.ts +27 -0
|
@@ -0,0 +1,345 @@
|
|
|
1
|
+
import { NgTemplateOutlet, NgClass, NgComponentOutlet } from '@angular/common';
|
|
2
|
+
import * as i0 from '@angular/core';
|
|
3
|
+
import { input, viewChild, inject, computed, Component, linkedSignal, model } from '@angular/core';
|
|
4
|
+
import { PurePipe } from '@cyia/ngx-common/pipe';
|
|
5
|
+
import { MergeClassPipe, CssPrefixPipe, TwPrefixPipe } from '@piying-lib/angular-daisyui/pipe';
|
|
6
|
+
import { useTwClass, ThemeService } from '@piying-lib/angular-daisyui/service';
|
|
7
|
+
import { PiyingViewGroupBase, AttributesDirective } from '@piying/view-angular';
|
|
8
|
+
import clsx from 'clsx';
|
|
9
|
+
import { MatIcon } from '@angular/material/icon';
|
|
10
|
+
import * as i1 from '@angular/forms';
|
|
11
|
+
import { FormsModule } from '@angular/forms';
|
|
12
|
+
import { SelectorlessOutlet } from '@cyia/ngx-common/directive';
|
|
13
|
+
import { StrOrTemplateComponent } from '@piying-lib/angular-core';
|
|
14
|
+
|
|
15
|
+
class AccordionItem {
|
|
16
|
+
constructor(field) { }
|
|
17
|
+
isActivated() { }
|
|
18
|
+
}
|
|
19
|
+
class AccordionFGC extends PiyingViewGroupBase {
|
|
20
|
+
static __version = 2;
|
|
21
|
+
static index = 0;
|
|
22
|
+
name = `accordion-${AccordionFGC.index++}`;
|
|
23
|
+
multi = input(false, ...(ngDevMode ? [{ debugName: "multi" }] : []));
|
|
24
|
+
templateRef = viewChild.required('templateRef');
|
|
25
|
+
childTitleFn = input((item) => {
|
|
26
|
+
return item.props()?.['title'] ?? item.keyPath?.slice(-1)[0] ?? '';
|
|
27
|
+
}, ...(ngDevMode ? [{ debugName: "childTitleFn" }] : []));
|
|
28
|
+
joinChild = input(true, ...(ngDevMode ? [{ debugName: "joinChild" }] : []));
|
|
29
|
+
collapseIcon = input(...(ngDevMode ? [undefined, { debugName: "collapseIcon" }] : []));
|
|
30
|
+
childClass = input(useTwClass('bg-base-100 border border-base-300'), ...(ngDevMode ? [{ debugName: "childClass" }] : []));
|
|
31
|
+
#theme = inject(ThemeService);
|
|
32
|
+
childClass$$ = computed(() => {
|
|
33
|
+
return clsx(this.#theme.addPrefix2('collapse', this.collapseIcon()), this.childClass(), this.joinChild() ? this.#theme.addPrefix('join-item') : undefined);
|
|
34
|
+
}, ...(ngDevMode ? [{ debugName: "childClass$$" }] : []));
|
|
35
|
+
childName = (multi, index) => {
|
|
36
|
+
if (multi) {
|
|
37
|
+
return `${this.name}-${index}`;
|
|
38
|
+
}
|
|
39
|
+
return this.name;
|
|
40
|
+
};
|
|
41
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: AccordionFGC, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
42
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.14", type: AccordionFGC, isStandalone: true, selector: "app-accordion", inputs: { multi: { classPropertyName: "multi", publicName: "multi", isSignal: true, isRequired: false, transformFunction: null }, childTitleFn: { classPropertyName: "childTitleFn", publicName: "childTitleFn", isSignal: true, isRequired: false, transformFunction: null }, joinChild: { classPropertyName: "joinChild", publicName: "joinChild", isSignal: true, isRequired: false, transformFunction: null }, collapseIcon: { classPropertyName: "collapseIcon", publicName: "collapseIcon", isSignal: true, isRequired: false, transformFunction: null }, childClass: { classPropertyName: "childClass", publicName: "childClass", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "templateRef", first: true, predicate: ["templateRef"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<ng-template #mainTemp>\n @for (field of children$$(); track field.id || $index) {\n <div [class]=\"childClass$$() | mergeClass: ('collapse' | cssPrefix)\">\n <input\n type=\"radio\"\n [name]=\"childName | pure: multi() : $index\"\n [checked]=\"!!field.props()['checked']\"\n />\n <div class=\"{{ 'collapse-title' | cssPrefix }}\">\n {{ childTitleFn() | pure: field }}\n </div>\n <div class=\"{{ 'collapse-content' | cssPrefix }}\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </div>\n </div>\n }\n</ng-template>\n<ng-template #templateRef let-attr=\"attributes\">\n @if (joinChild()) {\n <div\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('join join-vertical' | cssPrefix)\"\n >\n <ng-container *ngTemplateOutlet=\"mainTemp\"></ng-container>\n </div>\n } @else {\n <ng-container *ngTemplateOutlet=\"mainTemp\"></ng-container>\n }\n</ng-template>\n", dependencies: [{ kind: "directive", type: AttributesDirective, selector: "[attributes]", inputs: ["attributes", "excludes"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: PurePipe, name: "pure" }, { kind: "pipe", type: MergeClassPipe, name: "mergeClass" }, { kind: "pipe", type: CssPrefixPipe, name: "cssPrefix" }] });
|
|
43
|
+
}
|
|
44
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: AccordionFGC, decorators: [{
|
|
45
|
+
type: Component,
|
|
46
|
+
args: [{ selector: 'app-accordion', imports: [AttributesDirective, NgTemplateOutlet, PurePipe, MergeClassPipe, CssPrefixPipe], template: "<ng-template #mainTemp>\n @for (field of children$$(); track field.id || $index) {\n <div [class]=\"childClass$$() | mergeClass: ('collapse' | cssPrefix)\">\n <input\n type=\"radio\"\n [name]=\"childName | pure: multi() : $index\"\n [checked]=\"!!field.props()['checked']\"\n />\n <div class=\"{{ 'collapse-title' | cssPrefix }}\">\n {{ childTitleFn() | pure: field }}\n </div>\n <div class=\"{{ 'collapse-content' | cssPrefix }}\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </div>\n </div>\n }\n</ng-template>\n<ng-template #templateRef let-attr=\"attributes\">\n @if (joinChild()) {\n <div\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('join join-vertical' | cssPrefix)\"\n >\n <ng-container *ngTemplateOutlet=\"mainTemp\"></ng-container>\n </div>\n } @else {\n <ng-container *ngTemplateOutlet=\"mainTemp\"></ng-container>\n }\n</ng-template>\n" }]
|
|
47
|
+
}], propDecorators: { multi: [{ type: i0.Input, args: [{ isSignal: true, alias: "multi", required: false }] }], templateRef: [{ type: i0.ViewChild, args: ['templateRef', { isSignal: true }] }], childTitleFn: [{ type: i0.Input, args: [{ isSignal: true, alias: "childTitleFn", required: false }] }], joinChild: [{ type: i0.Input, args: [{ isSignal: true, alias: "joinChild", required: false }] }], collapseIcon: [{ type: i0.Input, args: [{ isSignal: true, alias: "collapseIcon", required: false }] }], childClass: [{ type: i0.Input, args: [{ isSignal: true, alias: "childClass", required: false }] }] } });
|
|
48
|
+
|
|
49
|
+
class CardFGC extends PiyingViewGroupBase {
|
|
50
|
+
static __version = 2;
|
|
51
|
+
templateRef = viewChild.required('templateRef');
|
|
52
|
+
border = input(...(ngDevMode ? [undefined, { debugName: "border" }] : []));
|
|
53
|
+
size = input(...(ngDevMode ? [undefined, { debugName: "size" }] : []));
|
|
54
|
+
bodyClass = input(...(ngDevMode ? [undefined, { debugName: "bodyClass" }] : []));
|
|
55
|
+
figureClass = input(...(ngDevMode ? [undefined, { debugName: "figureClass" }] : []));
|
|
56
|
+
actionsClass = input(useTwClass('justify-end'), ...(ngDevMode ? [{ debugName: "actionsClass" }] : []));
|
|
57
|
+
titleKey = input('title', ...(ngDevMode ? [{ debugName: "titleKey" }] : []));
|
|
58
|
+
figureKey = input('figure', ...(ngDevMode ? [{ debugName: "figureKey" }] : []));
|
|
59
|
+
actionsKey = input('actions', ...(ngDevMode ? [{ debugName: "actionsKey" }] : []));
|
|
60
|
+
titleFiled$$ = computed(() => {
|
|
61
|
+
return this.field$$()
|
|
62
|
+
.children?.()
|
|
63
|
+
.find((field) => {
|
|
64
|
+
return field.keyPath?.slice(-1)[0] === this.titleKey();
|
|
65
|
+
});
|
|
66
|
+
}, ...(ngDevMode ? [{ debugName: "titleFiled$$" }] : []));
|
|
67
|
+
figureFiled$$ = computed(() => {
|
|
68
|
+
return this.field$$()
|
|
69
|
+
.children?.()
|
|
70
|
+
.find((field) => {
|
|
71
|
+
return field.keyPath?.slice(-1)[0] === this.figureKey();
|
|
72
|
+
});
|
|
73
|
+
}, ...(ngDevMode ? [{ debugName: "figureFiled$$" }] : []));
|
|
74
|
+
actionsFiled$$ = computed(() => {
|
|
75
|
+
return this.field$$()
|
|
76
|
+
.children?.()
|
|
77
|
+
.find((field) => {
|
|
78
|
+
return field.keyPath?.slice(-1)[0] === this.actionsKey();
|
|
79
|
+
});
|
|
80
|
+
}, ...(ngDevMode ? [{ debugName: "actionsFiled$$" }] : []));
|
|
81
|
+
bodyChildren$$ = computed(() => {
|
|
82
|
+
return this.field$$()
|
|
83
|
+
.children?.()
|
|
84
|
+
.filter((field) => {
|
|
85
|
+
const key = field.keyPath?.slice(-1)[0];
|
|
86
|
+
return !(key === this.titleKey() || key === this.figureKey() || key === this.actionsKey());
|
|
87
|
+
});
|
|
88
|
+
}, ...(ngDevMode ? [{ debugName: "bodyChildren$$" }] : []));
|
|
89
|
+
#theme = inject(ThemeService);
|
|
90
|
+
wrapperClass$ = computed(() => {
|
|
91
|
+
return this.#theme.setClass(this.#theme.setSize('card', this.size()), this.#theme.addPrefix2('card', this.border()));
|
|
92
|
+
}, ...(ngDevMode ? [{ debugName: "wrapperClass$" }] : []));
|
|
93
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: CardFGC, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
94
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.14", type: CardFGC, isStandalone: true, selector: "app-card", inputs: { border: { classPropertyName: "border", publicName: "border", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, bodyClass: { classPropertyName: "bodyClass", publicName: "bodyClass", isSignal: true, isRequired: false, transformFunction: null }, figureClass: { classPropertyName: "figureClass", publicName: "figureClass", isSignal: true, isRequired: false, transformFunction: null }, actionsClass: { classPropertyName: "actionsClass", publicName: "actionsClass", isSignal: true, isRequired: false, transformFunction: null }, titleKey: { classPropertyName: "titleKey", publicName: "titleKey", isSignal: true, isRequired: false, transformFunction: null }, figureKey: { classPropertyName: "figureKey", publicName: "figureKey", isSignal: true, isRequired: false, transformFunction: null }, actionsKey: { classPropertyName: "actionsKey", publicName: "actionsKey", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "templateRef", first: true, predicate: ["templateRef"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<ng-template #templateRef let-attr=\"attributes\">\n <div\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('card' | cssPrefix) : wrapperClass$()\"\n >\n @if (figureFiled$$(); as field) {\n <figure [class]=\"figureClass()\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </figure>\n }\n <div [class]=\"bodyClass() | mergeClass: ('card-body' | cssPrefix)\">\n @if (titleFiled$$(); as field) {\n <h2 class=\"{{ 'card-title' | cssPrefix }}\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </h2>\n }\n @if (bodyChildren$$(); as bodyChildren) {\n <div>\n @for (field of bodyChildren; track $index) {\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n }\n </div>\n }\n @if (actionsFiled$$(); as field) {\n <div [class]=\"actionsClass() | mergeClass: ('card-actions' | cssPrefix)\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </div>\n }\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: AttributesDirective, selector: "[attributes]", inputs: ["attributes", "excludes"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: CssPrefixPipe, name: "cssPrefix" }, { kind: "pipe", type: MergeClassPipe, name: "mergeClass" }] });
|
|
95
|
+
}
|
|
96
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: CardFGC, decorators: [{
|
|
97
|
+
type: Component,
|
|
98
|
+
args: [{ selector: 'app-card', imports: [AttributesDirective, NgTemplateOutlet, NgClass, CssPrefixPipe, MergeClassPipe], template: "<ng-template #templateRef let-attr=\"attributes\">\n <div\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('card' | cssPrefix) : wrapperClass$()\"\n >\n @if (figureFiled$$(); as field) {\n <figure [class]=\"figureClass()\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </figure>\n }\n <div [class]=\"bodyClass() | mergeClass: ('card-body' | cssPrefix)\">\n @if (titleFiled$$(); as field) {\n <h2 class=\"{{ 'card-title' | cssPrefix }}\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </h2>\n }\n @if (bodyChildren$$(); as bodyChildren) {\n <div>\n @for (field of bodyChildren; track $index) {\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n }\n </div>\n }\n @if (actionsFiled$$(); as field) {\n <div [class]=\"actionsClass() | mergeClass: ('card-actions' | cssPrefix)\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </div>\n }\n </div>\n </div>\n</ng-template>\n" }]
|
|
99
|
+
}], propDecorators: { templateRef: [{ type: i0.ViewChild, args: ['templateRef', { isSignal: true }] }], border: [{ type: i0.Input, args: [{ isSignal: true, alias: "border", required: false }] }], size: [{ type: i0.Input, args: [{ isSignal: true, alias: "size", required: false }] }], bodyClass: [{ type: i0.Input, args: [{ isSignal: true, alias: "bodyClass", required: false }] }], figureClass: [{ type: i0.Input, args: [{ isSignal: true, alias: "figureClass", required: false }] }], actionsClass: [{ type: i0.Input, args: [{ isSignal: true, alias: "actionsClass", required: false }] }], titleKey: [{ type: i0.Input, args: [{ isSignal: true, alias: "titleKey", required: false }] }], figureKey: [{ type: i0.Input, args: [{ isSignal: true, alias: "figureKey", required: false }] }], actionsKey: [{ type: i0.Input, args: [{ isSignal: true, alias: "actionsKey", required: false }] }] } });
|
|
100
|
+
|
|
101
|
+
class CarouselFGC extends PiyingViewGroupBase {
|
|
102
|
+
static __version = 2;
|
|
103
|
+
static index = 0;
|
|
104
|
+
index = CarouselFGC.index++;
|
|
105
|
+
templateRef = viewChild.required('templateRef');
|
|
106
|
+
direction = input(...(ngDevMode ? [undefined, { debugName: "direction" }] : []));
|
|
107
|
+
scrollAlign = input(...(ngDevMode ? [undefined, { debugName: "scrollAlign" }] : []));
|
|
108
|
+
childIdMap = input((compIndex, childIndex) => {
|
|
109
|
+
return `carousel-${compIndex}-${childIndex}`;
|
|
110
|
+
}, ...(ngDevMode ? [{ debugName: "childIdMap" }] : []));
|
|
111
|
+
#theme = inject(ThemeService);
|
|
112
|
+
ngClass$$ = computed(() => {
|
|
113
|
+
return clsx([
|
|
114
|
+
this.#theme.addPrefix2('carousel', this.direction()),
|
|
115
|
+
this.#theme.addPrefix2('carousel', this.scrollAlign()),
|
|
116
|
+
]);
|
|
117
|
+
}, ...(ngDevMode ? [{ debugName: "ngClass$$" }] : []));
|
|
118
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: CarouselFGC, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
119
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.14", type: CarouselFGC, isStandalone: true, selector: "app-carousel", inputs: { direction: { classPropertyName: "direction", publicName: "direction", isSignal: true, isRequired: false, transformFunction: null }, scrollAlign: { classPropertyName: "scrollAlign", publicName: "scrollAlign", isSignal: true, isRequired: false, transformFunction: null }, childIdMap: { classPropertyName: "childIdMap", publicName: "childIdMap", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "templateRef", first: true, predicate: ["templateRef"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<ng-template #templateRef let-attr=\"attributes\">\n <div\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('carousel' | cssPrefix) : ngClass$$()\"\n >\n @for (field of children$$(); track $index) {\n <div class=\"{{ 'carousel-item' | cssPrefix }}\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </div>\n }\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: AttributesDirective, selector: "[attributes]", inputs: ["attributes", "excludes"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: CssPrefixPipe, name: "cssPrefix" }, { kind: "pipe", type: MergeClassPipe, name: "mergeClass" }] });
|
|
120
|
+
}
|
|
121
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: CarouselFGC, decorators: [{
|
|
122
|
+
type: Component,
|
|
123
|
+
args: [{ selector: 'app-carousel', imports: [AttributesDirective, NgTemplateOutlet, NgClass, CssPrefixPipe, MergeClassPipe], template: "<ng-template #templateRef let-attr=\"attributes\">\n <div\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('carousel' | cssPrefix) : ngClass$$()\"\n >\n @for (field of children$$(); track $index) {\n <div class=\"{{ 'carousel-item' | cssPrefix }}\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </div>\n }\n </div>\n</ng-template>\n" }]
|
|
124
|
+
}], propDecorators: { templateRef: [{ type: i0.ViewChild, args: ['templateRef', { isSignal: true }] }], direction: [{ type: i0.Input, args: [{ isSignal: true, alias: "direction", required: false }] }], scrollAlign: [{ type: i0.Input, args: [{ isSignal: true, alias: "scrollAlign", required: false }] }], childIdMap: [{ type: i0.Input, args: [{ isSignal: true, alias: "childIdMap", required: false }] }] } });
|
|
125
|
+
|
|
126
|
+
class DockFGC extends PiyingViewGroupBase {
|
|
127
|
+
static __version = 2;
|
|
128
|
+
templateRef = viewChild.required('templateRef');
|
|
129
|
+
size = input(...(ngDevMode ? [undefined, { debugName: "size" }] : []));
|
|
130
|
+
activatedIndex = input(0, ...(ngDevMode ? [{ debugName: "activatedIndex" }] : []));
|
|
131
|
+
activatedIndex$ = linkedSignal(this.activatedIndex, ...(ngDevMode ? [{ debugName: "activatedIndex$" }] : []));
|
|
132
|
+
toggleActivate(index) {
|
|
133
|
+
this.activatedIndex$.set(index);
|
|
134
|
+
}
|
|
135
|
+
#theme = inject(ThemeService);
|
|
136
|
+
wrapperClass$ = computed(() => {
|
|
137
|
+
return this.#theme.setClass(this.#theme.setSize('dock', this.size()));
|
|
138
|
+
}, ...(ngDevMode ? [{ debugName: "wrapperClass$" }] : []));
|
|
139
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: DockFGC, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
140
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.14", type: DockFGC, isStandalone: true, selector: "app-dock", inputs: { size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, activatedIndex: { classPropertyName: "activatedIndex", publicName: "activatedIndex", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "templateRef", first: true, predicate: ["templateRef"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<ng-template #templateRef let-attr=\"attributes\">\n @let activatedField = children$$()[activatedIndex$()];\n @if (activatedField) {\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: activatedField }\"\n ></ng-container>\n }\n\n <div\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('dock' | cssPrefix) : wrapperClass$()\"\n >\n @for (field of children$$(); track $index) {\n @let item = field.props();\n <button\n (click)=\"toggleActivate($index)\"\n [class]=\"$index === activatedIndex$() ? ('dock-active' | cssPrefix) : ''\"\n >\n @if (item['icon']; as icon) {\n <mat-icon\n [inline]=\"icon.inline\"\n [fontIcon]=\"icon.fontIcon\"\n [fontSet]=\"icon.fontSet\"\n [svgIcon]=\"icon.svgIcon\"\n ></mat-icon>\n }\n @if (item['title']) {\n <span [class]=\"'dock-label' | cssPrefix\">{{ item['title'] }}</span>\n }\n </button>\n }\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: AttributesDirective, selector: "[attributes]", inputs: ["attributes", "excludes"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: CssPrefixPipe, name: "cssPrefix" }, { kind: "pipe", type: MergeClassPipe, name: "mergeClass" }] });
|
|
141
|
+
}
|
|
142
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: DockFGC, decorators: [{
|
|
143
|
+
type: Component,
|
|
144
|
+
args: [{ selector: 'app-dock', imports: [AttributesDirective, NgTemplateOutlet, MatIcon, NgClass, CssPrefixPipe, MergeClassPipe], template: "<ng-template #templateRef let-attr=\"attributes\">\n @let activatedField = children$$()[activatedIndex$()];\n @if (activatedField) {\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: activatedField }\"\n ></ng-container>\n }\n\n <div\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('dock' | cssPrefix) : wrapperClass$()\"\n >\n @for (field of children$$(); track $index) {\n @let item = field.props();\n <button\n (click)=\"toggleActivate($index)\"\n [class]=\"$index === activatedIndex$() ? ('dock-active' | cssPrefix) : ''\"\n >\n @if (item['icon']; as icon) {\n <mat-icon\n [inline]=\"icon.inline\"\n [fontIcon]=\"icon.fontIcon\"\n [fontSet]=\"icon.fontSet\"\n [svgIcon]=\"icon.svgIcon\"\n ></mat-icon>\n }\n @if (item['title']) {\n <span [class]=\"'dock-label' | cssPrefix\">{{ item['title'] }}</span>\n }\n </button>\n }\n </div>\n</ng-template>\n" }]
|
|
145
|
+
}], propDecorators: { templateRef: [{ type: i0.ViewChild, args: ['templateRef', { isSignal: true }] }], size: [{ type: i0.Input, args: [{ isSignal: true, alias: "size", required: false }] }], activatedIndex: [{ type: i0.Input, args: [{ isSignal: true, alias: "activatedIndex", required: false }] }] } });
|
|
146
|
+
|
|
147
|
+
class ListFGC extends PiyingViewGroupBase {
|
|
148
|
+
static __version = 2;
|
|
149
|
+
templateRef = viewChild.required('templateRef');
|
|
150
|
+
titleClass = input(...(ngDevMode ? [undefined, { debugName: "titleClass" }] : []));
|
|
151
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: ListFGC, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
152
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.14", type: ListFGC, isStandalone: true, selector: "app-list", inputs: { titleClass: { classPropertyName: "titleClass", publicName: "titleClass", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "templateRef", first: true, predicate: ["templateRef"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<ng-template #templateRef let-attr=\"attributes\">\n <ul\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('list' | cssPrefix)\"\n >\n @let title = props$$()['title'];\n @if (title) {\n <li [class]=\"titleClass()\">{{ title }}</li>\n }\n\n @for (field of children$$(); track $index) {\n <li [class]=\"'list-row' | cssPrefix\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </li>\n }\n </ul>\n</ng-template>\n", dependencies: [{ kind: "directive", type: AttributesDirective, selector: "[attributes]", inputs: ["attributes", "excludes"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: CssPrefixPipe, name: "cssPrefix" }, { kind: "pipe", type: MergeClassPipe, name: "mergeClass" }] });
|
|
153
|
+
}
|
|
154
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: ListFGC, decorators: [{
|
|
155
|
+
type: Component,
|
|
156
|
+
args: [{ selector: 'app-list', imports: [AttributesDirective, NgTemplateOutlet, CssPrefixPipe, MergeClassPipe], template: "<ng-template #templateRef let-attr=\"attributes\">\n <ul\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('list' | cssPrefix)\"\n >\n @let title = props$$()['title'];\n @if (title) {\n <li [class]=\"titleClass()\">{{ title }}</li>\n }\n\n @for (field of children$$(); track $index) {\n <li [class]=\"'list-row' | cssPrefix\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </li>\n }\n </ul>\n</ng-template>\n" }]
|
|
157
|
+
}], propDecorators: { templateRef: [{ type: i0.ViewChild, args: ['templateRef', { isSignal: true }] }], titleClass: [{ type: i0.Input, args: [{ isSignal: true, alias: "titleClass", required: false }] }] } });
|
|
158
|
+
|
|
159
|
+
class NavbarFGC extends PiyingViewGroupBase {
|
|
160
|
+
static __version = 2;
|
|
161
|
+
static index = 0;
|
|
162
|
+
templateRef = viewChild.required('templateRef');
|
|
163
|
+
start$$ = computed(() => {
|
|
164
|
+
return this.children$$().find((field) => {
|
|
165
|
+
return field.keyPath?.slice(-1)[0] === 'start';
|
|
166
|
+
});
|
|
167
|
+
}, ...(ngDevMode ? [{ debugName: "start$$" }] : []));
|
|
168
|
+
center$$ = computed(() => {
|
|
169
|
+
return this.children$$().find((field) => {
|
|
170
|
+
return field.keyPath?.slice(-1)[0] === 'center';
|
|
171
|
+
});
|
|
172
|
+
}, ...(ngDevMode ? [{ debugName: "center$$" }] : []));
|
|
173
|
+
end$$ = computed(() => {
|
|
174
|
+
return this.children$$().find((field) => {
|
|
175
|
+
return field.keyPath?.slice(-1)[0] === 'end';
|
|
176
|
+
});
|
|
177
|
+
}, ...(ngDevMode ? [{ debugName: "end$$" }] : []));
|
|
178
|
+
rest$$ = computed(() => {
|
|
179
|
+
return this.children$$().filter((field) => {
|
|
180
|
+
return (field.keyPath?.slice(-1)[0] !== 'start' &&
|
|
181
|
+
field.keyPath?.slice(-1)[0] !== 'center' &&
|
|
182
|
+
field.keyPath?.slice(-1)[0] !== 'end');
|
|
183
|
+
});
|
|
184
|
+
}, ...(ngDevMode ? [{ debugName: "rest$$" }] : []));
|
|
185
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: NavbarFGC, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
186
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.14", type: NavbarFGC, isStandalone: true, selector: "app-navbar", viewQueries: [{ propertyName: "templateRef", first: true, predicate: ["templateRef"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<ng-template #templateRef let-attr=\"attributes\">\n <div\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('navbar' | cssPrefix)\"\n >\n @for (field of rest$$(); track $index) {\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n }\n @let start = start$$();\n @if (start) {\n <div [class]=\"'navbar-start' | cssPrefix\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: start }\"\n ></ng-container>\n </div>\n }\n @let center = center$$();\n @if (center) {\n <div [class]=\"'navbar-center' | cssPrefix\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: center }\"\n ></ng-container>\n </div>\n }\n\n @let end = end$$();\n @if (end) {\n <div [class]=\"'navbar-end' | cssPrefix\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: end }\"\n ></ng-container>\n </div>\n }\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: AttributesDirective, selector: "[attributes]", inputs: ["attributes", "excludes"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: CssPrefixPipe, name: "cssPrefix" }, { kind: "pipe", type: MergeClassPipe, name: "mergeClass" }] });
|
|
187
|
+
}
|
|
188
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: NavbarFGC, decorators: [{
|
|
189
|
+
type: Component,
|
|
190
|
+
args: [{ selector: 'app-navbar', imports: [AttributesDirective, NgTemplateOutlet, PurePipe, CssPrefixPipe, MergeClassPipe], template: "<ng-template #templateRef let-attr=\"attributes\">\n <div\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('navbar' | cssPrefix)\"\n >\n @for (field of rest$$(); track $index) {\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n }\n @let start = start$$();\n @if (start) {\n <div [class]=\"'navbar-start' | cssPrefix\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: start }\"\n ></ng-container>\n </div>\n }\n @let center = center$$();\n @if (center) {\n <div [class]=\"'navbar-center' | cssPrefix\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: center }\"\n ></ng-container>\n </div>\n }\n\n @let end = end$$();\n @if (end) {\n <div [class]=\"'navbar-end' | cssPrefix\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: end }\"\n ></ng-container>\n </div>\n }\n </div>\n</ng-template>\n" }]
|
|
191
|
+
}], propDecorators: { templateRef: [{ type: i0.ViewChild, args: ['templateRef', { isSignal: true }] }] } });
|
|
192
|
+
|
|
193
|
+
class DrawerFGC extends PiyingViewGroupBase {
|
|
194
|
+
static __version = 2;
|
|
195
|
+
static index = 0;
|
|
196
|
+
name = `drawer-${DrawerFGC.index++}`;
|
|
197
|
+
templateRef = viewChild.required('templateRef');
|
|
198
|
+
contentClass = input(...(ngDevMode ? [undefined, { debugName: "contentClass" }] : []));
|
|
199
|
+
sideClass = input(...(ngDevMode ? [undefined, { debugName: "sideClass" }] : []));
|
|
200
|
+
overlayClass = input(...(ngDevMode ? [undefined, { debugName: "overlayClass" }] : []));
|
|
201
|
+
mode = input('over', ...(ngDevMode ? [{ debugName: "mode" }] : []));
|
|
202
|
+
position = input(...(ngDevMode ? [undefined, { debugName: "position" }] : []));
|
|
203
|
+
contentFiled$$ = computed(() => {
|
|
204
|
+
return this.field$$()
|
|
205
|
+
.children?.()
|
|
206
|
+
.find((field) => {
|
|
207
|
+
return field.keyPath?.slice(-1)[0] === 'content';
|
|
208
|
+
});
|
|
209
|
+
}, ...(ngDevMode ? [{ debugName: "contentFiled$$" }] : []));
|
|
210
|
+
sideFiled$$ = computed(() => {
|
|
211
|
+
return this.field$$()
|
|
212
|
+
.children?.()
|
|
213
|
+
.find((field) => {
|
|
214
|
+
return field.keyPath?.slice(-1)[0] === 'side';
|
|
215
|
+
});
|
|
216
|
+
}, ...(ngDevMode ? [{ debugName: "sideFiled$$" }] : []));
|
|
217
|
+
opened = model(false, ...(ngDevMode ? [{ debugName: "opened" }] : []));
|
|
218
|
+
openChanged(value) {
|
|
219
|
+
this.opened.set(value);
|
|
220
|
+
}
|
|
221
|
+
#theme = inject(ThemeService);
|
|
222
|
+
wrapperClass$ = computed(() => {
|
|
223
|
+
return this.#theme.setClass(this.mode() === 'side' && this.opened() ? this.#theme.addPrefix('drawer-open') : undefined, this.position() === 'end' ? this.#theme.addPrefix2('drawer', this.position()) : undefined);
|
|
224
|
+
}, ...(ngDevMode ? [{ debugName: "wrapperClass$" }] : []));
|
|
225
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: DrawerFGC, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
226
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "20.3.14", type: DrawerFGC, isStandalone: true, selector: "app-drawer", inputs: { contentClass: { classPropertyName: "contentClass", publicName: "contentClass", isSignal: true, isRequired: false, transformFunction: null }, sideClass: { classPropertyName: "sideClass", publicName: "sideClass", isSignal: true, isRequired: false, transformFunction: null }, overlayClass: { classPropertyName: "overlayClass", publicName: "overlayClass", isSignal: true, isRequired: false, transformFunction: null }, mode: { classPropertyName: "mode", publicName: "mode", isSignal: true, isRequired: false, transformFunction: null }, position: { classPropertyName: "position", publicName: "position", isSignal: true, isRequired: false, transformFunction: null }, opened: { classPropertyName: "opened", publicName: "opened", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { opened: "openedChange" }, viewQueries: [{ propertyName: "templateRef", first: true, predicate: ["templateRef"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<ng-template #templateRef let-attr=\"attributes\">\n <div\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('drawer' | cssPrefix) : wrapperClass$()\"\n >\n <input\n [id]=\"name\"\n type=\"checkbox\"\n class=\"{{ 'drawer-toggle' | cssPrefix }}\"\n #toggle\n [ngModel]=\"opened()\"\n (ngModelChange)=\"openChanged($event)\"\n />\n <div [class]=\"contentClass() | mergeClass: ('drawer-content' | cssPrefix)\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: contentFiled$$() }\"\n ></ng-container>\n </div>\n <div [class]=\"sideClass() | mergeClass: ('drawer-side' | cssPrefix)\">\n <label\n [for]=\"name\"\n aria-label=\"close sidebar\"\n [class]=\"overlayClass() | mergeClass: ('drawer-overlay' | cssPrefix)\"\n ></label>\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: sideFiled$$() }\"\n ></ng-container>\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: AttributesDirective, selector: "[attributes]", inputs: ["attributes", "excludes"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { 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: "pipe", type: CssPrefixPipe, name: "cssPrefix" }, { kind: "pipe", type: MergeClassPipe, name: "mergeClass" }] });
|
|
227
|
+
}
|
|
228
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: DrawerFGC, decorators: [{
|
|
229
|
+
type: Component,
|
|
230
|
+
args: [{ selector: 'app-drawer', imports: [
|
|
231
|
+
AttributesDirective,
|
|
232
|
+
NgTemplateOutlet,
|
|
233
|
+
FormsModule,
|
|
234
|
+
NgClass,
|
|
235
|
+
CssPrefixPipe,
|
|
236
|
+
MergeClassPipe,
|
|
237
|
+
], template: "<ng-template #templateRef let-attr=\"attributes\">\n <div\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('drawer' | cssPrefix) : wrapperClass$()\"\n >\n <input\n [id]=\"name\"\n type=\"checkbox\"\n class=\"{{ 'drawer-toggle' | cssPrefix }}\"\n #toggle\n [ngModel]=\"opened()\"\n (ngModelChange)=\"openChanged($event)\"\n />\n <div [class]=\"contentClass() | mergeClass: ('drawer-content' | cssPrefix)\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: contentFiled$$() }\"\n ></ng-container>\n </div>\n <div [class]=\"sideClass() | mergeClass: ('drawer-side' | cssPrefix)\">\n <label\n [for]=\"name\"\n aria-label=\"close sidebar\"\n [class]=\"overlayClass() | mergeClass: ('drawer-overlay' | cssPrefix)\"\n ></label>\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: sideFiled$$() }\"\n ></ng-container>\n </div>\n </div>\n</ng-template>\n" }]
|
|
238
|
+
}], propDecorators: { templateRef: [{ type: i0.ViewChild, args: ['templateRef', { isSignal: true }] }], contentClass: [{ type: i0.Input, args: [{ isSignal: true, alias: "contentClass", required: false }] }], sideClass: [{ type: i0.Input, args: [{ isSignal: true, alias: "sideClass", required: false }] }], overlayClass: [{ type: i0.Input, args: [{ isSignal: true, alias: "overlayClass", required: false }] }], mode: [{ type: i0.Input, args: [{ isSignal: true, alias: "mode", required: false }] }], position: [{ type: i0.Input, args: [{ isSignal: true, alias: "position", required: false }] }], opened: [{ type: i0.Input, args: [{ isSignal: true, alias: "opened", required: false }] }, { type: i0.Output, args: ["openedChange"] }] } });
|
|
239
|
+
|
|
240
|
+
class TabsFGC extends PiyingViewGroupBase {
|
|
241
|
+
static __version = 2;
|
|
242
|
+
static index = 0;
|
|
243
|
+
templateRef = viewChild.required('templateRef');
|
|
244
|
+
StrOrTemplateComponent = StrOrTemplateComponent;
|
|
245
|
+
size = input(...(ngDevMode ? [undefined, { debugName: "size" }] : []));
|
|
246
|
+
name = `pc-tabs-${TabsFGC.index++}`;
|
|
247
|
+
activatedIndex = input(0, ...(ngDevMode ? [{ debugName: "activatedIndex" }] : []));
|
|
248
|
+
type = input(...(ngDevMode ? [undefined, { debugName: "type" }] : []));
|
|
249
|
+
placement = input(...(ngDevMode ? [undefined, { debugName: "placement" }] : []));
|
|
250
|
+
tabContentClass = input(useTwClass('bg-base-100 border-base-300 p-6'), ...(ngDevMode ? [{ debugName: "tabContentClass" }] : []));
|
|
251
|
+
activatedIndex$ = linkedSignal(this.activatedIndex, ...(ngDevMode ? [{ debugName: "activatedIndex$" }] : []));
|
|
252
|
+
toggleActivate(index) {
|
|
253
|
+
this.activatedIndex$.set(index);
|
|
254
|
+
}
|
|
255
|
+
#theme = inject(ThemeService);
|
|
256
|
+
wrapperClass$$ = computed(() => {
|
|
257
|
+
return this.#theme.setClass(this.#theme.setSize('tabs', this.size()), this.type() ? this.#theme.addPrefix(`tabs-${this.type()}`) : undefined, this.placement() ? this.#theme.addPrefix(`tabs-${this.placement()}`) : undefined);
|
|
258
|
+
}, ...(ngDevMode ? [{ debugName: "wrapperClass$$" }] : []));
|
|
259
|
+
labelInputs = (input) => {
|
|
260
|
+
return {
|
|
261
|
+
content: input,
|
|
262
|
+
};
|
|
263
|
+
};
|
|
264
|
+
changeIndex(index) {
|
|
265
|
+
this.activatedIndex$.set(index);
|
|
266
|
+
}
|
|
267
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: TabsFGC, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
268
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.14", type: TabsFGC, isStandalone: true, selector: "app-tabs", inputs: { size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, activatedIndex: { classPropertyName: "activatedIndex", publicName: "activatedIndex", isSignal: true, isRequired: false, transformFunction: null }, type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null }, placement: { classPropertyName: "placement", publicName: "placement", isSignal: true, isRequired: false, transformFunction: null }, tabContentClass: { classPropertyName: "tabContentClass", publicName: "tabContentClass", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "templateRef", first: true, predicate: ["templateRef"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<ng-template #templateRef let-attr=\"attributes\">\n <div\n role=\"tablist\"\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('tabs' | cssPrefix) : wrapperClass$$()\"\n >\n @for (field of children$$(); track $index) {\n @let item = field.props();\n <label\n role=\"tab\"\n [class]=\"\n 'tab'\n | cssPrefix\n | mergeClass: ($index === activatedIndex$() ? ('tab-active' | cssPrefix) : undefined)\n \"\n (click)=\"changeIndex($index)\"\n >\n <!-- <input type=\"radio\" [name]=\"name\" /> -->\n\n <ng-template\n [selectlessOutlet]=\"StrOrTemplateComponent\"\n [selectlessOutletInputs]=\"labelInputs | pure: item['title']\"\n ></ng-template>\n </label>\n <div [class]=\"'tab-content' | cssPrefix | mergeClass: tabContentClass()\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </div>\n }\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: AttributesDirective, selector: "[attributes]", inputs: ["attributes", "excludes"] }, { kind: "directive", type: SelectorlessOutlet, selector: "[selectlessOutlet]", inputs: ["selectlessOutlet", "selectlessOutletInputs", "selectlessOutletOutputs", "selectlessOutletDirectives", "selectlessOutletInjector", "selectlessOutletEnvironmentInjector"], exportAs: ["selectlessOutlet"] }, { kind: "pipe", type: CssPrefixPipe, name: "cssPrefix" }, { kind: "pipe", type: MergeClassPipe, name: "mergeClass" }, { kind: "pipe", type: PurePipe, name: "pure" }] });
|
|
269
|
+
}
|
|
270
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: TabsFGC, decorators: [{
|
|
271
|
+
type: Component,
|
|
272
|
+
args: [{ selector: 'app-tabs', imports: [
|
|
273
|
+
NgTemplateOutlet,
|
|
274
|
+
AttributesDirective,
|
|
275
|
+
MatIcon,
|
|
276
|
+
NgClass,
|
|
277
|
+
CssPrefixPipe,
|
|
278
|
+
MergeClassPipe,
|
|
279
|
+
PurePipe,
|
|
280
|
+
SelectorlessOutlet,
|
|
281
|
+
], template: "<ng-template #templateRef let-attr=\"attributes\">\n <div\n role=\"tablist\"\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('tabs' | cssPrefix) : wrapperClass$$()\"\n >\n @for (field of children$$(); track $index) {\n @let item = field.props();\n <label\n role=\"tab\"\n [class]=\"\n 'tab'\n | cssPrefix\n | mergeClass: ($index === activatedIndex$() ? ('tab-active' | cssPrefix) : undefined)\n \"\n (click)=\"changeIndex($index)\"\n >\n <!-- <input type=\"radio\" [name]=\"name\" /> -->\n\n <ng-template\n [selectlessOutlet]=\"StrOrTemplateComponent\"\n [selectlessOutletInputs]=\"labelInputs | pure: item['title']\"\n ></ng-template>\n </label>\n <div [class]=\"'tab-content' | cssPrefix | mergeClass: tabContentClass()\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </div>\n }\n </div>\n</ng-template>\n" }]
|
|
282
|
+
}], propDecorators: { templateRef: [{ type: i0.ViewChild, args: ['templateRef', { isSignal: true }] }], size: [{ type: i0.Input, args: [{ isSignal: true, alias: "size", required: false }] }], activatedIndex: [{ type: i0.Input, args: [{ isSignal: true, alias: "activatedIndex", required: false }] }], type: [{ type: i0.Input, args: [{ isSignal: true, alias: "type", required: false }] }], placement: [{ type: i0.Input, args: [{ isSignal: true, alias: "placement", required: false }] }], tabContentClass: [{ type: i0.Input, args: [{ isSignal: true, alias: "tabContentClass", required: false }] }] } });
|
|
283
|
+
|
|
284
|
+
class StepsFGC extends PiyingViewGroupBase {
|
|
285
|
+
static __version = 2;
|
|
286
|
+
templateRef = viewChild.required('templateRef');
|
|
287
|
+
StrOrTemplateComponent = StrOrTemplateComponent;
|
|
288
|
+
activatedIndex = model(0, ...(ngDevMode ? [{ debugName: "activatedIndex" }] : []));
|
|
289
|
+
activatedItem$$ = computed(() => this.field$$().children()[this.activatedIndex()], ...(ngDevMode ? [{ debugName: "activatedItem$$" }] : []));
|
|
290
|
+
prevItem$$ = computed(() => {
|
|
291
|
+
return this.children$$()[this.activatedIndex() - 1];
|
|
292
|
+
}, ...(ngDevMode ? [{ debugName: "prevItem$$" }] : []));
|
|
293
|
+
customAction = input(...(ngDevMode ? [undefined, { debugName: "customAction" }] : []));
|
|
294
|
+
prev = input('⬅️', ...(ngDevMode ? [{ debugName: "prev" }] : []));
|
|
295
|
+
next = input('➡️', ...(ngDevMode ? [{ debugName: "next" }] : []));
|
|
296
|
+
direction = input(...(ngDevMode ? [undefined, { debugName: "direction" }] : []));
|
|
297
|
+
stepColor = input('primary', ...(ngDevMode ? [{ debugName: "stepColor" }] : []));
|
|
298
|
+
toPrev() {
|
|
299
|
+
this.activatedIndex.update((value) => value - 1);
|
|
300
|
+
}
|
|
301
|
+
toNext() {
|
|
302
|
+
this.activatedIndex.update((value) => value + 1);
|
|
303
|
+
}
|
|
304
|
+
isActivated(activatedIndex, currentIndex) {
|
|
305
|
+
return activatedIndex >= currentIndex;
|
|
306
|
+
}
|
|
307
|
+
#theme = inject(ThemeService);
|
|
308
|
+
wrapperClass$$ = computed(() => {
|
|
309
|
+
return clsx(this.#theme.addPrefix('steps'), this.#theme.addPrefix2('steps', this.direction()));
|
|
310
|
+
}, ...(ngDevMode ? [{ debugName: "wrapperClass$$" }] : []));
|
|
311
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: StepsFGC, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
312
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.14", type: StepsFGC, isStandalone: true, selector: "app-steps", inputs: { activatedIndex: { classPropertyName: "activatedIndex", publicName: "activatedIndex", isSignal: true, isRequired: false, transformFunction: null }, customAction: { classPropertyName: "customAction", publicName: "customAction", isSignal: true, isRequired: false, transformFunction: null }, prev: { classPropertyName: "prev", publicName: "prev", isSignal: true, isRequired: false, transformFunction: null }, next: { classPropertyName: "next", publicName: "next", isSignal: true, isRequired: false, transformFunction: null }, direction: { classPropertyName: "direction", publicName: "direction", isSignal: true, isRequired: false, transformFunction: null }, stepColor: { classPropertyName: "stepColor", publicName: "stepColor", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { activatedIndex: "activatedIndexChange" }, viewQueries: [{ propertyName: "templateRef", first: true, predicate: ["templateRef"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<ng-template #templateRef let-attr=\"attributes\">\n <ul\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: wrapperClass$$()\"\n >\n @for (field of children$$(); track field.id || $index) {\n @let label = field.props()['title'] || '\uD83D\uDCC4' + ($index + 1);\n <li\n [class]=\"\n 'step'\n | cssPrefix\n | mergeClass\n : ((isActivated | pure: activatedIndex() : $index)\n ? ('step-' + stepColor() | cssPrefix)\n : undefined)\n \"\n >\n {{ label }}\n </li>\n }\n </ul>\n <div class=\"{{ 'flex flex-col gap-4' | twPrefix }}\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: activatedItem$$() }\"\n ></ng-container>\n @if (customAction()) {\n <ng-container\n *ngComponentOutlet=\"\n StrOrTemplateComponent;\n context: { inputs: { content: customAction(), context: this } }\n \"\n ></ng-container>\n } @else {\n <div [class]=\"'flex gap-2 items-center' | twPrefix\">\n <button\n [class]=\"'btn btn-secondary' | cssPrefix\"\n [disabled]=\"activatedIndex() === 0 || prevItem$$().form.control?.invalid\"\n (click)=\"toPrev()\"\n >\n {{ prev() }}\n </button>\n\n <button\n [class]=\"'btn btn-primary' | cssPrefix\"\n [disabled]=\"\n activatedItem$$().form.control?.invalid || activatedIndex() + 1 !== children$$().length\n \"\n (click)=\"toNext()\"\n >\n {{ next() }}\n </button>\n </div>\n }\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletEnvironmentInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"], exportAs: ["ngComponentOutlet"] }, { kind: "directive", type: AttributesDirective, selector: "[attributes]", inputs: ["attributes", "excludes"] }, { kind: "pipe", type: CssPrefixPipe, name: "cssPrefix" }, { kind: "pipe", type: MergeClassPipe, name: "mergeClass" }, { kind: "pipe", type: TwPrefixPipe, name: "twPrefix" }, { kind: "pipe", type: PurePipe, name: "pure" }] });
|
|
313
|
+
}
|
|
314
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: StepsFGC, decorators: [{
|
|
315
|
+
type: Component,
|
|
316
|
+
args: [{ selector: 'app-steps', imports: [
|
|
317
|
+
NgTemplateOutlet,
|
|
318
|
+
CssPrefixPipe,
|
|
319
|
+
MergeClassPipe,
|
|
320
|
+
TwPrefixPipe,
|
|
321
|
+
PurePipe,
|
|
322
|
+
SelectorlessOutlet,
|
|
323
|
+
StrOrTemplateComponent,
|
|
324
|
+
NgComponentOutlet,
|
|
325
|
+
AttributesDirective,
|
|
326
|
+
], template: "<ng-template #templateRef let-attr=\"attributes\">\n <ul\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: wrapperClass$$()\"\n >\n @for (field of children$$(); track field.id || $index) {\n @let label = field.props()['title'] || '\uD83D\uDCC4' + ($index + 1);\n <li\n [class]=\"\n 'step'\n | cssPrefix\n | mergeClass\n : ((isActivated | pure: activatedIndex() : $index)\n ? ('step-' + stepColor() | cssPrefix)\n : undefined)\n \"\n >\n {{ label }}\n </li>\n }\n </ul>\n <div class=\"{{ 'flex flex-col gap-4' | twPrefix }}\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: activatedItem$$() }\"\n ></ng-container>\n @if (customAction()) {\n <ng-container\n *ngComponentOutlet=\"\n StrOrTemplateComponent;\n context: { inputs: { content: customAction(), context: this } }\n \"\n ></ng-container>\n } @else {\n <div [class]=\"'flex gap-2 items-center' | twPrefix\">\n <button\n [class]=\"'btn btn-secondary' | cssPrefix\"\n [disabled]=\"activatedIndex() === 0 || prevItem$$().form.control?.invalid\"\n (click)=\"toPrev()\"\n >\n {{ prev() }}\n </button>\n\n <button\n [class]=\"'btn btn-primary' | cssPrefix\"\n [disabled]=\"\n activatedItem$$().form.control?.invalid || activatedIndex() + 1 !== children$$().length\n \"\n (click)=\"toNext()\"\n >\n {{ next() }}\n </button>\n </div>\n }\n </div>\n</ng-template>\n" }]
|
|
327
|
+
}], propDecorators: { templateRef: [{ type: i0.ViewChild, args: ['templateRef', { isSignal: true }] }], activatedIndex: [{ type: i0.Input, args: [{ isSignal: true, alias: "activatedIndex", required: false }] }, { type: i0.Output, args: ["activatedIndexChange"] }], customAction: [{ type: i0.Input, args: [{ isSignal: true, alias: "customAction", required: false }] }], prev: [{ type: i0.Input, args: [{ isSignal: true, alias: "prev", required: false }] }], next: [{ type: i0.Input, args: [{ isSignal: true, alias: "next", required: false }] }], direction: [{ type: i0.Input, args: [{ isSignal: true, alias: "direction", required: false }] }], stepColor: [{ type: i0.Input, args: [{ isSignal: true, alias: "stepColor", required: false }] }] } });
|
|
328
|
+
|
|
329
|
+
class FieldsetFGC extends PiyingViewGroupBase {
|
|
330
|
+
static __version = 2;
|
|
331
|
+
templateRef = viewChild.required('templateRef');
|
|
332
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: FieldsetFGC, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
333
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.14", type: FieldsetFGC, isStandalone: true, selector: "app-fieldset", viewQueries: [{ propertyName: "templateRef", first: true, predicate: ["templateRef"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<ng-template #templateRef let-attr=\"attributes\">\n <fieldset\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"'fieldset' | cssPrefix | mergeClass: attr()?.class\"\n >\n <legend [class]=\"'fieldset-legend' | cssPrefix\">{{ props$$()['title'] }}</legend>\n\n @for (field of children$$(); track $index) {\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n }\n </fieldset>\n</ng-template>\n", dependencies: [{ kind: "directive", type: AttributesDirective, selector: "[attributes]", inputs: ["attributes", "excludes"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: CssPrefixPipe, name: "cssPrefix" }, { kind: "pipe", type: MergeClassPipe, name: "mergeClass" }] });
|
|
334
|
+
}
|
|
335
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: FieldsetFGC, decorators: [{
|
|
336
|
+
type: Component,
|
|
337
|
+
args: [{ selector: 'app-fieldset', imports: [AttributesDirective, NgTemplateOutlet, CssPrefixPipe, MergeClassPipe], template: "<ng-template #templateRef let-attr=\"attributes\">\n <fieldset\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"'fieldset' | cssPrefix | mergeClass: attr()?.class\"\n >\n <legend [class]=\"'fieldset-legend' | cssPrefix\">{{ props$$()['title'] }}</legend>\n\n @for (field of children$$(); track $index) {\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n }\n </fieldset>\n</ng-template>\n" }]
|
|
338
|
+
}], propDecorators: { templateRef: [{ type: i0.ViewChild, args: ['templateRef', { isSignal: true }] }] } });
|
|
339
|
+
|
|
340
|
+
/**
|
|
341
|
+
* Generated bundle index. Do not edit.
|
|
342
|
+
*/
|
|
343
|
+
|
|
344
|
+
export { AccordionFGC, CardFGC, CarouselFGC, DockFGC, DrawerFGC, FieldsetFGC, ListFGC, NavbarFGC, StepsFGC, TabsFGC };
|
|
345
|
+
//# sourceMappingURL=piying-lib-angular-daisyui-field-group.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"piying-lib-angular-daisyui-field-group.mjs","sources":["../../../projects/daisyui/field-group/accordion/component.ts","../../../projects/daisyui/field-group/accordion/component.html","../../../projects/daisyui/field-group/card/component.ts","../../../projects/daisyui/field-group/card/component.html","../../../projects/daisyui/field-group/carousel/component.ts","../../../projects/daisyui/field-group/carousel/component.html","../../../projects/daisyui/field-group/dock/component.ts","../../../projects/daisyui/field-group/dock/component.html","../../../projects/daisyui/field-group/list/component.ts","../../../projects/daisyui/field-group/list/component.html","../../../projects/daisyui/field-group/navbar/component.ts","../../../projects/daisyui/field-group/navbar/component.html","../../../projects/daisyui/field-group/drawer/component.ts","../../../projects/daisyui/field-group/drawer/component.html","../../../projects/daisyui/field-group/tabs/component.ts","../../../projects/daisyui/field-group/tabs/component.html","../../../projects/daisyui/field-group/steps/component.ts","../../../projects/daisyui/field-group/steps/component.html","../../../projects/daisyui/field-group/fieldset/component.ts","../../../projects/daisyui/field-group/fieldset/component.html","../../../projects/daisyui/field-group/piying-lib-angular-daisyui-field-group.ts"],"sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport { Component, computed, inject, input, viewChild } from '@angular/core';\nimport { PurePipe } from '@cyia/ngx-common/pipe';\nimport { CssPrefixPipe } from '@piying-lib/angular-daisyui/pipe';\nimport { MergeClassPipe } from '@piying-lib/angular-daisyui/pipe';\nimport { ThemeService } from '@piying-lib/angular-daisyui/service';\nimport { useTwClass } from '@piying-lib/angular-daisyui/service';\n\nimport {\n AttributesDirective,\n PiResolvedViewFieldConfig,\n PiyingViewGroupBase,\n} from '@piying/view-angular';\nimport clsx from 'clsx';\nclass AccordionItem {\n constructor(field: PiResolvedViewFieldConfig) {}\n isActivated() {}\n}\n@Component({\n selector: 'app-accordion',\n templateUrl: './component.html',\n imports: [AttributesDirective, NgTemplateOutlet, PurePipe, MergeClassPipe, CssPrefixPipe],\n})\nexport class AccordionFGC extends PiyingViewGroupBase {\n static __version = 2;\n static index = 0;\n name = `accordion-${AccordionFGC.index++}`;\n multi = input(false);\n templateRef = viewChild.required('templateRef');\n\n childTitleFn = input((item: PiResolvedViewFieldConfig) => {\n return item.props()?.['title'] ?? item.keyPath?.slice(-1)[0] ?? '';\n });\n joinChild = input(true);\n collapseIcon = input<'arrow' | 'plus'>();\n childClass = input<string>(useTwClass('bg-base-100 border border-base-300'));\n #theme = inject(ThemeService);\n childClass$$ = computed(() => {\n return clsx(\n this.#theme.addPrefix2('collapse', this.collapseIcon()),\n this.childClass(),\n this.joinChild() ? this.#theme.addPrefix('join-item') : undefined,\n );\n });\n childName = (multi: boolean, index: number) => {\n if (multi) {\n return `${this.name}-${index}`;\n }\n return this.name;\n };\n}\n","<ng-template #mainTemp>\n @for (field of children$$(); track field.id || $index) {\n <div [class]=\"childClass$$() | mergeClass: ('collapse' | cssPrefix)\">\n <input\n type=\"radio\"\n [name]=\"childName | pure: multi() : $index\"\n [checked]=\"!!field.props()['checked']\"\n />\n <div class=\"{{ 'collapse-title' | cssPrefix }}\">\n {{ childTitleFn() | pure: field }}\n </div>\n <div class=\"{{ 'collapse-content' | cssPrefix }}\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </div>\n </div>\n }\n</ng-template>\n<ng-template #templateRef let-attr=\"attributes\">\n @if (joinChild()) {\n <div\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('join join-vertical' | cssPrefix)\"\n >\n <ng-container *ngTemplateOutlet=\"mainTemp\"></ng-container>\n </div>\n } @else {\n <ng-container *ngTemplateOutlet=\"mainTemp\"></ng-container>\n }\n</ng-template>\n","import { NgClass, NgTemplateOutlet } from '@angular/common';\nimport { Component, computed, inject, input, viewChild } from '@angular/core';\nimport { CssPrefixPipe, MergeClassPipe } from '@piying-lib/angular-daisyui/pipe';\nimport { ThemeService, useTwClass } from '@piying-lib/angular-daisyui/service';\nimport { Size } from '@piying-lib/angular-core';\n\nimport { AttributesDirective, PiyingViewGroupBase } from '@piying/view-angular';\n@Component({\n selector: 'app-card',\n templateUrl: './component.html',\n imports: [AttributesDirective, NgTemplateOutlet, NgClass, CssPrefixPipe, MergeClassPipe],\n})\nexport class CardFGC extends PiyingViewGroupBase {\n static __version = 2;\n templateRef = viewChild.required('templateRef');\n border = input<'border' | 'dash'>();\n size = input<Size>();\n\n bodyClass = input<string>();\n figureClass = input<string>();\n actionsClass = input(useTwClass('justify-end'));\n titleKey = input('title');\n figureKey = input('figure');\n actionsKey = input('actions');\n titleFiled$$ = computed(() => {\n return this.field$$()\n .children?.()\n .find((field) => {\n return field.keyPath?.slice(-1)[0] === this.titleKey();\n });\n });\n figureFiled$$ = computed(() => {\n return this.field$$()\n .children?.()\n .find((field) => {\n return field.keyPath?.slice(-1)[0] === this.figureKey();\n });\n });\n actionsFiled$$ = computed(() => {\n return this.field$$()\n .children?.()\n .find((field) => {\n return field.keyPath?.slice(-1)[0] === this.actionsKey();\n });\n });\n bodyChildren$$ = computed(() => {\n return this.field$$()\n .children?.()\n .filter((field) => {\n const key = field.keyPath?.slice(-1)[0];\n return !(key === this.titleKey() || key === this.figureKey() || key === this.actionsKey());\n });\n });\n #theme = inject(ThemeService);\n wrapperClass$ = computed(() => {\n return this.#theme.setClass(\n this.#theme.setSize('card', this.size()),\n this.#theme.addPrefix2('card', this.border()),\n );\n });\n}\n","<ng-template #templateRef let-attr=\"attributes\">\n <div\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('card' | cssPrefix) : wrapperClass$()\"\n >\n @if (figureFiled$$(); as field) {\n <figure [class]=\"figureClass()\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </figure>\n }\n <div [class]=\"bodyClass() | mergeClass: ('card-body' | cssPrefix)\">\n @if (titleFiled$$(); as field) {\n <h2 class=\"{{ 'card-title' | cssPrefix }}\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </h2>\n }\n @if (bodyChildren$$(); as bodyChildren) {\n <div>\n @for (field of bodyChildren; track $index) {\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n }\n </div>\n }\n @if (actionsFiled$$(); as field) {\n <div [class]=\"actionsClass() | mergeClass: ('card-actions' | cssPrefix)\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </div>\n }\n </div>\n </div>\n</ng-template>\n","import { NgClass, NgTemplateOutlet } from '@angular/common';\nimport { Component, computed, inject, input, viewChild } from '@angular/core';\nimport { CssPrefixPipe, MergeClassPipe } from '@piying-lib/angular-daisyui/pipe';\nimport { ThemeService } from '@piying-lib/angular-daisyui/service';\n\nimport { AttributesDirective, PiyingViewGroupBase } from '@piying/view-angular';\nimport clsx from 'clsx';\n\n@Component({\n selector: 'app-carousel',\n templateUrl: './component.html',\n imports: [AttributesDirective, NgTemplateOutlet, NgClass, CssPrefixPipe, MergeClassPipe],\n})\nexport class CarouselFGC extends PiyingViewGroupBase {\n static __version = 2;\n static index = 0;\n index = CarouselFGC.index++;\n templateRef = viewChild.required('templateRef');\n direction = input<'horizontal' | 'vertical'>();\n scrollAlign = input<'start' | 'center' | 'end'>();\n childIdMap = input((compIndex: number, childIndex: number) => {\n return `carousel-${compIndex}-${childIndex}`;\n });\n #theme = inject(ThemeService);\n ngClass$$ = computed(() => {\n return clsx([\n this.#theme.addPrefix2('carousel', this.direction()),\n this.#theme.addPrefix2('carousel', this.scrollAlign()),\n ]);\n });\n}\n","<ng-template #templateRef let-attr=\"attributes\">\n <div\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('carousel' | cssPrefix) : ngClass$$()\"\n >\n @for (field of children$$(); track $index) {\n <div class=\"{{ 'carousel-item' | cssPrefix }}\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </div>\n }\n </div>\n</ng-template>\n","import { NgClass, NgTemplateOutlet } from '@angular/common';\nimport { Component, computed, inject, input, linkedSignal, viewChild } from '@angular/core';\nimport { MatIcon } from '@angular/material/icon';\nimport { CssPrefixPipe, MergeClassPipe } from '@piying-lib/angular-daisyui/pipe';\nimport { ThemeService } from '@piying-lib/angular-daisyui/service';\nimport { Size } from '@piying-lib/angular-core';\n\nimport { AttributesDirective, PiyingViewGroupBase } from '@piying/view-angular';\n\n@Component({\n selector: 'app-dock',\n templateUrl: './component.html',\n imports: [AttributesDirective, NgTemplateOutlet, MatIcon, NgClass, CssPrefixPipe, MergeClassPipe],\n})\nexport class DockFGC extends PiyingViewGroupBase {\n static __version = 2;\n templateRef = viewChild.required('templateRef');\n\n size = input<Size>();\n\n activatedIndex = input(0);\n\n activatedIndex$ = linkedSignal(this.activatedIndex);\n toggleActivate(index: number) {\n this.activatedIndex$.set(index);\n }\n\n #theme = inject(ThemeService);\n wrapperClass$ = computed(() => {\n return this.#theme.setClass(this.#theme.setSize('dock', this.size()));\n });\n}\n","<ng-template #templateRef let-attr=\"attributes\">\n @let activatedField = children$$()[activatedIndex$()];\n @if (activatedField) {\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: activatedField }\"\n ></ng-container>\n }\n\n <div\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('dock' | cssPrefix) : wrapperClass$()\"\n >\n @for (field of children$$(); track $index) {\n @let item = field.props();\n <button\n (click)=\"toggleActivate($index)\"\n [class]=\"$index === activatedIndex$() ? ('dock-active' | cssPrefix) : ''\"\n >\n @if (item['icon']; as icon) {\n <mat-icon\n [inline]=\"icon.inline\"\n [fontIcon]=\"icon.fontIcon\"\n [fontSet]=\"icon.fontSet\"\n [svgIcon]=\"icon.svgIcon\"\n ></mat-icon>\n }\n @if (item['title']) {\n <span [class]=\"'dock-label' | cssPrefix\">{{ item['title'] }}</span>\n }\n </button>\n }\n </div>\n</ng-template>\n","import { NgTemplateOutlet } from '@angular/common';\nimport { Component, input, viewChild } from '@angular/core';\nimport { CssPrefixPipe, MergeClassPipe } from '@piying-lib/angular-daisyui/pipe';\n\nimport { AttributesDirective, PiyingViewGroupBase } from '@piying/view-angular';\n\n@Component({\n selector: 'app-list',\n templateUrl: './component.html',\n imports: [AttributesDirective, NgTemplateOutlet, CssPrefixPipe, MergeClassPipe],\n})\nexport class ListFGC extends PiyingViewGroupBase {\n static __version = 2;\n templateRef = viewChild.required('templateRef');\n titleClass = input();\n}\n","<ng-template #templateRef let-attr=\"attributes\">\n <ul\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('list' | cssPrefix)\"\n >\n @let title = props$$()['title'];\n @if (title) {\n <li [class]=\"titleClass()\">{{ title }}</li>\n }\n\n @for (field of children$$(); track $index) {\n <li [class]=\"'list-row' | cssPrefix\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </li>\n }\n </ul>\n</ng-template>\n","import { NgTemplateOutlet } from '@angular/common';\nimport { Component, computed, viewChild } from '@angular/core';\nimport { PurePipe } from '@cyia/ngx-common/pipe';\nimport { CssPrefixPipe, MergeClassPipe } from '@piying-lib/angular-daisyui/pipe';\n\nimport { AttributesDirective, PiyingViewGroupBase } from '@piying/view-angular';\n\n@Component({\n selector: 'app-navbar',\n templateUrl: './component.html',\n imports: [AttributesDirective, NgTemplateOutlet, PurePipe, CssPrefixPipe, MergeClassPipe],\n})\nexport class NavbarFGC extends PiyingViewGroupBase {\n static __version = 2;\n static index = 0;\n templateRef = viewChild.required('templateRef');\n start$$ = computed(() => {\n return this.children$$().find((field) => {\n return field.keyPath?.slice(-1)[0] === 'start';\n });\n });\n center$$ = computed(() => {\n return this.children$$().find((field) => {\n return field.keyPath?.slice(-1)[0] === 'center';\n });\n });\n end$$ = computed(() => {\n return this.children$$().find((field) => {\n return field.keyPath?.slice(-1)[0] === 'end';\n });\n });\n rest$$ = computed(() => {\n return this.children$$().filter((field) => {\n return (\n field.keyPath?.slice(-1)[0] !== 'start' &&\n field.keyPath?.slice(-1)[0] !== 'center' &&\n field.keyPath?.slice(-1)[0] !== 'end'\n );\n });\n });\n}\n","<ng-template #templateRef let-attr=\"attributes\">\n <div\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('navbar' | cssPrefix)\"\n >\n @for (field of rest$$(); track $index) {\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n }\n @let start = start$$();\n @if (start) {\n <div [class]=\"'navbar-start' | cssPrefix\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: start }\"\n ></ng-container>\n </div>\n }\n @let center = center$$();\n @if (center) {\n <div [class]=\"'navbar-center' | cssPrefix\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: center }\"\n ></ng-container>\n </div>\n }\n\n @let end = end$$();\n @if (end) {\n <div [class]=\"'navbar-end' | cssPrefix\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: end }\"\n ></ng-container>\n </div>\n }\n </div>\n</ng-template>\n","import { NgTemplateOutlet, NgClass } from '@angular/common';\nimport { Component, computed, inject, input, model, viewChild } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { CssPrefixPipe, MergeClassPipe } from '@piying-lib/angular-daisyui/pipe';\nimport { ThemeService } from '@piying-lib/angular-daisyui/service';\n\nimport { AttributesDirective, PiyingViewGroupBase } from '@piying/view-angular';\n@Component({\n selector: 'app-drawer',\n templateUrl: './component.html',\n imports: [\n AttributesDirective,\n NgTemplateOutlet,\n FormsModule,\n NgClass,\n CssPrefixPipe,\n MergeClassPipe,\n ],\n})\nexport class DrawerFGC extends PiyingViewGroupBase {\n static __version = 2;\n static index = 0;\n name = `drawer-${DrawerFGC.index++}`;\n templateRef = viewChild.required('templateRef');\n contentClass = input<string>();\n sideClass = input<string>();\n overlayClass = input<string>();\n mode = input<'over' | 'side'>('over');\n position = input<'start' | 'end'>();\n contentFiled$$ = computed(() => {\n return this.field$$()\n .children?.()\n .find((field) => {\n return field.keyPath?.slice(-1)[0] === 'content';\n });\n });\n sideFiled$$ = computed(() => {\n return this.field$$()\n .children?.()\n .find((field) => {\n return field.keyPath?.slice(-1)[0] === 'side';\n });\n });\n opened = model(false);\n openChanged(value: boolean) {\n this.opened.set(value);\n }\n #theme = inject(ThemeService);\n wrapperClass$ = computed(() => {\n return this.#theme.setClass(\n this.mode() === 'side' && this.opened() ? this.#theme.addPrefix('drawer-open') : undefined,\n this.position() === 'end' ? this.#theme.addPrefix2('drawer', this.position()) : undefined,\n );\n });\n}\n","<ng-template #templateRef let-attr=\"attributes\">\n <div\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('drawer' | cssPrefix) : wrapperClass$()\"\n >\n <input\n [id]=\"name\"\n type=\"checkbox\"\n class=\"{{ 'drawer-toggle' | cssPrefix }}\"\n #toggle\n [ngModel]=\"opened()\"\n (ngModelChange)=\"openChanged($event)\"\n />\n <div [class]=\"contentClass() | mergeClass: ('drawer-content' | cssPrefix)\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: contentFiled$$() }\"\n ></ng-container>\n </div>\n <div [class]=\"sideClass() | mergeClass: ('drawer-side' | cssPrefix)\">\n <label\n [for]=\"name\"\n aria-label=\"close sidebar\"\n [class]=\"overlayClass() | mergeClass: ('drawer-overlay' | cssPrefix)\"\n ></label>\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: sideFiled$$() }\"\n ></ng-container>\n </div>\n </div>\n</ng-template>\n","import { NgClass, NgTemplateOutlet } from '@angular/common';\nimport { Component, computed, inject, input, linkedSignal, viewChild } from '@angular/core';\nimport { MatIcon } from '@angular/material/icon';\nimport { SelectorlessOutlet } from '@cyia/ngx-common/directive';\nimport { PurePipe } from '@cyia/ngx-common/pipe';\nimport { StrOrTemplateComponent } from '@piying-lib/angular-core';\nimport { CssPrefixPipe, MergeClassPipe } from '@piying-lib/angular-daisyui/pipe';\nimport { ThemeService, useTwClass } from '@piying-lib/angular-daisyui/service';\nimport { Size } from '@piying-lib/angular-core';\nimport { AttributesDirective, PiyingViewGroupBase } from '@piying/view-angular';\n\n@Component({\n selector: 'app-tabs',\n templateUrl: './component.html',\n imports: [\n NgTemplateOutlet,\n AttributesDirective,\n MatIcon,\n NgClass,\n CssPrefixPipe,\n MergeClassPipe,\n PurePipe,\n SelectorlessOutlet,\n ],\n})\nexport class TabsFGC extends PiyingViewGroupBase {\n static __version = 2;\n\n static index = 0;\n templateRef = viewChild.required('templateRef');\n StrOrTemplateComponent = StrOrTemplateComponent;\n size = input<Size>();\n name = `pc-tabs-${TabsFGC.index++}`;\n activatedIndex = input(0);\n type = input<'box' | 'border' | 'lift' | undefined>();\n placement = input<'top' | 'bottom'>();\n tabContentClass = input(useTwClass('bg-base-100 border-base-300 p-6'));\n activatedIndex$ = linkedSignal(this.activatedIndex);\n toggleActivate(index: number) {\n this.activatedIndex$.set(index);\n }\n #theme = inject(ThemeService);\n\n wrapperClass$$ = computed(() => {\n return this.#theme.setClass(\n this.#theme.setSize('tabs', this.size()),\n this.type() ? this.#theme.addPrefix(`tabs-${this.type()}`) : undefined,\n this.placement() ? this.#theme.addPrefix(`tabs-${this.placement()}`) : undefined,\n );\n });\n labelInputs = (input: any) => {\n return {\n content: input,\n };\n };\n changeIndex(index: number) {\n this.activatedIndex$.set(index);\n }\n}\n","<ng-template #templateRef let-attr=\"attributes\">\n <div\n role=\"tablist\"\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: ('tabs' | cssPrefix) : wrapperClass$$()\"\n >\n @for (field of children$$(); track $index) {\n @let item = field.props();\n <label\n role=\"tab\"\n [class]=\"\n 'tab'\n | cssPrefix\n | mergeClass: ($index === activatedIndex$() ? ('tab-active' | cssPrefix) : undefined)\n \"\n (click)=\"changeIndex($index)\"\n >\n <!-- <input type=\"radio\" [name]=\"name\" /> -->\n\n <ng-template\n [selectlessOutlet]=\"StrOrTemplateComponent\"\n [selectlessOutletInputs]=\"labelInputs | pure: item['title']\"\n ></ng-template>\n </label>\n <div [class]=\"'tab-content' | cssPrefix | mergeClass: tabContentClass()\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n </div>\n }\n </div>\n</ng-template>\n","import { NgTemplateOutlet, NgComponentOutlet } from '@angular/common';\nimport { Component, computed, inject, input, model, viewChild } from '@angular/core';\nimport { SelectorlessOutlet } from '@cyia/ngx-common/directive';\nimport { PurePipe } from '@cyia/ngx-common/pipe';\nimport { StrOrTemplateComponent } from '@piying-lib/angular-core';\nimport { CssPrefixPipe, MergeClassPipe, TwPrefixPipe } from '@piying-lib/angular-daisyui/pipe';\nimport { ThemeService } from '@piying-lib/angular-daisyui/service';\nimport { Color } from '@piying-lib/angular-core';\nimport { AttributesDirective, PiyingViewGroupBase } from '@piying/view-angular';\nimport clsx from 'clsx';\n\n@Component({\n selector: 'app-steps',\n templateUrl: './component.html',\n imports: [\n NgTemplateOutlet,\n CssPrefixPipe,\n MergeClassPipe,\n TwPrefixPipe,\n PurePipe,\n SelectorlessOutlet,\n StrOrTemplateComponent,\n NgComponentOutlet,\n AttributesDirective,\n ],\n})\nexport class StepsFGC extends PiyingViewGroupBase {\n static __version = 2;\n templateRef = viewChild.required('templateRef');\n readonly StrOrTemplateComponent = StrOrTemplateComponent;\n activatedIndex = model(0);\n activatedItem$$ = computed(() => this.field$$().children!()[this.activatedIndex()]);\n prevItem$$ = computed(() => {\n return this.children$$()[this.activatedIndex() - 1];\n });\n customAction = input();\n prev = input('⬅️');\n next = input('➡️');\n direction = input<'vertical' | 'horizontal'>();\n stepColor = input<Color>('primary');\n\n toPrev() {\n this.activatedIndex.update((value) => value - 1);\n }\n toNext() {\n this.activatedIndex.update((value) => value + 1);\n }\n isActivated(activatedIndex: number, currentIndex: number) {\n return activatedIndex >= currentIndex;\n }\n #theme = inject(ThemeService);\n wrapperClass$$ = computed(() => {\n return clsx(this.#theme.addPrefix('steps'), this.#theme.addPrefix2('steps', this.direction()));\n });\n}\n","<ng-template #templateRef let-attr=\"attributes\">\n <ul\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"attr()?.class | mergeClass: wrapperClass$$()\"\n >\n @for (field of children$$(); track field.id || $index) {\n @let label = field.props()['title'] || '📄' + ($index + 1);\n <li\n [class]=\"\n 'step'\n | cssPrefix\n | mergeClass\n : ((isActivated | pure: activatedIndex() : $index)\n ? ('step-' + stepColor() | cssPrefix)\n : undefined)\n \"\n >\n {{ label }}\n </li>\n }\n </ul>\n <div class=\"{{ 'flex flex-col gap-4' | twPrefix }}\">\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: activatedItem$$() }\"\n ></ng-container>\n @if (customAction()) {\n <ng-container\n *ngComponentOutlet=\"\n StrOrTemplateComponent;\n context: { inputs: { content: customAction(), context: this } }\n \"\n ></ng-container>\n } @else {\n <div [class]=\"'flex gap-2 items-center' | twPrefix\">\n <button\n [class]=\"'btn btn-secondary' | cssPrefix\"\n [disabled]=\"activatedIndex() === 0 || prevItem$$().form.control?.invalid\"\n (click)=\"toPrev()\"\n >\n {{ prev() }}\n </button>\n\n <button\n [class]=\"'btn btn-primary' | cssPrefix\"\n [disabled]=\"\n activatedItem$$().form.control?.invalid || activatedIndex() + 1 !== children$$().length\n \"\n (click)=\"toNext()\"\n >\n {{ next() }}\n </button>\n </div>\n }\n </div>\n</ng-template>\n","import { NgTemplateOutlet } from '@angular/common';\nimport { Component, viewChild } from '@angular/core';\nimport { CssPrefixPipe, MergeClassPipe } from '@piying-lib/angular-daisyui/pipe';\n\nimport { AttributesDirective, PiyingViewGroupBase } from '@piying/view-angular';\n\n@Component({\n selector: 'app-fieldset',\n templateUrl: './component.html',\n imports: [AttributesDirective, NgTemplateOutlet, CssPrefixPipe, MergeClassPipe],\n})\nexport class FieldsetFGC extends PiyingViewGroupBase {\n static __version = 2;\n templateRef = viewChild.required('templateRef');\n}\n","<ng-template #templateRef let-attr=\"attributes\">\n <fieldset\n [attributes]=\"attr()\"\n [excludes]=\"['class']\"\n [class]=\"'fieldset' | cssPrefix | mergeClass: attr()?.class\"\n >\n <legend [class]=\"'fieldset-legend' | cssPrefix\">{{ props$$()['title'] }}</legend>\n\n @for (field of children$$(); track $index) {\n <ng-container\n *ngTemplateOutlet=\"fieldTemplateRef(); context: { $implicit: field }\"\n ></ng-container>\n }\n </fieldset>\n</ng-template>\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|