@bootkit/ng0 0.0.0-alpha.1
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 +2 -0
- package/accordion/accordion-item.component.d.ts +13 -0
- package/accordion/accordion.component.d.ts +13 -0
- package/accordion/accordion.module.d.ts +8 -0
- package/accordion/index.d.ts +5 -0
- package/accordion/public-api.d.ts +3 -0
- package/collapse/collapse.component.d.ts +18 -0
- package/collapse/collapse.directive.d.ts +32 -0
- package/collapse/collapse.module.d.ts +8 -0
- package/collapse/index.d.ts +5 -0
- package/collapse/public-api.d.ts +3 -0
- package/common/index.d.ts +5 -0
- package/common/public-api.d.ts +2 -0
- package/common/types.d.ts +4 -0
- package/common/utils.d.ts +3 -0
- package/esm2022/accordion/accordion-item.component.mjs +34 -0
- package/esm2022/accordion/accordion.component.mjs +25 -0
- package/esm2022/accordion/accordion.module.mjs +25 -0
- package/esm2022/accordion/bootkit-ng0-accordion.mjs +5 -0
- package/esm2022/accordion/public-api.mjs +4 -0
- package/esm2022/bootkit-ng0.mjs +5 -0
- package/esm2022/collapse/bootkit-ng0-collapse.mjs +5 -0
- package/esm2022/collapse/collapse.component.mjs +46 -0
- package/esm2022/collapse/collapse.directive.mjs +94 -0
- package/esm2022/collapse/collapse.module.mjs +23 -0
- package/esm2022/collapse/public-api.mjs +4 -0
- package/esm2022/common/bootkit-ng0-common.mjs +5 -0
- package/esm2022/common/public-api.mjs +3 -0
- package/esm2022/common/types.mjs +3 -0
- package/esm2022/common/utils.mjs +16 -0
- package/esm2022/lib/index.mjs +3 -0
- package/esm2022/lib/types.mjs +2 -0
- package/esm2022/modal/bootkit-ng0-modal.mjs +5 -0
- package/esm2022/modal/modal.component.mjs +44 -0
- package/esm2022/modal/modal.module.mjs +20 -0
- package/esm2022/modal/public-api.mjs +3 -0
- package/esm2022/modal/types.mjs +3 -0
- package/esm2022/nav/bootkit-ng0-nav.mjs +5 -0
- package/esm2022/nav/nav-item.directive.mjs +26 -0
- package/esm2022/nav/nav-link.directive.mjs +45 -0
- package/esm2022/nav/nav.directive.mjs +23 -0
- package/esm2022/nav/nav.module.mjs +35 -0
- package/esm2022/nav/public-api.mjs +7 -0
- package/esm2022/nav/tab-content.component.mjs +29 -0
- package/esm2022/nav/tab-pane.directive.mjs +20 -0
- package/esm2022/offcanvas/bootkit-ng0-offcanvas.mjs +5 -0
- package/esm2022/offcanvas/offcanvas.directive.mjs +118 -0
- package/esm2022/offcanvas/offcanvas.module.mjs +19 -0
- package/esm2022/offcanvas/public-api.mjs +3 -0
- package/esm2022/overlay/bootkit-ng0-overlay.mjs +5 -0
- package/esm2022/overlay/overlay.directive.mjs +111 -0
- package/esm2022/overlay/overlay.module.mjs +22 -0
- package/esm2022/overlay/private/utils.mjs +58 -0
- package/esm2022/overlay/public-api.mjs +3 -0
- package/esm2022/popover/bootkit-ng0-popover.mjs +5 -0
- package/esm2022/popover/popover-wrapper/popover-wrapper.component.mjs +29 -0
- package/esm2022/popover/popover.directive.mjs +140 -0
- package/esm2022/popover/public-api.mjs +2 -0
- package/esm2022/popover/types.mjs +2 -0
- package/esm2022/public-api.mjs +5 -0
- package/esm2022/toast/bootkit-ng0-toast.mjs +5 -0
- package/esm2022/toast/public-api.mjs +4 -0
- package/esm2022/toast/toast-ref.mjs +27 -0
- package/esm2022/toast/toast.component.mjs +68 -0
- package/esm2022/toast/toast.service.mjs +93 -0
- package/esm2022/toast/types.mjs +2 -0
- package/esm2022/tooltip/bootkit-ng0-tooltip.mjs +5 -0
- package/esm2022/tooltip/public-api.mjs +3 -0
- package/esm2022/tooltip/tooltip-wrapper/tooltip-wrapper.component.mjs +44 -0
- package/esm2022/tooltip/tooltip.directive.mjs +93 -0
- package/esm2022/tooltip/types.mjs +2 -0
- package/fesm2022/bootkit-ng0-accordion.mjs +83 -0
- package/fesm2022/bootkit-ng0-accordion.mjs.map +1 -0
- package/fesm2022/bootkit-ng0-collapse.mjs +163 -0
- package/fesm2022/bootkit-ng0-collapse.mjs.map +1 -0
- package/fesm2022/bootkit-ng0-common.mjs +26 -0
- package/fesm2022/bootkit-ng0-common.mjs.map +1 -0
- package/fesm2022/bootkit-ng0-modal.mjs +68 -0
- package/fesm2022/bootkit-ng0-modal.mjs.map +1 -0
- package/fesm2022/bootkit-ng0-nav.mjs +166 -0
- package/fesm2022/bootkit-ng0-nav.mjs.map +1 -0
- package/fesm2022/bootkit-ng0-offcanvas.mjs +141 -0
- package/fesm2022/bootkit-ng0-offcanvas.mjs.map +1 -0
- package/fesm2022/bootkit-ng0-overlay.mjs +194 -0
- package/fesm2022/bootkit-ng0-overlay.mjs.map +1 -0
- package/fesm2022/bootkit-ng0-popover.mjs +173 -0
- package/fesm2022/bootkit-ng0-popover.mjs.map +1 -0
- package/fesm2022/bootkit-ng0-toast.mjs +191 -0
- package/fesm2022/bootkit-ng0-toast.mjs.map +1 -0
- package/fesm2022/bootkit-ng0-tooltip.mjs +141 -0
- package/fesm2022/bootkit-ng0-tooltip.mjs.map +1 -0
- package/fesm2022/bootkit-ng0.mjs +12 -0
- package/fesm2022/bootkit-ng0.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/index.d.ts +2 -0
- package/lib/types.d.ts +1 -0
- package/modal/index.d.ts +5 -0
- package/modal/modal.component.d.ts +18 -0
- package/modal/modal.module.d.ts +7 -0
- package/modal/public-api.d.ts +2 -0
- package/modal/types.d.ts +2 -0
- package/nav/index.d.ts +5 -0
- package/nav/nav-item.directive.d.ts +13 -0
- package/nav/nav-link.directive.d.ts +16 -0
- package/nav/nav.directive.d.ts +11 -0
- package/nav/nav.module.d.ts +11 -0
- package/nav/public-api.d.ts +6 -0
- package/nav/tab-content.component.d.ts +15 -0
- package/nav/tab-pane.directive.d.ts +9 -0
- package/offcanvas/index.d.ts +5 -0
- package/offcanvas/offcanvas.directive.d.ts +24 -0
- package/offcanvas/offcanvas.module.d.ts +7 -0
- package/offcanvas/public-api.d.ts +2 -0
- package/overlay/index.d.ts +5 -0
- package/overlay/overlay.directive.d.ts +50 -0
- package/overlay/overlay.module.d.ts +10 -0
- package/overlay/private/utils.d.ts +10 -0
- package/overlay/public-api.d.ts +2 -0
- package/package.json +101 -0
- package/popover/index.d.ts +5 -0
- package/popover/popover-wrapper/popover-wrapper.component.d.ts +15 -0
- package/popover/popover.directive.d.ts +30 -0
- package/popover/public-api.d.ts +1 -0
- package/popover/types.d.ts +4 -0
- package/public-api.d.ts +1 -0
- package/toast/index.d.ts +5 -0
- package/toast/public-api.d.ts +3 -0
- package/toast/toast-ref.d.ts +12 -0
- package/toast/toast.component.d.ts +19 -0
- package/toast/toast.service.d.ts +43 -0
- package/toast/types.d.ts +44 -0
- package/tooltip/index.d.ts +5 -0
- package/tooltip/public-api.d.ts +2 -0
- package/tooltip/tooltip-wrapper/tooltip-wrapper.component.d.ts +19 -0
- package/tooltip/tooltip.directive.d.ts +24 -0
- package/tooltip/types.d.ts +3 -0
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { Directive, HostListener, input } from '@angular/core';
|
|
2
|
+
import { ComponentPortal } from '@angular/cdk/portal';
|
|
3
|
+
import { TooltipWrapperComponent } from './tooltip-wrapper/tooltip-wrapper.component';
|
|
4
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/cdk/overlay";
|
|
7
|
+
export class TooltipDirective {
|
|
8
|
+
overlayService;
|
|
9
|
+
elementRef;
|
|
10
|
+
destroyRef;
|
|
11
|
+
viewRef;
|
|
12
|
+
content = input(undefined, { alias: 'ng0Tooltip' });
|
|
13
|
+
placement = input('bottom');
|
|
14
|
+
portal;
|
|
15
|
+
overlayRef;
|
|
16
|
+
constructor(overlayService, elementRef, destroyRef, viewRef) {
|
|
17
|
+
this.overlayService = overlayService;
|
|
18
|
+
this.elementRef = elementRef;
|
|
19
|
+
this.destroyRef = destroyRef;
|
|
20
|
+
this.viewRef = viewRef;
|
|
21
|
+
}
|
|
22
|
+
ngOnInit() {
|
|
23
|
+
this.portal = new ComponentPortal(TooltipWrapperComponent, this.viewRef);
|
|
24
|
+
}
|
|
25
|
+
onMouseEnter() {
|
|
26
|
+
this.createOverlay();
|
|
27
|
+
}
|
|
28
|
+
onMouseLeave() {
|
|
29
|
+
this.disposeOverlay();
|
|
30
|
+
}
|
|
31
|
+
createOverlay() {
|
|
32
|
+
let wrapperInstance;
|
|
33
|
+
const scrollStrategy = this.overlayService.scrollStrategies.reposition();
|
|
34
|
+
const positionStrategy = this.overlayService.position().flexibleConnectedTo(this.elementRef).withPositions(this.getPositions());
|
|
35
|
+
positionStrategy.positionChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(p => {
|
|
36
|
+
wrapperRef.instance.set(this.content(), p.connectionPair.key);
|
|
37
|
+
});
|
|
38
|
+
this.overlayRef = this.overlayService.create({ scrollStrategy, positionStrategy });
|
|
39
|
+
let wrapperRef = this.overlayRef.attach(this.portal);
|
|
40
|
+
wrapperRef.instance.set(this.content(), this.placement());
|
|
41
|
+
}
|
|
42
|
+
disposeOverlay() {
|
|
43
|
+
if (this.overlayRef) {
|
|
44
|
+
this.overlayRef.dispose();
|
|
45
|
+
this.overlayRef = undefined;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
getPositions() {
|
|
49
|
+
const c = 'center', t = 'top', b = 'bottom', s = 'start', e = 'end';
|
|
50
|
+
const top = { key: t, originX: c, originY: t, overlayX: c, overlayY: b, };
|
|
51
|
+
const bottom = { key: b, originX: c, originY: b, overlayX: c, overlayY: t, };
|
|
52
|
+
const start = { key: s, originX: s, originY: c, overlayX: e, overlayY: c, };
|
|
53
|
+
const end = { key: e, originX: e, originY: c, overlayX: s, overlayY: c, };
|
|
54
|
+
let positions;
|
|
55
|
+
switch (this.placement()) {
|
|
56
|
+
case 'bottom':
|
|
57
|
+
positions = [bottom, top];
|
|
58
|
+
break;
|
|
59
|
+
case 'start':
|
|
60
|
+
positions = [start, start];
|
|
61
|
+
break;
|
|
62
|
+
case 'end':
|
|
63
|
+
positions = [end, start];
|
|
64
|
+
break;
|
|
65
|
+
case 'top':
|
|
66
|
+
positions = [top, bottom];
|
|
67
|
+
break;
|
|
68
|
+
default:
|
|
69
|
+
positions = [bottom, top];
|
|
70
|
+
}
|
|
71
|
+
return positions;
|
|
72
|
+
}
|
|
73
|
+
ngOnDestroy() {
|
|
74
|
+
this.disposeOverlay();
|
|
75
|
+
}
|
|
76
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: TooltipDirective, deps: [{ token: i1.Overlay }, { token: i0.ElementRef }, { token: i0.DestroyRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
77
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.11", type: TooltipDirective, isStandalone: true, selector: "[ng0Tooltip]", inputs: { content: { classPropertyName: "content", publicName: "ng0Tooltip", isSignal: true, isRequired: false, transformFunction: null }, placement: { classPropertyName: "placement", publicName: "placement", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()" } }, exportAs: ["ng0Tooltip"], ngImport: i0 });
|
|
78
|
+
}
|
|
79
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: TooltipDirective, decorators: [{
|
|
80
|
+
type: Directive,
|
|
81
|
+
args: [{
|
|
82
|
+
selector: '[ng0Tooltip]',
|
|
83
|
+
exportAs: 'ng0Tooltip',
|
|
84
|
+
standalone: true
|
|
85
|
+
}]
|
|
86
|
+
}], ctorParameters: () => [{ type: i1.Overlay }, { type: i0.ElementRef }, { type: i0.DestroyRef }, { type: i0.ViewContainerRef }], propDecorators: { onMouseEnter: [{
|
|
87
|
+
type: HostListener,
|
|
88
|
+
args: ['mouseenter']
|
|
89
|
+
}], onMouseLeave: [{
|
|
90
|
+
type: HostListener,
|
|
91
|
+
args: ['mouseleave']
|
|
92
|
+
}] } });
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../projects/ng0/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Directive, TemplateRef, ViewContainerRef, OnDestroy, ElementRef, HostListener, OnInit,\r\n    input,\r\n    DestroyRef\r\n} from '@angular/core';\r\nimport { Overlay, OverlayRef } from '@angular/cdk/overlay';\r\nimport { ComponentPortal } from '@angular/cdk/portal';\r\nimport { TooltipWrapperComponent } from './tooltip-wrapper/tooltip-wrapper.component';\r\nimport { TooltipPlacement } from './types';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\n@Directive({\r\n    selector: '[ng0Tooltip]',\r\n    exportAs: 'ng0Tooltip',\r\n    standalone: true\r\n})\r\nexport class TooltipDirective implements OnInit, OnDestroy {\r\n    public content = input<string | TemplateRef<any> | undefined | null>(undefined, { alias: 'ng0Tooltip' });\r\n    public placement = input<TooltipPlacement>('bottom');\r\n    private portal!: ComponentPortal<TooltipWrapperComponent>;\r\n    private overlayRef?: OverlayRef;\r\n\r\n    constructor(\r\n        private overlayService: Overlay,\r\n        private elementRef: ElementRef,\r\n        private destroyRef: DestroyRef,\r\n        private viewRef: ViewContainerRef) {\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this.portal = new ComponentPortal(TooltipWrapperComponent, this.viewRef);\r\n    }\r\n\r\n    @HostListener('mouseenter') \r\n    private onMouseEnter(): void {\r\n        this.createOverlay();\r\n    }\r\n\r\n    @HostListener('mouseleave') \r\n    private onMouseLeave(): void {\r\n        this.disposeOverlay();\r\n    }\r\n\r\n    private createOverlay(): void {\r\n        let wrapperInstance: TooltipWrapperComponent;\r\n\r\n        const scrollStrategy = this.overlayService.scrollStrategies.reposition();\r\n        const positionStrategy = this.overlayService.position().flexibleConnectedTo(this.elementRef).withPositions(this.getPositions());\r\n\r\n        positionStrategy.positionChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(p => {\r\n            wrapperRef.instance.set(this.content(), (p.connectionPair as any).key);\r\n        });\r\n\r\n        this.overlayRef = this.overlayService.create({ scrollStrategy, positionStrategy });\r\n        let wrapperRef = this.overlayRef.attach(this.portal);\r\n        wrapperRef.instance.set(this.content(), this.placement());\r\n    }\r\n\r\n    private disposeOverlay(): void {\r\n        if (this.overlayRef) {\r\n            this.overlayRef.dispose();\r\n            this.overlayRef = undefined;\r\n        }\r\n    }\r\n\r\n    private getPositions(): any[] {\r\n        const c = 'center', t = 'top', b = 'bottom', s = 'start', e = 'end';\r\n        const top = { key: t, originX: c, originY: t, overlayX: c, overlayY: b, };\r\n        const bottom = { key: b, originX: c, originY: b, overlayX: c, overlayY: t, };\r\n        const start = { key: s, originX: s, originY: c, overlayX: e, overlayY: c, };\r\n        const end = { key: e, originX: e, originY: c, overlayX: s, overlayY: c, };\r\n\r\n        let positions: Array<any>;\r\n\r\n        switch (this.placement()) {\r\n            case 'bottom':\r\n                positions = [bottom, top];\r\n                break;\r\n            case 'start':\r\n                positions = [start, start];\r\n                break;\r\n            case 'end':\r\n                positions = [end, start];\r\n                break;\r\n            case 'top':\r\n                positions = [top, bottom];\r\n                break;\r\n            default:\r\n                positions = [bottom, top];\r\n        }\r\n\r\n        return positions;\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.disposeOverlay();\r\n    }\r\n}\r\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZzAvdG9vbHRpcC90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVtcGxhdGVSZWYgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5cclxuZXhwb3J0IHR5cGUgVG9vbHRpcFBsYWNlbWVudCA9ICd0b3AnIHwgJ2JvdHRvbScgfCAnc3RhcnQnIHwgJ2VuZCc7XHJcbmV4cG9ydCB0eXBlIFRvb2x0aXBDb250ZW50ID0gc3RyaW5nIHwgVGVtcGxhdGVSZWY8YW55PjtcclxuXHJcblxyXG4iXX0=
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { input, model, effect, Component, ChangeDetectionStrategy, ContentChildren, NgModule } from '@angular/core';
|
|
3
|
+
import { CollapseComponent } from '@bootkit/ng0/collapse';
|
|
4
|
+
|
|
5
|
+
class AccordionItemComponent {
|
|
6
|
+
_element;
|
|
7
|
+
_renderer;
|
|
8
|
+
_accordion;
|
|
9
|
+
header = input();
|
|
10
|
+
collapsed = model(true);
|
|
11
|
+
constructor(_element, _renderer, _accordion) {
|
|
12
|
+
this._element = _element;
|
|
13
|
+
this._renderer = _renderer;
|
|
14
|
+
this._accordion = _accordion;
|
|
15
|
+
this._renderer.addClass(this._element.nativeElement, 'accordion-item');
|
|
16
|
+
effect(() => {
|
|
17
|
+
var collapsed = this.collapsed();
|
|
18
|
+
if (_accordion.mode() == 'single') {
|
|
19
|
+
if (!collapsed) {
|
|
20
|
+
this._accordion.items.filter(x => x !== this).forEach(x => x.collapsed.update(x => true));
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}, { allowSignalWrites: true });
|
|
24
|
+
}
|
|
25
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: AccordionItemComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: AccordionComponent }], target: i0.ɵɵFactoryTarget.Component });
|
|
26
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.11", type: AccordionItemComponent, isStandalone: true, selector: "ng0-accordion-item", inputs: { header: { classPropertyName: "header", publicName: "header", isSignal: true, isRequired: false, transformFunction: null }, collapsed: { classPropertyName: "collapsed", publicName: "collapsed", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { collapsed: "collapsedChange" }, exportAs: ["ng0AccordionItem"], ngImport: i0, template: "<h6 class=\"accordion-header\">\r\n <button class=\"accordion-button\" type=\"button\" [class.collapsed]=\"collapsed()\" (click)=\"collapsed.set(!collapsed())\">\r\n {{header()}}\r\n </button>\r\n</h6>\r\n\r\n<ng0-collapse [collapsed]=\"collapsed()\">\r\n <div class=\"accordion-body\">\r\n <ng-content></ng-content>\r\n </div>\r\n</ng0-collapse>", styles: [":host{display:block}\n"], dependencies: [{ kind: "component", type: CollapseComponent, selector: "ng0-collapse", inputs: ["collapsed", "timings"], outputs: ["collapsedChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
27
|
+
}
|
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: AccordionItemComponent, decorators: [{
|
|
29
|
+
type: Component,
|
|
30
|
+
args: [{ selector: 'ng0-accordion-item', exportAs: 'ng0AccordionItem', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
|
|
31
|
+
CollapseComponent
|
|
32
|
+
], template: "<h6 class=\"accordion-header\">\r\n <button class=\"accordion-button\" type=\"button\" [class.collapsed]=\"collapsed()\" (click)=\"collapsed.set(!collapsed())\">\r\n {{header()}}\r\n </button>\r\n</h6>\r\n\r\n<ng0-collapse [collapsed]=\"collapsed()\">\r\n <div class=\"accordion-body\">\r\n <ng-content></ng-content>\r\n </div>\r\n</ng0-collapse>", styles: [":host{display:block}\n"] }]
|
|
33
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: AccordionComponent }] });
|
|
34
|
+
|
|
35
|
+
class AccordionComponent {
|
|
36
|
+
_element;
|
|
37
|
+
_renderer;
|
|
38
|
+
/** Items open mode */
|
|
39
|
+
mode = input('single');
|
|
40
|
+
items;
|
|
41
|
+
constructor(_element, _renderer) {
|
|
42
|
+
this._element = _element;
|
|
43
|
+
this._renderer = _renderer;
|
|
44
|
+
this._renderer.addClass(this._element.nativeElement, 'accordion');
|
|
45
|
+
}
|
|
46
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: AccordionComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
|
|
47
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.11", type: AccordionComponent, isStandalone: true, selector: "ng0-accordion", inputs: { mode: { classPropertyName: "mode", publicName: "mode", isSignal: true, isRequired: false, transformFunction: null } }, queries: [{ propertyName: "items", predicate: AccordionItemComponent }], exportAs: ["ng0Accordion"], ngImport: i0, template: "<ng-content></ng-content>", styles: [":host{display:block}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
48
|
+
}
|
|
49
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: AccordionComponent, decorators: [{
|
|
50
|
+
type: Component,
|
|
51
|
+
args: [{ selector: 'ng0-accordion', exportAs: 'ng0Accordion', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-content></ng-content>", styles: [":host{display:block}\n"] }]
|
|
52
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { items: [{
|
|
53
|
+
type: ContentChildren,
|
|
54
|
+
args: [AccordionItemComponent]
|
|
55
|
+
}] } });
|
|
56
|
+
|
|
57
|
+
class AccordionModule {
|
|
58
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: AccordionModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
59
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.11", ngImport: i0, type: AccordionModule, imports: [AccordionComponent,
|
|
60
|
+
AccordionItemComponent], exports: [AccordionComponent,
|
|
61
|
+
AccordionItemComponent] });
|
|
62
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: AccordionModule, imports: [AccordionItemComponent] });
|
|
63
|
+
}
|
|
64
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: AccordionModule, decorators: [{
|
|
65
|
+
type: NgModule,
|
|
66
|
+
args: [{
|
|
67
|
+
imports: [
|
|
68
|
+
AccordionComponent,
|
|
69
|
+
AccordionItemComponent,
|
|
70
|
+
],
|
|
71
|
+
exports: [
|
|
72
|
+
AccordionComponent,
|
|
73
|
+
AccordionItemComponent,
|
|
74
|
+
]
|
|
75
|
+
}]
|
|
76
|
+
}] });
|
|
77
|
+
|
|
78
|
+
/**
|
|
79
|
+
* Generated bundle index. Do not edit.
|
|
80
|
+
*/
|
|
81
|
+
|
|
82
|
+
export { AccordionComponent, AccordionItemComponent, AccordionModule };
|
|
83
|
+
//# sourceMappingURL=bootkit-ng0-accordion.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bootkit-ng0-accordion.mjs","sources":["../../../projects/ng0/accordion/accordion-item.component.ts","../../../projects/ng0/accordion/accordion-item.component.html","../../../projects/ng0/accordion/accordion.component.ts","../../../projects/ng0/accordion/accordion.component.html","../../../projects/ng0/accordion/accordion.module.ts","../../../projects/ng0/accordion/bootkit-ng0-accordion.ts"],"sourcesContent":["import { ChangeDetectionStrategy, Component, effect, ElementRef, input, model, Renderer2 } from '@angular/core';\r\nimport { CollapseComponent } from '@bootkit/ng0/collapse';\r\nimport { AccordionComponent } from './accordion.component';\r\n\r\n@Component({\r\n selector: 'ng0-accordion-item',\r\n exportAs: 'ng0AccordionItem',\r\n templateUrl: './accordion-item.component.html',\r\n standalone: true,\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n styles: `:host {display: block;}`,\r\n imports: [\r\n CollapseComponent\r\n ]\r\n})\r\nexport class AccordionItemComponent {\r\n public header = input<string>();\r\n public collapsed = model(true);\r\n\r\n constructor(private _element: ElementRef, private _renderer: Renderer2, private _accordion: AccordionComponent) {\r\n this._renderer.addClass(this._element.nativeElement, 'accordion-item');\r\n\r\n effect(() => {\r\n var collapsed = this.collapsed();\r\n \r\n if(_accordion.mode() == 'single') {\r\n if(!collapsed) {\r\n this._accordion.items.filter(x => x !== this).forEach(x => x.collapsed.update(x => true));\r\n }\r\n }\r\n }, {allowSignalWrites: true})\r\n }\r\n}\r\n","<h6 class=\"accordion-header\">\r\n <button class=\"accordion-button\" type=\"button\" [class.collapsed]=\"collapsed()\" (click)=\"collapsed.set(!collapsed())\">\r\n {{header()}}\r\n </button>\r\n</h6>\r\n\r\n<ng0-collapse [collapsed]=\"collapsed()\">\r\n <div class=\"accordion-body\">\r\n <ng-content></ng-content>\r\n </div>\r\n</ng0-collapse>","import { ChangeDetectionStrategy, Component, ContentChildren, ElementRef, input, QueryList, Renderer2 } from '@angular/core';\r\nimport { AccordionItemComponent } from './accordion-item.component';\r\n\r\n@Component({\r\n selector: 'ng0-accordion',\r\n exportAs: 'ng0Accordion',\r\n templateUrl: './accordion.component.html',\r\n standalone: true,\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n styles: `:host {display: block;}`\r\n})\r\nexport class AccordionComponent {\r\n /** Items open mode */\r\n public mode = input<'single' | 'multiple'>('single');\r\n\r\n @ContentChildren(AccordionItemComponent)\r\n public readonly items!: QueryList<AccordionItemComponent>;\r\n\r\n constructor(private _element: ElementRef, private _renderer: Renderer2) {\r\n this._renderer.addClass(this._element.nativeElement, 'accordion');\r\n }\r\n}\r\n","<ng-content></ng-content>","import { NgModule } from '@angular/core';\r\nimport { AccordionComponent } from './accordion.component';\r\nimport { AccordionItemComponent } from './accordion-item.component';\r\n\r\n@NgModule({\r\n imports: [\r\n AccordionComponent,\r\n AccordionItemComponent,\r\n ],\r\n exports: [\r\n AccordionComponent,\r\n AccordionItemComponent,\r\n ]\r\n})\r\nexport class AccordionModule {\r\n}\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["i1.AccordionComponent"],"mappings":"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"}
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { input, effect, Directive, model, Component, ChangeDetectionStrategy, HostBinding, NgModule } from '@angular/core';
|
|
3
|
+
import * as i1 from '@angular/animations';
|
|
4
|
+
import { style, animate, trigger, state, transition } from '@angular/animations';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Directive to handle the collapse and expand functionality of a host element.
|
|
8
|
+
*/
|
|
9
|
+
class CollapseDirective {
|
|
10
|
+
el;
|
|
11
|
+
builder;
|
|
12
|
+
renderer;
|
|
13
|
+
/**
|
|
14
|
+
* Indicates whether the host element is collapsed.
|
|
15
|
+
* @input
|
|
16
|
+
*/
|
|
17
|
+
collapsed = input(false);
|
|
18
|
+
/** Animation timings for collapse/expand animations.
|
|
19
|
+
* @input
|
|
20
|
+
*/
|
|
21
|
+
timings = input('0.2s');
|
|
22
|
+
_player;
|
|
23
|
+
_firstExecution = true;
|
|
24
|
+
constructor(el, builder, renderer) {
|
|
25
|
+
this.el = el;
|
|
26
|
+
this.builder = builder;
|
|
27
|
+
this.renderer = renderer;
|
|
28
|
+
renderer.setStyle(el.nativeElement, 'overflow', 'hidden');
|
|
29
|
+
effect(() => {
|
|
30
|
+
var collapsed = this.collapsed();
|
|
31
|
+
if (this._firstExecution) {
|
|
32
|
+
this._firstExecution = false;
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
if (collapsed)
|
|
36
|
+
this._collapse();
|
|
37
|
+
else
|
|
38
|
+
this._expand();
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
ngOnInit() {
|
|
42
|
+
this._addClass('collapse');
|
|
43
|
+
if (!this.collapsed()) {
|
|
44
|
+
this._addClass('show');
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
_collapse() {
|
|
48
|
+
if (this._player) {
|
|
49
|
+
this._player.destroy();
|
|
50
|
+
}
|
|
51
|
+
this._playAnimation([
|
|
52
|
+
style({ height: '*', opacity: '*' }),
|
|
53
|
+
animate(this.timings(), style({ height: 0, opacity: 0 })),
|
|
54
|
+
]);
|
|
55
|
+
this._player.onDone(() => {
|
|
56
|
+
if (this.collapsed()) {
|
|
57
|
+
this._removeClass('show');
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
_expand() {
|
|
62
|
+
if (this._player) {
|
|
63
|
+
this._player.destroy();
|
|
64
|
+
}
|
|
65
|
+
this._addClass('show');
|
|
66
|
+
this._playAnimation([
|
|
67
|
+
style({ height: 0, opacity: 0 }),
|
|
68
|
+
animate(this.timings(), style({ height: '*', opacity: '*' })),
|
|
69
|
+
]);
|
|
70
|
+
this._player.onDone(() => {
|
|
71
|
+
this._player.destroy();
|
|
72
|
+
this._player = undefined;
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
_playAnimation(animation) {
|
|
76
|
+
this._player = this.builder.build(animation).create(this.el.nativeElement);
|
|
77
|
+
this._player.play();
|
|
78
|
+
}
|
|
79
|
+
_addClass = (cls) => this.renderer.addClass(this.el.nativeElement, cls);
|
|
80
|
+
_removeClass = (cls) => this.renderer.removeClass(this.el.nativeElement, cls);
|
|
81
|
+
ngOnDestroy() {
|
|
82
|
+
this._player?.destroy();
|
|
83
|
+
}
|
|
84
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: CollapseDirective, deps: [{ token: i0.ElementRef }, { token: i1.AnimationBuilder }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
|
|
85
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.11", type: CollapseDirective, isStandalone: true, selector: "[ng0Collapse]", inputs: { collapsed: { classPropertyName: "collapsed", publicName: "collapsed", isSignal: true, isRequired: false, transformFunction: null }, timings: { classPropertyName: "timings", publicName: "timings", isSignal: true, isRequired: false, transformFunction: null } }, exportAs: ["ng0Collapse"], ngImport: i0 });
|
|
86
|
+
}
|
|
87
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: CollapseDirective, decorators: [{
|
|
88
|
+
type: Directive,
|
|
89
|
+
args: [{
|
|
90
|
+
selector: '[ng0Collapse]',
|
|
91
|
+
exportAs: 'ng0Collapse',
|
|
92
|
+
standalone: true,
|
|
93
|
+
}]
|
|
94
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.AnimationBuilder }, { type: i0.Renderer2 }] });
|
|
95
|
+
|
|
96
|
+
/**
|
|
97
|
+
* A component that provides collapse and expand functionality.
|
|
98
|
+
*/
|
|
99
|
+
class CollapseComponent {
|
|
100
|
+
/**
|
|
101
|
+
* Indicates whether the host element is collapsed.
|
|
102
|
+
* @model
|
|
103
|
+
*/
|
|
104
|
+
collapsed = model(false);
|
|
105
|
+
/** Animation timings for collapse/expand animations.
|
|
106
|
+
* @input
|
|
107
|
+
*/
|
|
108
|
+
timings = input('0.2s');
|
|
109
|
+
get _collapseExpand() {
|
|
110
|
+
return { value: this.collapsed() ? 'collapsed' : 'expanded', params: { timings: this.timings() } };
|
|
111
|
+
}
|
|
112
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: CollapseComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
113
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.11", type: CollapseComponent, isStandalone: true, selector: "ng0-collapse", inputs: { collapsed: { classPropertyName: "collapsed", publicName: "collapsed", isSignal: true, isRequired: false, transformFunction: null }, timings: { classPropertyName: "timings", publicName: "timings", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { collapsed: "collapsedChange" }, host: { properties: { "@collapseExpand": "this._collapseExpand" } }, ngImport: i0, template: "<ng-content></ng-content>", styles: [":host{display:block;overflow:hidden}\n"], animations: [
|
|
114
|
+
trigger('collapseExpand', [
|
|
115
|
+
state('collapsed', style({ height: 0, opacity: 0, })),
|
|
116
|
+
state('expanded', style({ height: '*', opacity: '*', })),
|
|
117
|
+
transition('collapsed <=> expanded', [
|
|
118
|
+
animate('{{timings}}')
|
|
119
|
+
])
|
|
120
|
+
])
|
|
121
|
+
], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
122
|
+
}
|
|
123
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: CollapseComponent, decorators: [{
|
|
124
|
+
type: Component,
|
|
125
|
+
args: [{ selector: 'ng0-collapse', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, animations: [
|
|
126
|
+
trigger('collapseExpand', [
|
|
127
|
+
state('collapsed', style({ height: 0, opacity: 0, })),
|
|
128
|
+
state('expanded', style({ height: '*', opacity: '*', })),
|
|
129
|
+
transition('collapsed <=> expanded', [
|
|
130
|
+
animate('{{timings}}')
|
|
131
|
+
])
|
|
132
|
+
])
|
|
133
|
+
], template: "<ng-content></ng-content>", styles: [":host{display:block;overflow:hidden}\n"] }]
|
|
134
|
+
}], propDecorators: { _collapseExpand: [{
|
|
135
|
+
type: HostBinding,
|
|
136
|
+
args: ['@collapseExpand']
|
|
137
|
+
}] } });
|
|
138
|
+
|
|
139
|
+
const items = [
|
|
140
|
+
CollapseDirective,
|
|
141
|
+
CollapseComponent
|
|
142
|
+
];
|
|
143
|
+
class CollapseModule {
|
|
144
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: CollapseModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
145
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.11", ngImport: i0, type: CollapseModule, imports: [CollapseDirective,
|
|
146
|
+
CollapseComponent], exports: [CollapseDirective,
|
|
147
|
+
CollapseComponent] });
|
|
148
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: CollapseModule });
|
|
149
|
+
}
|
|
150
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: CollapseModule, decorators: [{
|
|
151
|
+
type: NgModule,
|
|
152
|
+
args: [{
|
|
153
|
+
imports: items,
|
|
154
|
+
exports: items
|
|
155
|
+
}]
|
|
156
|
+
}] });
|
|
157
|
+
|
|
158
|
+
/**
|
|
159
|
+
* Generated bundle index. Do not edit.
|
|
160
|
+
*/
|
|
161
|
+
|
|
162
|
+
export { CollapseComponent, CollapseDirective, CollapseModule };
|
|
163
|
+
//# sourceMappingURL=bootkit-ng0-collapse.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bootkit-ng0-collapse.mjs","sources":["../../../projects/ng0/collapse/collapse.directive.ts","../../../projects/ng0/collapse/collapse.component.ts","../../../projects/ng0/collapse/collapse.component.html","../../../projects/ng0/collapse/collapse.module.ts","../../../projects/ng0/collapse/bootkit-ng0-collapse.ts"],"sourcesContent":["import { Directive, OnInit, ElementRef, Renderer2, input, effect, OnDestroy } from '@angular/core';\r\nimport { animate, AnimationBuilder, AnimationMetadata, AnimationPlayer, style } from '@angular/animations';\r\n\r\n/** \r\n * Directive to handle the collapse and expand functionality of a host element. \r\n */\r\n@Directive({\r\n selector: '[ng0Collapse]',\r\n exportAs: 'ng0Collapse',\r\n standalone: true,\r\n})\r\nexport class CollapseDirective implements OnInit, OnDestroy {\r\n /**\r\n * Indicates whether the host element is collapsed. \r\n * @input \r\n */\r\n public collapsed = input(false);\r\n\r\n /** Animation timings for collapse/expand animations. \r\n * @input \r\n */\r\n public timings = input<string | number>('0.2s');\r\n\r\n private _player?: AnimationPlayer;\r\n private _firstExecution = true;\r\n\r\n constructor(private el: ElementRef, private builder: AnimationBuilder, private renderer: Renderer2) {\r\n renderer.setStyle(el.nativeElement, 'overflow', 'hidden');\r\n \r\n effect(() => {\r\n var collapsed = this.collapsed();\r\n if (this._firstExecution) {\r\n this._firstExecution = false;\r\n return;\r\n }\r\n\r\n if (collapsed)\r\n this._collapse()\r\n else\r\n this._expand();\r\n });\r\n }\r\n\r\n ngOnInit(): void {\r\n this._addClass('collapse');\r\n if (!this.collapsed()) {\r\n this._addClass('show');\r\n }\r\n }\r\n\r\n private _collapse() {\r\n if (this._player) {\r\n this._player.destroy();\r\n }\r\n\r\n this._playAnimation([\r\n style({ height: '*', opacity: '*' }),\r\n animate(this.timings(), style({ height: 0, opacity: 0 })),\r\n ])\r\n\r\n this._player!.onDone(() => {\r\n if (this.collapsed()) {\r\n this._removeClass('show')\r\n }\r\n });\r\n }\r\n\r\n private _expand() {\r\n if (this._player) {\r\n this._player.destroy();\r\n }\r\n\r\n this._addClass('show')\r\n this._playAnimation([\r\n style({ height: 0, opacity: 0 }),\r\n animate(this.timings(), style({ height: '*', opacity: '*' })),\r\n ]);\r\n\r\n this._player.onDone(() => {\r\n this._player.destroy()\r\n this._player = undefined;\r\n });\r\n }\r\n\r\n private _playAnimation(animation: AnimationMetadata | AnimationMetadata[]) {\r\n this._player = this.builder.build(animation).create(this.el.nativeElement);\r\n this._player.play();\r\n }\r\n\r\n private _addClass = (cls: string) => this.renderer.addClass(this.el.nativeElement, cls);\r\n private _removeClass = (cls: string) => this.renderer.removeClass(this.el.nativeElement, cls);\r\n\r\n ngOnDestroy(): void {\r\n this._player?.destroy();\r\n }\r\n}\r\n","import { ChangeDetectionStrategy, Component, HostBinding, input, model } from '@angular/core';\r\nimport { trigger, state, style, animate, transition } from '@angular/animations';\r\n\r\n/**\r\n * A component that provides collapse and expand functionality. \r\n*/\r\n@Component({\r\n selector: 'ng0-collapse',\r\n templateUrl: './collapse.component.html',\r\n standalone: true,\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n styles: `:host{display :block; overflow: hidden}`,\r\n animations: [\r\n trigger('collapseExpand', [\r\n state('collapsed', style({ height: 0, opacity: 0, })),\r\n state('expanded', style({ height: '*', opacity: '*', })),\r\n transition('collapsed <=> expanded', [\r\n animate('{{timings}}')\r\n ])\r\n ])\r\n ]\r\n})\r\nexport class CollapseComponent {\r\n /**\r\n * Indicates whether the host element is collapsed. \r\n * @model \r\n */\r\n public collapsed = model(false);\r\n\r\n /** Animation timings for collapse/expand animations. \r\n * @input \r\n */\r\n public timings = input<string | number>('0.2s');\r\n\r\n @HostBinding('@collapseExpand')\r\n private get _collapseExpand() {\r\n return { value: this.collapsed() ? 'collapsed' : 'expanded', params: { timings: this.timings() } };\r\n }\r\n}\r\n","<ng-content></ng-content>","import { NgModule } from '@angular/core';\r\nimport { CollapseDirective } from './collapse.directive';\r\nimport { CollapseComponent } from './collapse.component';\r\n\r\nconst items = [\r\n CollapseDirective,\r\n CollapseComponent\r\n];\r\n\r\n@NgModule({\r\n imports: items,\r\n exports: items\r\n})\r\nexport class CollapseModule {\r\n}\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { InjectionToken } from '@angular/core';
|
|
2
|
+
|
|
3
|
+
const RTL = new InjectionToken('RTL Direction');
|
|
4
|
+
|
|
5
|
+
function flipPlacement(placement) {
|
|
6
|
+
switch (placement) {
|
|
7
|
+
case 'bottom':
|
|
8
|
+
return 'top';
|
|
9
|
+
case 'top':
|
|
10
|
+
return 'bottom';
|
|
11
|
+
case 'start':
|
|
12
|
+
return 'end';
|
|
13
|
+
case 'end':
|
|
14
|
+
return 'start';
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
function numberRange(start, end) {
|
|
18
|
+
return Array.from({ length: end - start + 1 }, (_, i) => i + start);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* Generated bundle index. Do not edit.
|
|
23
|
+
*/
|
|
24
|
+
|
|
25
|
+
export { RTL, flipPlacement, numberRange };
|
|
26
|
+
//# sourceMappingURL=bootkit-ng0-common.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bootkit-ng0-common.mjs","sources":["../../../projects/ng0/common/types.ts","../../../projects/ng0/common/utils.ts","../../../projects/ng0/common/bootkit-ng0-common.ts"],"sourcesContent":["import { InjectionToken } from \"@angular/core\";\r\n\r\nexport type Placement = 'start' | 'end' | 'top' | 'bottom';\r\nexport type Alignment = 'start' | 'center' | 'end';\r\nexport const RTL = new InjectionToken<boolean>('RTL Direction');","import { Placement } from \"./types\";\r\n \r\nexport function flipPlacement(placement: Placement) {\r\n switch (placement) {\r\n case 'bottom':\r\n return 'top'\r\n case 'top':\r\n return 'bottom'\r\n case 'start':\r\n return 'end'\r\n case 'end':\r\n return 'start'\r\n }\r\n }\r\n\r\n export function numberRange(start: number, end: number) {\r\n return Array.from({ length: end - start + 1 }, (_, i) => i + start)\r\n }","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":";;MAIa,GAAG,GAAG,IAAI,cAAc,CAAU,eAAe;;ACFxD,SAAU,aAAa,CAAC,SAAoB,EAAA;IAC5C,QAAQ,SAAS;AACb,QAAA,KAAK,QAAQ;AACT,YAAA,OAAO,KAAK,CAAA;AAChB,QAAA,KAAK,KAAK;AACN,YAAA,OAAO,QAAQ,CAAA;AACnB,QAAA,KAAK,OAAO;AACR,YAAA,OAAO,KAAK,CAAA;AAChB,QAAA,KAAK,KAAK;AACN,YAAA,OAAO,OAAO,CAAA;KACrB;AACL,CAAC;AAEe,SAAA,WAAW,CAAC,KAAa,EAAE,GAAW,EAAA;IACpD,OAAO,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,GAAG,GAAG,KAAK,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC,CAAA;AACrE;;ACjBF;;AAEG;;;;"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { input, EventEmitter, signal, Component, ChangeDetectionStrategy, Output, HostListener, NgModule } from '@angular/core';
|
|
3
|
+
import { CommonModule } from '@angular/common';
|
|
4
|
+
|
|
5
|
+
class ModalComponent {
|
|
6
|
+
scrollable = input(false);
|
|
7
|
+
/** Is modal vertically centered? */
|
|
8
|
+
centered = input(false);
|
|
9
|
+
size = input('default');
|
|
10
|
+
fullscreen = input();
|
|
11
|
+
closeRequest = new EventEmitter();
|
|
12
|
+
backdropClick = new EventEmitter();
|
|
13
|
+
_modalStatic = signal(false);
|
|
14
|
+
constructor() {
|
|
15
|
+
}
|
|
16
|
+
_onBackdropClick() {
|
|
17
|
+
this.backdropClick.emit();
|
|
18
|
+
this._modalStatic.set(true);
|
|
19
|
+
var timeout = setTimeout(() => {
|
|
20
|
+
this._modalStatic.set(false);
|
|
21
|
+
clearTimeout(timeout);
|
|
22
|
+
}, 100);
|
|
23
|
+
}
|
|
24
|
+
onKeyDown(event) {
|
|
25
|
+
if (event.key === 'Escape') {
|
|
26
|
+
this.closeRequest.emit();
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: ModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
30
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.11", type: ModalComponent, isStandalone: true, selector: "ng0-modal", inputs: { scrollable: { classPropertyName: "scrollable", publicName: "scrollable", isSignal: true, isRequired: false, transformFunction: null }, centered: { classPropertyName: "centered", publicName: "centered", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, fullscreen: { classPropertyName: "fullscreen", publicName: "fullscreen", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { closeRequest: "closeRequest", backdropClick: "backdropClick" }, host: { listeners: { "document:keydown": "onKeyDown($event)" } }, exportAs: ["ng0Modal"], ngImport: i0, template: "@let fullscreenValue=fullscreen();\r\n@let sizeValue=size();\r\n\r\n<div class=\"modal d-block\"\r\n (click)=\"$event.target == $event.currentTarget ? _onBackdropClick(): ''\"\r\n [class.modal-static]=\"_modalStatic()\">\r\n\r\n <div class=\"modal-dialog\"\r\n [class]=\"{\r\n 'modal-dialog-scrollable': scrollable(),\r\n 'modal-dialog-centered': centered(),\r\n 'modal-fullscreen': fullscreenValue == 'always',\r\n 'modal-fullscreen-sm-down': fullscreenValue == 'sm',\r\n 'modal-fullscreen-md-down': fullscreenValue == 'md',\r\n 'modal-fullscreen-lg-down': fullscreenValue == 'lg',\r\n 'modal-fullscreen-xl-down': fullscreenValue == 'xl',\r\n 'modal-fullscreen-xxl-down': fullscreenValue == 'xxl',\r\n 'modal-sm': sizeValue == 'sm',\r\n 'modal-lg': sizeValue == 'lg',\r\n 'modal-xl': sizeValue == 'xl',\r\n }\">\r\n <div class=\"modal-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n </div>\r\n</div>\r\n<div class=\"modal-backdrop fade show\"></div>", dependencies: [{ kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
31
|
+
}
|
|
32
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: ModalComponent, decorators: [{
|
|
33
|
+
type: Component,
|
|
34
|
+
args: [{ selector: 'ng0-modal', exportAs: 'ng0Modal', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
|
|
35
|
+
CommonModule,
|
|
36
|
+
], template: "@let fullscreenValue=fullscreen();\r\n@let sizeValue=size();\r\n\r\n<div class=\"modal d-block\"\r\n (click)=\"$event.target == $event.currentTarget ? _onBackdropClick(): ''\"\r\n [class.modal-static]=\"_modalStatic()\">\r\n\r\n <div class=\"modal-dialog\"\r\n [class]=\"{\r\n 'modal-dialog-scrollable': scrollable(),\r\n 'modal-dialog-centered': centered(),\r\n 'modal-fullscreen': fullscreenValue == 'always',\r\n 'modal-fullscreen-sm-down': fullscreenValue == 'sm',\r\n 'modal-fullscreen-md-down': fullscreenValue == 'md',\r\n 'modal-fullscreen-lg-down': fullscreenValue == 'lg',\r\n 'modal-fullscreen-xl-down': fullscreenValue == 'xl',\r\n 'modal-fullscreen-xxl-down': fullscreenValue == 'xxl',\r\n 'modal-sm': sizeValue == 'sm',\r\n 'modal-lg': sizeValue == 'lg',\r\n 'modal-xl': sizeValue == 'xl',\r\n }\">\r\n <div class=\"modal-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n </div>\r\n</div>\r\n<div class=\"modal-backdrop fade show\"></div>" }]
|
|
37
|
+
}], ctorParameters: () => [], propDecorators: { closeRequest: [{
|
|
38
|
+
type: Output
|
|
39
|
+
}], backdropClick: [{
|
|
40
|
+
type: Output
|
|
41
|
+
}], onKeyDown: [{
|
|
42
|
+
type: HostListener,
|
|
43
|
+
args: ['document:keydown', ['$event']]
|
|
44
|
+
}] } });
|
|
45
|
+
|
|
46
|
+
class ModalModule {
|
|
47
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: ModalModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
48
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.11", ngImport: i0, type: ModalModule, imports: [ModalComponent], exports: [ModalComponent] });
|
|
49
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: ModalModule, imports: [ModalComponent] });
|
|
50
|
+
}
|
|
51
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: ModalModule, decorators: [{
|
|
52
|
+
type: NgModule,
|
|
53
|
+
args: [{
|
|
54
|
+
imports: [
|
|
55
|
+
ModalComponent,
|
|
56
|
+
],
|
|
57
|
+
exports: [
|
|
58
|
+
ModalComponent,
|
|
59
|
+
]
|
|
60
|
+
}]
|
|
61
|
+
}] });
|
|
62
|
+
|
|
63
|
+
/**
|
|
64
|
+
* Generated bundle index. Do not edit.
|
|
65
|
+
*/
|
|
66
|
+
|
|
67
|
+
export { ModalComponent, ModalModule };
|
|
68
|
+
//# sourceMappingURL=bootkit-ng0-modal.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bootkit-ng0-modal.mjs","sources":["../../../projects/ng0/modal/modal.component.ts","../../../projects/ng0/modal/modal.component.html","../../../projects/ng0/modal/modal.module.ts","../../../projects/ng0/modal/bootkit-ng0-modal.ts"],"sourcesContent":["import { Component, Output, EventEmitter, ChangeDetectionStrategy, input, signal, HostListener } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ModalCloseRequest } from './types';\r\n\r\n@Component({\r\n selector: 'ng0-modal',\r\n exportAs: 'ng0Modal',\r\n templateUrl: 'modal.component.html',\r\n standalone: true,\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n imports: [\r\n CommonModule,\r\n ]\r\n})\r\nexport class ModalComponent {\r\n public scrollable = input<boolean>(false);\r\n\r\n /** Is modal vertically centered? */\r\n public centered = input<boolean>(false);\r\n public size = input<'sm' | 'default' | 'lg' | 'xl'>('default');\r\n public fullscreen = input<'always' | 'sm' | 'md' | 'lg' | 'xl' | 'xxl'>();\r\n @Output() public closeRequest = new EventEmitter<ModalCloseRequest>();\r\n @Output() public backdropClick = new EventEmitter();\r\n\r\n protected _modalStatic = signal(false);\r\n\r\n constructor() {\r\n }\r\n\r\n protected _onBackdropClick() {\r\n this.backdropClick.emit();\r\n this._modalStatic.set(true)\r\n var timeout = setTimeout(() => {\r\n this._modalStatic.set(false)\r\n clearTimeout(timeout);\r\n }, 100);\r\n }\r\n\r\n @HostListener('document:keydown', ['$event'])\r\n onKeyDown(event: KeyboardEvent) {\r\n if (event.key === 'Escape') {\r\n this.closeRequest.emit();\r\n }\r\n }\r\n}\r\n","@let fullscreenValue=fullscreen();\r\n@let sizeValue=size();\r\n\r\n<div class=\"modal d-block\"\r\n (click)=\"$event.target == $event.currentTarget ? _onBackdropClick(): ''\"\r\n [class.modal-static]=\"_modalStatic()\">\r\n\r\n <div class=\"modal-dialog\"\r\n [class]=\"{\r\n 'modal-dialog-scrollable': scrollable(),\r\n 'modal-dialog-centered': centered(),\r\n 'modal-fullscreen': fullscreenValue == 'always',\r\n 'modal-fullscreen-sm-down': fullscreenValue == 'sm',\r\n 'modal-fullscreen-md-down': fullscreenValue == 'md',\r\n 'modal-fullscreen-lg-down': fullscreenValue == 'lg',\r\n 'modal-fullscreen-xl-down': fullscreenValue == 'xl',\r\n 'modal-fullscreen-xxl-down': fullscreenValue == 'xxl',\r\n 'modal-sm': sizeValue == 'sm',\r\n 'modal-lg': sizeValue == 'lg',\r\n 'modal-xl': sizeValue == 'xl',\r\n }\">\r\n <div class=\"modal-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n </div>\r\n</div>\r\n<div class=\"modal-backdrop fade show\"></div>","import { NgModule } from '@angular/core';\r\nimport { ModalComponent } from './modal.component';\r\n\r\n@NgModule({\r\n imports: [\r\n ModalComponent,\r\n ],\r\n exports: [\r\n ModalComponent,\r\n ]\r\n})\r\nexport class ModalModule {\r\n}\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
|