@ngutil/layout 0.0.81 → 0.0.82

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.
@@ -1,11 +0,0 @@
1
- import { Component } from "@angular/core";
2
- import * as i0 from "@angular/core";
3
- export class SlidingItemComponent {
4
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: SlidingItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
5
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.6", type: SlidingItemComponent, isStandalone: true, selector: "nu-sliding-item", ngImport: i0, template: `<ng-content />`, isInline: true, styles: [":host{grid-column:1;grid-row:1;display:flex;flex-direction:column;align-items:stretch;position:relative;overflow:hidden}\n"] }); }
6
- }
7
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: SlidingItemComponent, decorators: [{
8
- type: Component,
9
- args: [{ selector: "nu-sliding-item", standalone: true, template: `<ng-content />`, styles: [":host{grid-column:1;grid-row:1;display:flex;flex-direction:column;align-items:stretch;position:relative;overflow:hidden}\n"] }]
10
- }] });
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGluZy1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xheW91dC9zcmMvc2xpZGluZy9zbGlkaW5nLWl0ZW0uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUE7O0FBaUJ6QyxNQUFNLE9BQU8sb0JBQW9COzhHQUFwQixvQkFBb0I7a0dBQXBCLG9CQUFvQiwyRUFGbkIsZ0JBQWdCOzsyRkFFakIsb0JBQW9CO2tCQU5oQyxTQUFTOytCQUNJLGlCQUFpQixjQUNmLElBQUksWUFFTixnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiXG5cbmV4cG9ydCBjb25zdCBlbnVtIEl0ZW1BbmltYXRpb25TdGF0ZSB7XG4gICAgTGVmdEluID0gXCJsZWZ0LWluXCIsXG4gICAgTGVmdE91dCA9IFwibGVmdC1vdXRcIixcbiAgICBSaWdodEluID0gXCJyaWdodC1pblwiLFxuICAgIFJpZ2h0T3V0ID0gXCJyaWdodC1vdXRcIixcbiAgICBGYXN0T3V0ID0gXCJmYXN0LW91dFwiLFxuICAgIEZhc3RJbiA9IFwiZmFzdC1pblwiXG59XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiBcIm51LXNsaWRpbmctaXRlbVwiLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgc3R5bGVVcmw6IFwiLi9zbGlkaW5nLWl0ZW0uY29tcG9uZW50LnNjc3NcIixcbiAgICB0ZW1wbGF0ZTogYDxuZy1jb250ZW50IC8+YFxufSlcbmV4cG9ydCBjbGFzcyBTbGlkaW5nSXRlbUNvbXBvbmVudCB7fVxuIl19
@@ -1,25 +0,0 @@
1
- import { Directive, effect, inject, output, signal, TemplateRef } from "@angular/core";
2
- import * as i0 from "@angular/core";
3
- export class SlidingItemDirective {
4
- constructor() {
5
- this.tpl = inject(TemplateRef);
6
- this.rendered = signal(false);
7
- this.active = signal(false);
8
- this.animation = signal(null);
9
- this.activated = output();
10
- effect(() => {
11
- this.activated.emit(this.active());
12
- }, { allowSignalWrites: true });
13
- }
14
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: SlidingItemDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
15
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.6", type: SlidingItemDirective, isStandalone: true, selector: "ng-template[nuSlidingItem]", outputs: { activated: "activated" }, exportAs: ["nuSlidingItem"], ngImport: i0 }); }
16
- }
17
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: SlidingItemDirective, decorators: [{
18
- type: Directive,
19
- args: [{
20
- selector: "ng-template[nuSlidingItem]",
21
- exportAs: "nuSlidingItem",
22
- standalone: true
23
- }]
24
- }], ctorParameters: () => [] });
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGluZy1pdGVtLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xheW91dC9zcmMvc2xpZGluZy9zbGlkaW5nLWl0ZW0uZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQTs7QUFTdEYsTUFBTSxPQUFPLG9CQUFvQjtJQVE3QjtRQVBTLFFBQUcsR0FBRyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUE7UUFFekIsYUFBUSxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQTtRQUN4QixXQUFNLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFBO1FBQ3RCLGNBQVMsR0FBRyxNQUFNLENBQTRCLElBQUksQ0FBQyxDQUFBO1FBQ25ELGNBQVMsR0FBRyxNQUFNLEVBQVcsQ0FBQTtRQUdsQyxNQUFNLENBQ0YsR0FBRyxFQUFFO1lBQ0QsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUE7UUFDdEMsQ0FBQyxFQUNELEVBQUUsaUJBQWlCLEVBQUUsSUFBSSxFQUFFLENBQzlCLENBQUE7SUFDTCxDQUFDOzhHQWZRLG9CQUFvQjtrR0FBcEIsb0JBQW9COzsyRkFBcEIsb0JBQW9CO2tCQUxoQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSw0QkFBNEI7b0JBQ3RDLFFBQVEsRUFBRSxlQUFlO29CQUN6QixVQUFVLEVBQUUsSUFBSTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIGVmZmVjdCwgaW5qZWN0LCBvdXRwdXQsIHNpZ25hbCwgVGVtcGxhdGVSZWYgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiXG5cbmltcG9ydCB0eXBlIHsgSXRlbUFuaW1hdGlvblN0YXRlIH0gZnJvbSBcIi4vc2xpZGluZy1pdGVtLmNvbXBvbmVudFwiXG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiBcIm5nLXRlbXBsYXRlW251U2xpZGluZ0l0ZW1dXCIsXG4gICAgZXhwb3J0QXM6IFwibnVTbGlkaW5nSXRlbVwiLFxuICAgIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgU2xpZGluZ0l0ZW1EaXJlY3RpdmUge1xuICAgIHJlYWRvbmx5IHRwbCA9IGluamVjdChUZW1wbGF0ZVJlZilcblxuICAgIHJlYWRvbmx5IHJlbmRlcmVkID0gc2lnbmFsKGZhbHNlKVxuICAgIHJlYWRvbmx5IGFjdGl2ZSA9IHNpZ25hbChmYWxzZSlcbiAgICByZWFkb25seSBhbmltYXRpb24gPSBzaWduYWw8SXRlbUFuaW1hdGlvblN0YXRlIHwgbnVsbD4obnVsbClcbiAgICByZWFkb25seSBhY3RpdmF0ZWQgPSBvdXRwdXQ8Ym9vbGVhbj4oKVxuXG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIGVmZmVjdChcbiAgICAgICAgICAgICgpID0+IHtcbiAgICAgICAgICAgICAgICB0aGlzLmFjdGl2YXRlZC5lbWl0KHRoaXMuYWN0aXZlKCkpXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgeyBhbGxvd1NpZ25hbFdyaXRlczogdHJ1ZSB9XG4gICAgICAgIClcbiAgICB9XG59XG4iXX0=
@@ -1,183 +0,0 @@
1
- import { animate, state, style, transition, trigger } from "@angular/animations";
2
- import { CommonModule } from "@angular/common";
3
- import { Component, computed, contentChildren, effect, input, output, signal } from "@angular/core";
4
- import { clamp } from "lodash-es";
5
- import { Duration, Ease } from "@ngutil/style";
6
- import { SlidingItemComponent } from "./sliding-item.component";
7
- import { SlidingItemDirective } from "./sliding-item.directive";
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "@angular/common";
10
- const absolute = { position: "absolute", top: "0px", left: "0px" };
11
- const anim = `${Duration.Fast} ${Ease.Acceleration}`;
12
- export class SlidingComponent {
13
- constructor() {
14
- /**
15
- * List of items
16
- */
17
- this.items = contentChildren(SlidingItemDirective);
18
- /**
19
- * Lazily rendering items
20
- */
21
- this.lazy = input(true);
22
- /**
23
- * Index of the preferred item
24
- */
25
- this.preferred = signal(0);
26
- /**
27
- * Index of the active item
28
- */
29
- this.active = computed(() => {
30
- const items = this.items();
31
- if (items.length === 0) {
32
- return -1;
33
- }
34
- const index = this.preferred();
35
- return clamp(index, 0, items.length - 1);
36
- });
37
- /**
38
- * Changes of the active item
39
- */
40
- this.changes = output();
41
- effect(() => {
42
- const activeIndex = this.active();
43
- const items = this.items();
44
- const lazy = this.lazy();
45
- const preferred = this.preferred();
46
- const currentActiveIndex = items.findIndex(item => item.active());
47
- if (activeIndex === currentActiveIndex) {
48
- if (items[activeIndex]?.active()) {
49
- return;
50
- }
51
- }
52
- let activeItem;
53
- let inAnimation = null;
54
- for (let i = 0; i < items.length; i++) {
55
- const item = items[i];
56
- const isActive = i === activeIndex;
57
- if (isActive) {
58
- activeItem = item;
59
- }
60
- else {
61
- const currentlyActive = item.active();
62
- item.active.set(false);
63
- if (lazy === false && !item.rendered()) {
64
- item.rendered.set(true);
65
- }
66
- if (item.animation() || item.rendered()) {
67
- if (currentlyActive) {
68
- if (activeIndex < currentActiveIndex) {
69
- item.animation.set("right-out" /* ItemAnimationState.RightOut */);
70
- inAnimation = "left-in" /* ItemAnimationState.LeftIn */;
71
- }
72
- else {
73
- item.animation.set("left-out" /* ItemAnimationState.LeftOut */);
74
- inAnimation = "right-in" /* ItemAnimationState.RightIn */;
75
- }
76
- }
77
- else {
78
- item.animation.set("fast-out" /* ItemAnimationState.FastOut */);
79
- }
80
- }
81
- }
82
- }
83
- if (activeItem) {
84
- if (inAnimation) {
85
- activeItem.animation.set(inAnimation);
86
- }
87
- else if (items.length === 1) {
88
- activeItem.animation.set("fast-in" /* ItemAnimationState.FastIn */);
89
- }
90
- else if (activeIndex < currentActiveIndex) {
91
- activeItem.animation.set("left-in" /* ItemAnimationState.LeftIn */);
92
- }
93
- else {
94
- activeItem.animation.set("right-in" /* ItemAnimationState.RightIn */);
95
- }
96
- activeItem.active.set(true);
97
- activeItem.rendered.set(true);
98
- }
99
- const preferredClamp = clamp(preferred, 0, items.length - 1);
100
- if (preferred !== preferredClamp) {
101
- this.preferred.set(preferredClamp);
102
- }
103
- this.changes.emit(this);
104
- }, { allowSignalWrites: true });
105
- }
106
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: SlidingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
107
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.6", type: SlidingComponent, isStandalone: true, selector: "nu-sliding", inputs: { lazy: { classPropertyName: "lazy", publicName: "lazy", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { changes: "changes" }, queries: [{ propertyName: "items", predicate: SlidingItemDirective, isSignal: true }], ngImport: i0, template: `
108
- @if (items(); as _items) {
109
- @for (item of _items; track item; let index = $index) {
110
- @if (item.rendered()) {
111
- <nu-sliding-item [@animate]="item.animation()">
112
- <ng-template [ngTemplateOutlet]="item.tpl" />
113
- </nu-sliding-item>
114
- }
115
- }
116
- }
117
- `, isInline: true, styles: [":host{display:grid;grid-template-columns:1fr;grid-template-rows:1fr;overflow:hidden;position:relative}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: SlidingItemComponent, selector: "nu-sliding-item" }], animations: [
118
- trigger("animate", [
119
- state("fast-out" /* ItemAnimationState.FastOut */, style({ display: "none", ...absolute, transform: "translateX(-100%)" })),
120
- state("left-out" /* ItemAnimationState.LeftOut */, style({ display: "none", ...absolute, transform: "translateX(-100%)" })),
121
- state("right-out" /* ItemAnimationState.RightOut */, style({ display: "none", ...absolute, transform: "translateX(100%)" })),
122
- state("fast-in" /* ItemAnimationState.FastIn */, style({ display: "", position: "relative", transform: "translateX(0)" })),
123
- state("left-in" /* ItemAnimationState.LeftIn */, style({ display: "", position: "relative", transform: "translateX(0)" })),
124
- state("right-in" /* ItemAnimationState.RightIn */, style({ display: "", position: "relative", transform: "translateX(0)" })),
125
- transition(`* => ${"left-out" /* ItemAnimationState.LeftOut */}`, [
126
- style({ width: "*", ...absolute, transform: "translateX(0)" }),
127
- animate(anim, style({ transform: "translateX(-100%)" }))
128
- ]),
129
- transition(`* => ${"right-out" /* ItemAnimationState.RightOut */}`, [
130
- style({ width: "*", ...absolute, transform: "translateX(0)" }),
131
- animate(anim, style({ transform: "translateX(100%)" }))
132
- ]),
133
- transition(`* => ${"left-in" /* ItemAnimationState.LeftIn */}`, [
134
- style({ display: "", position: "relative", transform: "translateX(-100%)" }),
135
- animate(anim, style({ transform: "translateX(0)" }))
136
- ]),
137
- transition(`* => ${"right-in" /* ItemAnimationState.RightIn */}`, [
138
- style({ display: "", position: "relative", transform: "translateX(100%)" }),
139
- animate(anim, style({ transform: "translateX(0%)" }))
140
- ])
141
- ])
142
- ] }); }
143
- }
144
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: SlidingComponent, decorators: [{
145
- type: Component,
146
- args: [{ selector: "nu-sliding", standalone: true, imports: [CommonModule, SlidingItemComponent], animations: [
147
- trigger("animate", [
148
- state("fast-out" /* ItemAnimationState.FastOut */, style({ display: "none", ...absolute, transform: "translateX(-100%)" })),
149
- state("left-out" /* ItemAnimationState.LeftOut */, style({ display: "none", ...absolute, transform: "translateX(-100%)" })),
150
- state("right-out" /* ItemAnimationState.RightOut */, style({ display: "none", ...absolute, transform: "translateX(100%)" })),
151
- state("fast-in" /* ItemAnimationState.FastIn */, style({ display: "", position: "relative", transform: "translateX(0)" })),
152
- state("left-in" /* ItemAnimationState.LeftIn */, style({ display: "", position: "relative", transform: "translateX(0)" })),
153
- state("right-in" /* ItemAnimationState.RightIn */, style({ display: "", position: "relative", transform: "translateX(0)" })),
154
- transition(`* => ${"left-out" /* ItemAnimationState.LeftOut */}`, [
155
- style({ width: "*", ...absolute, transform: "translateX(0)" }),
156
- animate(anim, style({ transform: "translateX(-100%)" }))
157
- ]),
158
- transition(`* => ${"right-out" /* ItemAnimationState.RightOut */}`, [
159
- style({ width: "*", ...absolute, transform: "translateX(0)" }),
160
- animate(anim, style({ transform: "translateX(100%)" }))
161
- ]),
162
- transition(`* => ${"left-in" /* ItemAnimationState.LeftIn */}`, [
163
- style({ display: "", position: "relative", transform: "translateX(-100%)" }),
164
- animate(anim, style({ transform: "translateX(0)" }))
165
- ]),
166
- transition(`* => ${"right-in" /* ItemAnimationState.RightIn */}`, [
167
- style({ display: "", position: "relative", transform: "translateX(100%)" }),
168
- animate(anim, style({ transform: "translateX(0%)" }))
169
- ])
170
- ])
171
- ], template: `
172
- @if (items(); as _items) {
173
- @for (item of _items; track item; let index = $index) {
174
- @if (item.rendered()) {
175
- <nu-sliding-item [@animate]="item.animation()">
176
- <ng-template [ngTemplateOutlet]="item.tpl" />
177
- </nu-sliding-item>
178
- }
179
- }
180
- }
181
- `, styles: [":host{display:grid;grid-template-columns:1fr;grid-template-rows:1fr;overflow:hidden;position:relative}\n"] }]
182
- }], ctorParameters: () => [] });
183
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sliding.component.js","sourceRoot":"","sources":["../../../../../packages/layout/src/sliding/sliding.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, state, style, transition, trigger } from \"@angular/animations\"\nimport { CommonModule } from \"@angular/common\"\nimport { Component, computed, contentChildren, effect, input, output, signal } from \"@angular/core\"\n\nimport { clamp } from \"lodash-es\"\n\nimport { Duration, Ease } from \"@ngutil/style\"\n\nimport { ItemAnimationState, SlidingItemComponent } from \"./sliding-item.component\"\nimport { SlidingItemDirective } from \"./sliding-item.directive\"\n\nconst absolute = { position: \"absolute\", top: \"0px\", left: \"0px\" }\n\nconst anim = `${Duration.Fast} ${Ease.Acceleration}`\n\n@Component({\n    selector: \"nu-sliding\",\n    standalone: true,\n    imports: [CommonModule, SlidingItemComponent],\n    styleUrl: \"./sliding.component.scss\",\n    animations: [\n        trigger(\"animate\", [\n            state(ItemAnimationState.FastOut, style({ display: \"none\", ...absolute, transform: \"translateX(-100%)\" })),\n            state(ItemAnimationState.LeftOut, style({ display: \"none\", ...absolute, transform: \"translateX(-100%)\" })),\n            state(ItemAnimationState.RightOut, style({ display: \"none\", ...absolute, transform: \"translateX(100%)\" })),\n            state(ItemAnimationState.FastIn, style({ display: \"\", position: \"relative\", transform: \"translateX(0)\" })),\n            state(ItemAnimationState.LeftIn, style({ display: \"\", position: \"relative\", transform: \"translateX(0)\" })),\n            state(ItemAnimationState.RightIn, style({ display: \"\", position: \"relative\", transform: \"translateX(0)\" })),\n\n            transition(`* => ${ItemAnimationState.LeftOut}`, [\n                style({ width: \"*\", ...absolute, transform: \"translateX(0)\" }),\n                animate(anim, style({ transform: \"translateX(-100%)\" }))\n            ]),\n            transition(`* => ${ItemAnimationState.RightOut}`, [\n                style({ width: \"*\", ...absolute, transform: \"translateX(0)\" }),\n                animate(anim, style({ transform: \"translateX(100%)\" }))\n            ]),\n            transition(`* => ${ItemAnimationState.LeftIn}`, [\n                style({ display: \"\", position: \"relative\", transform: \"translateX(-100%)\" }),\n                animate(anim, style({ transform: \"translateX(0)\" }))\n            ]),\n            transition(`* => ${ItemAnimationState.RightIn}`, [\n                style({ display: \"\", position: \"relative\", transform: \"translateX(100%)\" }),\n                animate(anim, style({ transform: \"translateX(0%)\" }))\n            ])\n        ])\n    ],\n    template: `\n        @if (items(); as _items) {\n            @for (item of _items; track item; let index = $index) {\n                @if (item.rendered()) {\n                    <nu-sliding-item [@animate]=\"item.animation()\">\n                        <ng-template [ngTemplateOutlet]=\"item.tpl\" />\n                    </nu-sliding-item>\n                }\n            }\n        }\n    `\n})\nexport class SlidingComponent {\n    /**\n     * List of items\n     */\n    readonly items = contentChildren(SlidingItemDirective)\n\n    /**\n     * Lazily rendering items\n     */\n    readonly lazy = input(true)\n\n    /**\n     * Index of the preferred item\n     */\n    readonly preferred = signal(0)\n\n    /**\n     * Index of the active item\n     */\n    readonly active = computed(() => {\n        const items = this.items()\n        if (items.length === 0) {\n            return -1\n        }\n        const index = this.preferred()\n        return clamp(index, 0, items.length - 1)\n    })\n\n    /**\n     * Changes of the active item\n     */\n    readonly changes = output<SlidingComponent>()\n\n    constructor() {\n        effect(\n            () => {\n                const activeIndex = this.active()\n                const items = this.items()\n                const lazy = this.lazy()\n                const preferred = this.preferred()\n                const currentActiveIndex = items.findIndex(item => item.active())\n                if (activeIndex === currentActiveIndex) {\n                    if (items[activeIndex]?.active()) {\n                        return\n                    }\n                }\n\n                let activeItem: SlidingItemDirective | undefined\n                let inAnimation: ItemAnimationState | null = null\n\n                for (let i = 0; i < items.length; i++) {\n                    const item = items[i]\n                    const isActive = i === activeIndex\n\n                    if (isActive) {\n                        activeItem = item\n                    } else {\n                        const currentlyActive = item.active()\n                        item.active.set(false)\n\n                        if (lazy === false && !item.rendered()) {\n                            item.rendered.set(true)\n                        }\n\n                        if (item.animation() || item.rendered()) {\n                            if (currentlyActive) {\n                                if (activeIndex < currentActiveIndex) {\n                                    item.animation.set(ItemAnimationState.RightOut)\n                                    inAnimation = ItemAnimationState.LeftIn\n                                } else {\n                                    item.animation.set(ItemAnimationState.LeftOut)\n                                    inAnimation = ItemAnimationState.RightIn\n                                }\n                            } else {\n                                item.animation.set(ItemAnimationState.FastOut)\n                            }\n                        }\n                    }\n                }\n\n                if (activeItem) {\n                    if (inAnimation) {\n                        activeItem.animation.set(inAnimation)\n                    } else if (items.length === 1) {\n                        activeItem.animation.set(ItemAnimationState.FastIn)\n                    } else if (activeIndex < currentActiveIndex) {\n                        activeItem.animation.set(ItemAnimationState.LeftIn)\n                    } else {\n                        activeItem.animation.set(ItemAnimationState.RightIn)\n                    }\n                    activeItem.active.set(true)\n                    activeItem.rendered.set(true)\n                }\n\n                const preferredClamp = clamp(preferred, 0, items.length - 1)\n                if (preferred !== preferredClamp) {\n                    this.preferred.set(preferredClamp)\n                }\n\n                this.changes.emit(this)\n            },\n            { allowSignalWrites: true }\n        )\n    }\n}\n"]}
@@ -1,13 +0,0 @@
1
- import * as i0 from "@angular/core";
2
- export declare const enum ItemAnimationState {
3
- LeftIn = "left-in",
4
- LeftOut = "left-out",
5
- RightIn = "right-in",
6
- RightOut = "right-out",
7
- FastOut = "fast-out",
8
- FastIn = "fast-in"
9
- }
10
- export declare class SlidingItemComponent {
11
- static ɵfac: i0.ɵɵFactoryDeclaration<SlidingItemComponent, never>;
12
- static ɵcmp: i0.ɵɵComponentDeclaration<SlidingItemComponent, "nu-sliding-item", never, {}, {}, never, ["*"], true, never>;
13
- }
@@ -1,13 +0,0 @@
1
- import { TemplateRef } from "@angular/core";
2
- import type { ItemAnimationState } from "./sliding-item.component";
3
- import * as i0 from "@angular/core";
4
- export declare class SlidingItemDirective {
5
- readonly tpl: TemplateRef<any>;
6
- readonly rendered: import("@angular/core").WritableSignal<boolean>;
7
- readonly active: import("@angular/core").WritableSignal<boolean>;
8
- readonly animation: import("@angular/core").WritableSignal<ItemAnimationState | null>;
9
- readonly activated: import("@angular/core").OutputEmitterRef<boolean>;
10
- constructor();
11
- static ɵfac: i0.ɵɵFactoryDeclaration<SlidingItemDirective, never>;
12
- static ɵdir: i0.ɵɵDirectiveDeclaration<SlidingItemDirective, "ng-template[nuSlidingItem]", ["nuSlidingItem"], {}, { "activated": "activated"; }, never, never, true, never>;
13
- }