ngx-easy-view-transitions 3.1.0 → 3.1.2
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 +5 -9
- package/fesm2022/ngx-easy-view-transitions.mjs +47 -25
- package/fesm2022/ngx-easy-view-transitions.mjs.map +1 -1
- package/package.json +3 -3
- package/types/ngx-easy-view-transitions.d.ts +218 -0
- package/index.d.ts +0 -6
- package/lib/css-keyframes-transition.d.ts +0 -17
- package/lib/default-transitions.d.ts +0 -42
- package/lib/default-view-transition.provider.d.ts +0 -9
- package/lib/keyframes-transition.d.ts +0 -17
- package/lib/keyframes.service.d.ts +0 -1
- package/lib/no-transition.directive.d.ts +0 -14
- package/lib/transition-name.directive.d.ts +0 -26
- package/lib/utils.d.ts +0 -1
- package/lib/view-transitions.service.d.ts +0 -1
package/README.md
CHANGED
|
@@ -18,11 +18,7 @@ Available on [npm](https://www.npmjs.org/package/ngx-easy-view-transitions/).
|
|
|
18
18
|
npm install ngx-easy-view-transitions
|
|
19
19
|
```
|
|
20
20
|
|
|
21
|
-
|
|
22
|
-
|-----------------|-----------------|
|
|
23
|
-
| `3.x.x` | `>=19.0.0` |
|
|
24
|
-
| `2.x.x` | `>=18.0.0` |
|
|
25
|
-
| `1.x.x` | `^17.3.0` |
|
|
21
|
+
Required Angular version: `>=19.0.0`
|
|
26
22
|
|
|
27
23
|
You have to enable Angulars built-in view transitions in the Router using the [`withViewTransitions()`](https://angular.io/api/router/withViewTransitions#usage-notes) function.
|
|
28
24
|
|
|
@@ -130,7 +126,7 @@ You can see them in the [demo](https://derstimmler.github.io/ngx-easy-view-trans
|
|
|
130
126
|
|
|
131
127
|
### Exclude element from view transitions
|
|
132
128
|
|
|
133
|
-
When you want to exclude an element
|
|
129
|
+
When you want to exclude an element from view transitions, you can add the `noTransition` directive.
|
|
134
130
|
|
|
135
131
|
```typescript
|
|
136
132
|
import { NoTransitionDirective } from 'ngx-easy-view-transitions';
|
|
@@ -142,10 +138,10 @@ import { NoTransitionDirective } from 'ngx-easy-view-transitions';
|
|
|
142
138
|
|
|
143
139
|
### Configure default transition
|
|
144
140
|
|
|
145
|
-
By default View Transitions API will perform a cross-fade animation on all elements.
|
|
141
|
+
By default, View Transitions API will perform a cross-fade animation on all elements.
|
|
146
142
|
But you can also provide your own in and out animations by adding the `provideDefaultViewTransition()` provider function.
|
|
147
143
|
|
|
148
|
-
In the following example the default animation gets disabled:
|
|
144
|
+
In the following example, the default animation gets disabled:
|
|
149
145
|
|
|
150
146
|
```typescript
|
|
151
147
|
bootstrapApplication(AppComponent,
|
|
@@ -174,4 +170,4 @@ Run `pnpm lint` to lint all projects.
|
|
|
174
170
|
|
|
175
171
|
Run `pnpm build` to build all projects. You can find the output under `/dist`.
|
|
176
172
|
|
|
177
|
-
Since it's a nx workspace you can use the common nx commands for everything else.
|
|
173
|
+
Since it's a nx workspace, you can use the common nx commands for everything else.
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { inject, ElementRef, RendererFactory2, Directive, Injectable, input, effect, provideAppInitializer } from '@angular/core';
|
|
2
|
+
import { inject, ElementRef, RendererFactory2, Directive, Injectable, input, Renderer2, effect, provideAppInitializer } from '@angular/core';
|
|
3
3
|
import { DOCUMENT } from '@angular/common';
|
|
4
4
|
|
|
5
5
|
const none = [];
|
|
@@ -600,10 +600,10 @@ class NoTransitionDirective {
|
|
|
600
600
|
if (!this._document.getElementById(elementId))
|
|
601
601
|
this._renderer.appendChild(this._document.head, styleElement);
|
|
602
602
|
}
|
|
603
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
604
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "
|
|
603
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.1", ngImport: i0, type: NoTransitionDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
604
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "21.1.1", type: NoTransitionDirective, isStandalone: true, selector: "[noTransition]", ngImport: i0 }); }
|
|
605
605
|
}
|
|
606
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
606
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.1", ngImport: i0, type: NoTransitionDirective, decorators: [{
|
|
607
607
|
type: Directive,
|
|
608
608
|
args: [{
|
|
609
609
|
standalone: true,
|
|
@@ -621,6 +621,19 @@ function hashCode(str) {
|
|
|
621
621
|
}
|
|
622
622
|
return hash;
|
|
623
623
|
}
|
|
624
|
+
/**@internal*/
|
|
625
|
+
function isValidCustomIdentValue(value) {
|
|
626
|
+
const regex = /^(?:[A-Za-z_]|-(?!\d)|\\[0-9A-Fa-f]{1,6}|\\.)[A-Za-z0-9_-]*(?:\\[0-9A-Fa-f]{1,6}|\\.)*[A-Za-z0-9_-]*$/u;
|
|
627
|
+
return regex.test(value);
|
|
628
|
+
}
|
|
629
|
+
/**@internal*/
|
|
630
|
+
function isValidViewTransitionName(value) {
|
|
631
|
+
return (isValidCustomIdentValue(value) &&
|
|
632
|
+
value !== 'unset' &&
|
|
633
|
+
value !== 'initial' &&
|
|
634
|
+
value !== 'inherit' &&
|
|
635
|
+
value !== 'none');
|
|
636
|
+
}
|
|
624
637
|
|
|
625
638
|
/**@internal*/
|
|
626
639
|
class KeyframesService {
|
|
@@ -628,17 +641,20 @@ class KeyframesService {
|
|
|
628
641
|
this._rendererFactory = inject(RendererFactory2);
|
|
629
642
|
this._renderer = this._rendererFactory.createRenderer(null, null);
|
|
630
643
|
this._document = inject(DOCUMENT);
|
|
644
|
+
this._insertedKeyframes = new Set();
|
|
631
645
|
}
|
|
632
646
|
setKeyframes(keyframes) {
|
|
633
647
|
const keyframesAsString = JSON.stringify(keyframes);
|
|
634
648
|
const hashedKeyframes = hashCode(keyframesAsString);
|
|
635
|
-
const keyframesName = `
|
|
636
|
-
|
|
637
|
-
|
|
638
|
-
styleElement
|
|
639
|
-
styleElement
|
|
640
|
-
|
|
641
|
-
|
|
649
|
+
const keyframesName = `keyframes-${hashedKeyframes}`;
|
|
650
|
+
if (this._insertedKeyframes.has(keyframesName))
|
|
651
|
+
return keyframesName;
|
|
652
|
+
const styleElement = this._renderer.createElement('style');
|
|
653
|
+
this._renderer.setAttribute(styleElement, 'id', keyframesName);
|
|
654
|
+
const cssKeyframeRule = this.generateCssKeyframeRule(keyframesName, keyframes);
|
|
655
|
+
this._renderer.setProperty(styleElement, 'innerHTML', cssKeyframeRule);
|
|
656
|
+
this._renderer.appendChild(this._document.head, styleElement);
|
|
657
|
+
this._insertedKeyframes.add(keyframesName);
|
|
642
658
|
return keyframesName;
|
|
643
659
|
}
|
|
644
660
|
generateCssKeyframeRule(animationName, keyframes) {
|
|
@@ -654,10 +670,10 @@ class KeyframesService {
|
|
|
654
670
|
});
|
|
655
671
|
return `@keyframes ${animationName} { ${cssKeyframes.join(' ')} }`;
|
|
656
672
|
}
|
|
657
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
658
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
673
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.1", ngImport: i0, type: KeyframesService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
674
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.1.1", ngImport: i0, type: KeyframesService, providedIn: 'root' }); }
|
|
659
675
|
}
|
|
660
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
676
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.1", ngImport: i0, type: KeyframesService, decorators: [{
|
|
661
677
|
type: Injectable,
|
|
662
678
|
args: [{ providedIn: 'root' }]
|
|
663
679
|
}] });
|
|
@@ -693,10 +709,10 @@ class ViewTransitionsService {
|
|
|
693
709
|
if (!this._document.getElementById(elementId))
|
|
694
710
|
this._renderer.appendChild(this._document.head, styleElement);
|
|
695
711
|
}
|
|
696
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
697
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
712
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.1", ngImport: i0, type: ViewTransitionsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
713
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.1.1", ngImport: i0, type: ViewTransitionsService, providedIn: 'root' }); }
|
|
698
714
|
}
|
|
699
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
715
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.1", ngImport: i0, type: ViewTransitionsService, decorators: [{
|
|
700
716
|
type: Injectable,
|
|
701
717
|
args: [{ providedIn: 'root' }]
|
|
702
718
|
}] });
|
|
@@ -709,21 +725,27 @@ class TransitionNameDirective {
|
|
|
709
725
|
/**
|
|
710
726
|
* Set the `view-transition-name` property to assign transitions to that element
|
|
711
727
|
*/
|
|
712
|
-
this.transitionName = input.required();
|
|
728
|
+
this.transitionName = input.required(...(ngDevMode ? [{ debugName: "transitionName" }] : []));
|
|
713
729
|
/**
|
|
714
730
|
* Configure the animation when the element enters the view
|
|
715
731
|
*/
|
|
716
|
-
this.inAnimation = input();
|
|
732
|
+
this.inAnimation = input(...(ngDevMode ? [undefined, { debugName: "inAnimation" }] : []));
|
|
717
733
|
/**
|
|
718
734
|
* Configure the animation when the element leaves the view
|
|
719
735
|
*/
|
|
720
|
-
this.outAnimation = input();
|
|
736
|
+
this.outAnimation = input(...(ngDevMode ? [undefined, { debugName: "outAnimation" }] : []));
|
|
721
737
|
this._el = inject(ElementRef);
|
|
738
|
+
this._renderer = inject(Renderer2);
|
|
722
739
|
this._keyframesService = inject(KeyframesService);
|
|
723
740
|
this._viewTransitionsService = inject(ViewTransitionsService);
|
|
724
741
|
//transitionName
|
|
725
742
|
effect(() => {
|
|
726
|
-
|
|
743
|
+
const transitionName = this.transitionName();
|
|
744
|
+
this._renderer.setStyle(this._el.nativeElement, 'view-transition-name', transitionName);
|
|
745
|
+
queueMicrotask(() => {
|
|
746
|
+
if (!isValidViewTransitionName(transitionName))
|
|
747
|
+
console.warn(`The transition name "${transitionName}" is potentially invalid. Please use a valid CSS <custom-ident> value and avoid forbidden values like "unset", "initial", "inherit" and "none".`);
|
|
748
|
+
});
|
|
727
749
|
});
|
|
728
750
|
//inAnimation
|
|
729
751
|
effect(async () => {
|
|
@@ -756,16 +778,16 @@ class TransitionNameDirective {
|
|
|
756
778
|
}
|
|
757
779
|
});
|
|
758
780
|
}
|
|
759
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
760
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "
|
|
781
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.1", ngImport: i0, type: TransitionNameDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
782
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "21.1.1", type: TransitionNameDirective, isStandalone: true, selector: "[transitionName]", inputs: { transitionName: { classPropertyName: "transitionName", publicName: "transitionName", isSignal: true, isRequired: true, transformFunction: null }, inAnimation: { classPropertyName: "inAnimation", publicName: "inAnimation", isSignal: true, isRequired: false, transformFunction: null }, outAnimation: { classPropertyName: "outAnimation", publicName: "outAnimation", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0 }); }
|
|
761
783
|
}
|
|
762
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
784
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.1", ngImport: i0, type: TransitionNameDirective, decorators: [{
|
|
763
785
|
type: Directive,
|
|
764
786
|
args: [{
|
|
765
787
|
standalone: true,
|
|
766
788
|
selector: '[transitionName]',
|
|
767
789
|
}]
|
|
768
|
-
}], ctorParameters: () => [] });
|
|
790
|
+
}], ctorParameters: () => [], propDecorators: { transitionName: [{ type: i0.Input, args: [{ isSignal: true, alias: "transitionName", required: true }] }], inAnimation: [{ type: i0.Input, args: [{ isSignal: true, alias: "inAnimation", required: false }] }], outAnimation: [{ type: i0.Input, args: [{ isSignal: true, alias: "outAnimation", required: false }] }] } });
|
|
769
791
|
|
|
770
792
|
/**
|
|
771
793
|
* Override the default View Transition API cross-fade animation
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ngx-easy-view-transitions.mjs","sources":["../../../ngx-easy-view-transitions/src/lib/default-transitions.ts","../../../ngx-easy-view-transitions/src/lib/no-transition.directive.ts","../../../ngx-easy-view-transitions/src/lib/utils.ts","../../../ngx-easy-view-transitions/src/lib/keyframes.service.ts","../../../ngx-easy-view-transitions/src/lib/view-transitions.service.ts","../../../ngx-easy-view-transitions/src/lib/transition-name.directive.ts","../../../ngx-easy-view-transitions/src/lib/default-view-transition.provider.ts","../../../ngx-easy-view-transitions/src/ngx-easy-view-transitions.ts"],"sourcesContent":["export const none: Keyframe[] = [];\n\nexport const scaleIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'scale(0.5)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'scale(1)',\n offset: 1,\n },\n];\n\nexport const scaleOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'scale(1)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'scale(0.5)',\n offset: 1,\n },\n];\n\nexport const fadeIn: Keyframe[] = [\n {\n opacity: 0,\n offset: 0,\n },\n {\n opacity: 1,\n offset: 1,\n },\n];\n\nexport const fadeOut: Keyframe[] = [\n {\n opacity: 1,\n offset: 0,\n },\n {\n opacity: 0,\n offset: 1,\n },\n];\n\nexport const fadeInUp: Keyframe[] = [\n {\n opacity: 0,\n transform: 'translate(0, 100%)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'translate(0, 0)',\n offset: 1,\n },\n];\n\nexport const fadeOutUp: Keyframe[] = [\n {\n opacity: 1,\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'translate(0, -100%)',\n offset: 1,\n },\n];\n\nexport const fadeInDown: Keyframe[] = [\n {\n opacity: 0,\n transform: 'translate(0, -100%)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'translate(0, 0)',\n offset: 1,\n },\n];\n\nexport const fadeOutDown: Keyframe[] = [\n {\n opacity: 1,\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'translate(0, 100%)',\n offset: 1,\n },\n];\n\nexport const fadeInRight: Keyframe[] = [\n {\n opacity: 0,\n transform: 'translate(100%, 0)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'translate(0, 0)',\n offset: 1,\n },\n];\n\nexport const fadeOutRight: Keyframe[] = [\n {\n opacity: 1,\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'translate(100%, 0)',\n offset: 1,\n },\n];\n\nexport const fadeInLeft: Keyframe[] = [\n {\n opacity: 0,\n transform: 'translate(-100%, 0)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'translate(0, 0)',\n offset: 1,\n },\n];\n\nexport const fadeOutLeft: Keyframe[] = [\n {\n opacity: 1,\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'translate(-100%, 0)',\n offset: 1,\n },\n];\n\nexport const flipInX: Keyframe[] = [\n {\n opacity: 0,\n transform: 'rotateX(90deg)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'rotateX(0)',\n offset: 1,\n },\n];\n\nexport const flipOutX: Keyframe[] = [\n {\n opacity: 1,\n transform: 'rotateX(0)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'rotateX(90deg)',\n offset: 1,\n },\n];\n\nexport const flipInY: Keyframe[] = [\n {\n opacity: 0,\n transform: 'rotateY(90deg)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'rotateY(0)',\n offset: 1,\n },\n];\n\nexport const flipOutY: Keyframe[] = [\n {\n opacity: 1,\n transform: 'rotateY(0)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'rotateY(90deg)',\n offset: 1,\n },\n];\n\nexport const rotateIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'rotate(-180deg) scale(0.5)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'rotate(0) scale(1)',\n offset: 1,\n },\n];\n\nexport const rotateOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'rotate(0) scale(1)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'rotate(180deg) scale(0.5)',\n offset: 1,\n },\n];\n\nexport const bounceIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'scale(0.3)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'scale(1.05)',\n offset: 0.6,\n },\n {\n opacity: 1,\n transform: 'scale(0.95)',\n offset: 0.8,\n },\n {\n opacity: 1,\n transform: 'scale(1)',\n offset: 1,\n },\n];\n\nexport const bounceOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'scale(1)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'scale(0.95)',\n offset: 0.2,\n },\n {\n opacity: 1,\n transform: 'scale(1.05)',\n offset: 0.4,\n },\n {\n opacity: 0,\n transform: 'scale(0.3)',\n offset: 1,\n },\n];\n\nexport const blurIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'scale(1.2)',\n filter: 'blur(20px)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'scale(1)',\n filter: 'blur(0px)',\n offset: 1,\n },\n];\n\nexport const blurOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'scale(1)',\n filter: 'blur(0px)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'scale(0.8)',\n filter: 'blur(20px)',\n offset: 1,\n },\n];\n\nexport const perspectiveIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'perspective(1000px) rotateY(90deg)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'perspective(1000px) rotateY(0deg)',\n offset: 1,\n },\n];\n\nexport const perspectiveOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'perspective(1000px) rotateY(0deg)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'perspective(1000px) rotateY(-90deg)',\n offset: 1,\n },\n];\n\nexport const skewIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'translateX(-100%) skewX(30deg)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'translateX(0) skewX(0deg)',\n offset: 1,\n },\n];\n\nexport const skewOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'translateX(0) skewX(0deg)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'translateX(100%) skewX(-30deg)',\n offset: 1,\n },\n];\n\nexport const revealCircleIn: Keyframe[] = [\n {\n clipPath: 'circle(0% at 50% 50%)',\n offset: 0,\n },\n {\n clipPath: 'circle(150% at 50% 50%)',\n offset: 1,\n },\n];\n\nexport const revealCircleOut: Keyframe[] = [\n {\n clipPath: 'circle(150% at 50% 50%)',\n offset: 0,\n },\n {\n clipPath: 'circle(0% at 50% 50%)',\n offset: 1,\n },\n];\n\nexport const parallaxIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'translateZ(-300px) scale(2)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'translateZ(0) scale(1)',\n offset: 1,\n },\n];\n\nexport const parallaxOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'translateZ(0) scale(1)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'translateZ(-300px) scale(0.8)',\n offset: 1,\n },\n];\n\nexport const tiltIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'rotate(-15deg) translateY(50%)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'rotate(0) translateY(0)',\n offset: 1,\n },\n];\n\nexport const tiltOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'rotate(0) translateY(0)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'rotate(15deg) translateY(-50%)',\n offset: 1,\n },\n];\n\nexport const glitchIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'translate(0, 0)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'translate(-2px, 2px)',\n offset: 0.2,\n },\n {\n opacity: 1,\n transform: 'translate(2px, -2px)',\n offset: 0.4,\n },\n {\n opacity: 1,\n transform: 'translate(-1px, 1px)',\n offset: 0.6,\n },\n {\n opacity: 1,\n transform: 'translate(1px, -1px)',\n offset: 0.8,\n },\n {\n opacity: 1,\n transform: 'translate(0, 0)',\n offset: 1,\n },\n];\n\nexport const curtainIn: Keyframe[] = [\n {\n clipPath: 'inset(0 50% 0 50%)',\n offset: 0,\n },\n {\n clipPath: 'inset(0 0% 0 0%)',\n offset: 1,\n },\n];\n\nexport const curtainOut: Keyframe[] = [\n {\n clipPath: 'inset(0 0% 0 0%)',\n offset: 0,\n },\n {\n clipPath: 'inset(0 50% 0 50%)',\n offset: 1,\n },\n];\n\nexport const depthFlipIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'perspective(1200px) rotateX(-90deg) translateZ(-200px)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'perspective(1200px) rotateX(0deg) translateZ(0)',\n offset: 1,\n },\n];\n\nexport const depthFlipOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'perspective(1200px) rotateX(0deg) translateZ(0)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'perspective(1200px) rotateX(90deg) translateZ(-200px)',\n offset: 1,\n },\n];\n\nexport const distortWarpIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'skewX(20deg) scale(0.9)',\n filter: 'blur(10px)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'skewX(0deg) scale(1)',\n filter: 'blur(0px)',\n offset: 1,\n },\n];\n\nexport const distortWarpOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'skewX(0deg) scale(1)',\n filter: 'blur(0px)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'skewX(-20deg) scale(0.9)',\n filter: 'blur(10px)',\n offset: 1,\n },\n];\n\nexport const coverFlipIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'perspective(800px) rotateY(-12deg) translateX(-8px)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'perspective(800px) rotateY(0deg) translateX(0)',\n offset: 1,\n },\n];\n\nexport const coverFlipOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'perspective(800px) rotateY(0deg) translateX(0)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'perspective(800px) rotateY(12deg) translateX(8px)',\n offset: 1,\n },\n];\n","import { Directive, ElementRef, inject, OnInit, RendererFactory2 } from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\n\n/**\n * Exclude an element from view transitions\n */\n@Directive({\n standalone: true,\n selector: '[noTransition]',\n})\nexport class NoTransitionDirective implements OnInit {\n private readonly _el = inject(ElementRef);\n private readonly _rendererFactory = inject(RendererFactory2);\n private readonly _renderer = this._rendererFactory.createRenderer(null, null);\n private readonly _document = inject(DOCUMENT);\n\n ngOnInit(): void {\n const transitionName = 'ngx-easy-view-transitions-disabled';\n\n this._el.nativeElement.style.viewTransitionName = transitionName;\n\n const elementId = 'view-transition-none';\n\n const styleElement = this._document.getElementById(elementId) || this._document.createElement('style');\n\n styleElement.innerHTML = `\n ::view-transition-group(${transitionName}),\n ::view-transition-old(${transitionName}),\n ::view-transition-new(${transitionName}) {\n animation-duration: 0s !important;\n }\n `;\n styleElement.id = elementId;\n\n if (!this._document.getElementById(elementId)) this._renderer.appendChild(this._document.head, styleElement);\n }\n}\n","/**@internal*/\nexport function hashCode(str: string): number {\n let hash = 0;\n for (let i = 0, len = str.length; i < len; i++) {\n const code = str.charCodeAt(i);\n hash = (hash << 5) - hash + code;\n hash |= 0; // Convert to 32bit integer\n }\n return hash;\n}\n","import { inject, Injectable, RendererFactory2 } from '@angular/core';\nimport { hashCode } from './utils';\nimport { DOCUMENT } from '@angular/common';\n\n/**@internal*/\n@Injectable({ providedIn: 'root' })\nexport class KeyframesService {\n private readonly _rendererFactory = inject(RendererFactory2);\n private readonly _renderer = this._rendererFactory.createRenderer(null, null);\n private readonly _document = inject(DOCUMENT);\n\n setKeyframes(keyframes: Keyframe[]) {\n const keyframesAsString = JSON.stringify(keyframes);\n const hashedKeyframes = hashCode(keyframesAsString);\n const keyframesName = `_${hashedKeyframes}`;\n\n const elementId = `keyframes-${keyframesName}`;\n\n const styleElement = this._document.getElementById(elementId) || this._document.createElement('style');\n\n styleElement.innerHTML = this.generateCssKeyframeRule(keyframesName, keyframes);\n styleElement.id = elementId;\n\n if (!this._document.getElementById(elementId)) this._renderer.appendChild(this._document.head, styleElement);\n\n return keyframesName;\n }\n\n private generateCssKeyframeRule(animationName: string, keyframes: Keyframe[]): string {\n const cssKeyframes: string[] = [];\n\n keyframes.forEach((keyframe, index) => {\n const offset = keyframe.offset ? `${keyframe.offset * 100}%` : '';\n\n const keyframeDeclaration = `${\n index === 0 ? 'from' : offset ? offset : index === keyframes.length - 1 ? 'to' : ''\n }`;\n\n const cssProperties = Object.entries(keyframe)\n .filter(([property]) => property !== 'offset')\n .map(([property, value]) => `${property}: ${value};`)\n .join('');\n\n cssKeyframes.push(`${keyframeDeclaration} { ${cssProperties} }`);\n });\n\n return `@keyframes ${animationName} { ${cssKeyframes.join(' ')} }`;\n }\n}\n","import { inject, Injectable, RendererFactory2 } from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\n\n/**@internal*/\n@Injectable({ providedIn: 'root' })\nexport class ViewTransitionsService {\n private readonly _rendererFactory = inject(RendererFactory2);\n private readonly _renderer = this._rendererFactory.createRenderer(null, null);\n private readonly _document = inject(DOCUMENT);\n\n setOutAnimation(outAnimation: string, transitionName: string) {\n const elementId = `view-transition-out-${transitionName}`;\n\n const styleElement = this._document.getElementById(elementId) || this._document.createElement('style');\n\n styleElement.innerHTML = `\n ::view-transition-old(${transitionName}){\n animation: ${outAnimation};\n }\n `;\n styleElement.id = elementId;\n\n if (!this._document.getElementById(elementId)) this._renderer.appendChild(this._document.head, styleElement);\n }\n\n setInAnimation(inAnimation: string, transitionName: string) {\n const elementId = `view-transition-in-${transitionName}`;\n\n const styleElement = this._document.getElementById(elementId) || this._document.createElement('style');\n\n styleElement.innerHTML = `\n ::view-transition-new(${transitionName}){\n animation: ${inAnimation};\n }\n `;\n styleElement.id = elementId;\n\n if (!this._document.getElementById(elementId)) this._renderer.appendChild(this._document.head, styleElement);\n }\n}\n","import { Directive, effect, ElementRef, inject, input } from '@angular/core';\nimport { KeyframesTransition } from './keyframes-transition';\nimport { CssKeyframesTransition } from './css-keyframes-transition';\nimport { KeyframesService } from './keyframes.service';\nimport { ViewTransitionsService } from './view-transitions.service';\n\n/**\n * Configure view transitions for the element\n */\n@Directive({\n standalone: true,\n selector: '[transitionName]',\n})\nexport class TransitionNameDirective {\n /**\n * Set the `view-transition-name` property to assign transitions to that element\n */\n transitionName = input.required<string>();\n /**\n * Configure the animation when the element enters the view\n */\n inAnimation = input<KeyframesTransition | CssKeyframesTransition>();\n /**\n * Configure the animation when the element leaves the view\n */\n outAnimation = input<KeyframesTransition | CssKeyframesTransition>();\n\n private readonly _el = inject(ElementRef);\n private readonly _keyframesService = inject(KeyframesService);\n private readonly _viewTransitionsService = inject(ViewTransitionsService);\n\n constructor() {\n //transitionName\n effect(() => {\n this._el.nativeElement.style.viewTransitionName = this.transitionName();\n });\n\n //inAnimation\n effect(async () => {\n const inAnimation = this.inAnimation();\n\n if (!inAnimation) return;\n\n if ('keyframesName' in inAnimation) {\n const animation = inAnimation as CssKeyframesTransition;\n this._viewTransitionsService.setInAnimation(\n `${animation.duration}ms ${animation.keyframesName} ${animation.reverse ? 'reverse' : ''}`,\n this.transitionName()\n );\n }\n\n if ('keyframes' in inAnimation) {\n const animation = inAnimation as KeyframesTransition;\n const keyframesName = this._keyframesService.setKeyframes(animation.keyframes);\n this._viewTransitionsService.setInAnimation(\n `${animation.duration}ms ${keyframesName} ${animation.reverse ? 'reverse' : ''}`,\n this.transitionName()\n );\n }\n });\n\n //outAnimation\n effect(async () => {\n const outAnimation = this.outAnimation();\n\n if (!outAnimation) return;\n\n if ('keyframesName' in outAnimation) {\n const animation = outAnimation as CssKeyframesTransition;\n this._viewTransitionsService.setOutAnimation(\n `${animation.duration}ms ${animation.keyframesName} ${animation.reverse ? 'reverse' : ''}`,\n this.transitionName()\n );\n }\n\n if ('keyframes' in outAnimation) {\n const animation = outAnimation as KeyframesTransition;\n const keyframesName = this._keyframesService.setKeyframes(animation.keyframes);\n this._viewTransitionsService.setOutAnimation(\n `${animation.duration}ms ${keyframesName} ${animation.reverse ? 'reverse' : ''}`,\n this.transitionName()\n );\n }\n });\n }\n}\n","import { EnvironmentProviders, inject, provideAppInitializer } from '@angular/core';\nimport { KeyframesTransition } from './keyframes-transition';\nimport { CssKeyframesTransition } from './css-keyframes-transition';\nimport { ViewTransitionsService } from './view-transitions.service';\nimport { KeyframesService } from './keyframes.service';\n\n/**\n * Override the default View Transition API cross-fade animation\n * @param inAnimation\n * @param outAnimation\n */\nexport function provideDefaultViewTransition(\n inAnimation: KeyframesTransition | CssKeyframesTransition,\n outAnimation: KeyframesTransition | CssKeyframesTransition\n): EnvironmentProviders {\n const factory = (viewTransitionService: ViewTransitionsService, keyframesService: KeyframesService) => {\n return () => {\n if ('keyframesName' in inAnimation) {\n const animation = inAnimation as CssKeyframesTransition;\n viewTransitionService.setInAnimation(\n `${animation.duration}ms ${animation.keyframesName} ${animation.reverse ? 'reverse' : ''}`,\n 'root'\n );\n }\n\n if ('keyframes' in inAnimation) {\n const animation = inAnimation as KeyframesTransition;\n const keyframesName = keyframesService.setKeyframes(animation.keyframes);\n viewTransitionService.setInAnimation(\n `${animation.duration}ms ${keyframesName} ${animation.reverse ? 'reverse' : ''}`,\n 'root'\n );\n }\n\n if ('keyframesName' in outAnimation) {\n const animation = outAnimation as CssKeyframesTransition;\n viewTransitionService.setOutAnimation(\n `${animation.duration}ms ${animation.keyframesName} ${animation.reverse ? 'reverse' : ''}`,\n 'root'\n );\n }\n\n if ('keyframes' in outAnimation) {\n const animation = outAnimation as KeyframesTransition;\n const keyframesName = keyframesService.setKeyframes(animation.keyframes);\n viewTransitionService.setOutAnimation(\n `${animation.duration}ms ${keyframesName} ${animation.reverse ? 'reverse' : ''}`,\n 'root'\n );\n }\n };\n };\n\n return provideAppInitializer(() => {\n const initializerFn = factory(inject(ViewTransitionsService), inject(KeyframesService));\n return initializerFn();\n });\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ngx-easy-view-transitions.mjs","sources":["../../../ngx-easy-view-transitions/src/lib/default-transitions.ts","../../../ngx-easy-view-transitions/src/lib/no-transition.directive.ts","../../../ngx-easy-view-transitions/src/lib/utils.ts","../../../ngx-easy-view-transitions/src/lib/keyframes.service.ts","../../../ngx-easy-view-transitions/src/lib/view-transitions.service.ts","../../../ngx-easy-view-transitions/src/lib/transition-name.directive.ts","../../../ngx-easy-view-transitions/src/lib/default-view-transition.provider.ts","../../../ngx-easy-view-transitions/src/ngx-easy-view-transitions.ts"],"sourcesContent":["export const none: Keyframe[] = [];\n\nexport const scaleIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'scale(0.5)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'scale(1)',\n offset: 1,\n },\n];\n\nexport const scaleOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'scale(1)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'scale(0.5)',\n offset: 1,\n },\n];\n\nexport const fadeIn: Keyframe[] = [\n {\n opacity: 0,\n offset: 0,\n },\n {\n opacity: 1,\n offset: 1,\n },\n];\n\nexport const fadeOut: Keyframe[] = [\n {\n opacity: 1,\n offset: 0,\n },\n {\n opacity: 0,\n offset: 1,\n },\n];\n\nexport const fadeInUp: Keyframe[] = [\n {\n opacity: 0,\n transform: 'translate(0, 100%)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'translate(0, 0)',\n offset: 1,\n },\n];\n\nexport const fadeOutUp: Keyframe[] = [\n {\n opacity: 1,\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'translate(0, -100%)',\n offset: 1,\n },\n];\n\nexport const fadeInDown: Keyframe[] = [\n {\n opacity: 0,\n transform: 'translate(0, -100%)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'translate(0, 0)',\n offset: 1,\n },\n];\n\nexport const fadeOutDown: Keyframe[] = [\n {\n opacity: 1,\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'translate(0, 100%)',\n offset: 1,\n },\n];\n\nexport const fadeInRight: Keyframe[] = [\n {\n opacity: 0,\n transform: 'translate(100%, 0)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'translate(0, 0)',\n offset: 1,\n },\n];\n\nexport const fadeOutRight: Keyframe[] = [\n {\n opacity: 1,\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'translate(100%, 0)',\n offset: 1,\n },\n];\n\nexport const fadeInLeft: Keyframe[] = [\n {\n opacity: 0,\n transform: 'translate(-100%, 0)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'translate(0, 0)',\n offset: 1,\n },\n];\n\nexport const fadeOutLeft: Keyframe[] = [\n {\n opacity: 1,\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'translate(-100%, 0)',\n offset: 1,\n },\n];\n\nexport const flipInX: Keyframe[] = [\n {\n opacity: 0,\n transform: 'rotateX(90deg)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'rotateX(0)',\n offset: 1,\n },\n];\n\nexport const flipOutX: Keyframe[] = [\n {\n opacity: 1,\n transform: 'rotateX(0)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'rotateX(90deg)',\n offset: 1,\n },\n];\n\nexport const flipInY: Keyframe[] = [\n {\n opacity: 0,\n transform: 'rotateY(90deg)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'rotateY(0)',\n offset: 1,\n },\n];\n\nexport const flipOutY: Keyframe[] = [\n {\n opacity: 1,\n transform: 'rotateY(0)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'rotateY(90deg)',\n offset: 1,\n },\n];\n\nexport const rotateIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'rotate(-180deg) scale(0.5)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'rotate(0) scale(1)',\n offset: 1,\n },\n];\n\nexport const rotateOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'rotate(0) scale(1)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'rotate(180deg) scale(0.5)',\n offset: 1,\n },\n];\n\nexport const bounceIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'scale(0.3)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'scale(1.05)',\n offset: 0.6,\n },\n {\n opacity: 1,\n transform: 'scale(0.95)',\n offset: 0.8,\n },\n {\n opacity: 1,\n transform: 'scale(1)',\n offset: 1,\n },\n];\n\nexport const bounceOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'scale(1)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'scale(0.95)',\n offset: 0.2,\n },\n {\n opacity: 1,\n transform: 'scale(1.05)',\n offset: 0.4,\n },\n {\n opacity: 0,\n transform: 'scale(0.3)',\n offset: 1,\n },\n];\n\nexport const blurIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'scale(1.2)',\n filter: 'blur(20px)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'scale(1)',\n filter: 'blur(0px)',\n offset: 1,\n },\n];\n\nexport const blurOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'scale(1)',\n filter: 'blur(0px)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'scale(0.8)',\n filter: 'blur(20px)',\n offset: 1,\n },\n];\n\nexport const perspectiveIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'perspective(1000px) rotateY(90deg)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'perspective(1000px) rotateY(0deg)',\n offset: 1,\n },\n];\n\nexport const perspectiveOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'perspective(1000px) rotateY(0deg)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'perspective(1000px) rotateY(-90deg)',\n offset: 1,\n },\n];\n\nexport const skewIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'translateX(-100%) skewX(30deg)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'translateX(0) skewX(0deg)',\n offset: 1,\n },\n];\n\nexport const skewOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'translateX(0) skewX(0deg)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'translateX(100%) skewX(-30deg)',\n offset: 1,\n },\n];\n\nexport const revealCircleIn: Keyframe[] = [\n {\n clipPath: 'circle(0% at 50% 50%)',\n offset: 0,\n },\n {\n clipPath: 'circle(150% at 50% 50%)',\n offset: 1,\n },\n];\n\nexport const revealCircleOut: Keyframe[] = [\n {\n clipPath: 'circle(150% at 50% 50%)',\n offset: 0,\n },\n {\n clipPath: 'circle(0% at 50% 50%)',\n offset: 1,\n },\n];\n\nexport const parallaxIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'translateZ(-300px) scale(2)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'translateZ(0) scale(1)',\n offset: 1,\n },\n];\n\nexport const parallaxOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'translateZ(0) scale(1)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'translateZ(-300px) scale(0.8)',\n offset: 1,\n },\n];\n\nexport const tiltIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'rotate(-15deg) translateY(50%)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'rotate(0) translateY(0)',\n offset: 1,\n },\n];\n\nexport const tiltOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'rotate(0) translateY(0)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'rotate(15deg) translateY(-50%)',\n offset: 1,\n },\n];\n\nexport const glitchIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'translate(0, 0)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'translate(-2px, 2px)',\n offset: 0.2,\n },\n {\n opacity: 1,\n transform: 'translate(2px, -2px)',\n offset: 0.4,\n },\n {\n opacity: 1,\n transform: 'translate(-1px, 1px)',\n offset: 0.6,\n },\n {\n opacity: 1,\n transform: 'translate(1px, -1px)',\n offset: 0.8,\n },\n {\n opacity: 1,\n transform: 'translate(0, 0)',\n offset: 1,\n },\n];\n\nexport const curtainIn: Keyframe[] = [\n {\n clipPath: 'inset(0 50% 0 50%)',\n offset: 0,\n },\n {\n clipPath: 'inset(0 0% 0 0%)',\n offset: 1,\n },\n];\n\nexport const curtainOut: Keyframe[] = [\n {\n clipPath: 'inset(0 0% 0 0%)',\n offset: 0,\n },\n {\n clipPath: 'inset(0 50% 0 50%)',\n offset: 1,\n },\n];\n\nexport const depthFlipIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'perspective(1200px) rotateX(-90deg) translateZ(-200px)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'perspective(1200px) rotateX(0deg) translateZ(0)',\n offset: 1,\n },\n];\n\nexport const depthFlipOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'perspective(1200px) rotateX(0deg) translateZ(0)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'perspective(1200px) rotateX(90deg) translateZ(-200px)',\n offset: 1,\n },\n];\n\nexport const distortWarpIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'skewX(20deg) scale(0.9)',\n filter: 'blur(10px)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'skewX(0deg) scale(1)',\n filter: 'blur(0px)',\n offset: 1,\n },\n];\n\nexport const distortWarpOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'skewX(0deg) scale(1)',\n filter: 'blur(0px)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'skewX(-20deg) scale(0.9)',\n filter: 'blur(10px)',\n offset: 1,\n },\n];\n\nexport const coverFlipIn: Keyframe[] = [\n {\n opacity: 0,\n transform: 'perspective(800px) rotateY(-12deg) translateX(-8px)',\n offset: 0,\n },\n {\n opacity: 1,\n transform: 'perspective(800px) rotateY(0deg) translateX(0)',\n offset: 1,\n },\n];\n\nexport const coverFlipOut: Keyframe[] = [\n {\n opacity: 1,\n transform: 'perspective(800px) rotateY(0deg) translateX(0)',\n offset: 0,\n },\n {\n opacity: 0,\n transform: 'perspective(800px) rotateY(12deg) translateX(8px)',\n offset: 1,\n },\n];\n","import { Directive, ElementRef, inject, OnInit, RendererFactory2 } from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\n\n/**\n * Exclude an element from view transitions\n */\n@Directive({\n standalone: true,\n selector: '[noTransition]',\n})\nexport class NoTransitionDirective implements OnInit {\n private readonly _el = inject(ElementRef);\n private readonly _rendererFactory = inject(RendererFactory2);\n private readonly _renderer = this._rendererFactory.createRenderer(null, null);\n private readonly _document = inject(DOCUMENT);\n\n ngOnInit(): void {\n const transitionName = 'ngx-easy-view-transitions-disabled';\n\n this._el.nativeElement.style.viewTransitionName = transitionName;\n\n const elementId = 'view-transition-none';\n\n const styleElement = this._document.getElementById(elementId) || this._document.createElement('style');\n\n styleElement.innerHTML = `\n ::view-transition-group(${transitionName}),\n ::view-transition-old(${transitionName}),\n ::view-transition-new(${transitionName}) {\n animation-duration: 0s !important;\n }\n `;\n styleElement.id = elementId;\n\n if (!this._document.getElementById(elementId)) this._renderer.appendChild(this._document.head, styleElement);\n }\n}\n","/**@internal*/\nexport function hashCode(str: string): number {\n let hash = 0;\n for (let i = 0, len = str.length; i < len; i++) {\n const code = str.charCodeAt(i);\n hash = (hash << 5) - hash + code;\n hash |= 0; // Convert to 32bit integer\n }\n return hash;\n}\n\n/**@internal*/\nexport function isValidCustomIdentValue(value: string): boolean {\n const regex =\n /^(?:[A-Za-z_]|-(?!\\d)|\\\\[0-9A-Fa-f]{1,6}|\\\\.)[A-Za-z0-9_-]*(?:\\\\[0-9A-Fa-f]{1,6}|\\\\.)*[A-Za-z0-9_-]*$/u;\n\n return regex.test(value);\n}\n\n/**@internal*/\nexport function isValidViewTransitionName(value: string): boolean {\n return (\n isValidCustomIdentValue(value) &&\n value !== 'unset' &&\n value !== 'initial' &&\n value !== 'inherit' &&\n value !== 'none'\n );\n}\n","import { inject, Injectable, RendererFactory2 } from '@angular/core';\nimport { hashCode } from './utils';\nimport { DOCUMENT } from '@angular/common';\n\n/**@internal*/\n@Injectable({ providedIn: 'root' })\nexport class KeyframesService {\n private readonly _rendererFactory = inject(RendererFactory2);\n private readonly _renderer = this._rendererFactory.createRenderer(null, null);\n private readonly _document = inject(DOCUMENT);\n\n private readonly _insertedKeyframes = new Set<string>();\n\n setKeyframes(keyframes: Keyframe[]) {\n const keyframesAsString = JSON.stringify(keyframes);\n const hashedKeyframes = hashCode(keyframesAsString);\n const keyframesName = `keyframes-${hashedKeyframes}`;\n\n if (this._insertedKeyframes.has(keyframesName)) return keyframesName;\n\n const styleElement = this._renderer.createElement('style') as HTMLStyleElement;\n\n this._renderer.setAttribute(styleElement, 'id', keyframesName);\n\n const cssKeyframeRule = this.generateCssKeyframeRule(keyframesName, keyframes);\n this._renderer.setProperty(styleElement, 'innerHTML', cssKeyframeRule);\n\n this._renderer.appendChild(this._document.head, styleElement);\n\n this._insertedKeyframes.add(keyframesName);\n\n return keyframesName;\n }\n\n private generateCssKeyframeRule(animationName: string, keyframes: Keyframe[]): string {\n const cssKeyframes: string[] = [];\n\n keyframes.forEach((keyframe, index) => {\n const offset = keyframe.offset ? `${keyframe.offset * 100}%` : '';\n\n const keyframeDeclaration = `${\n index === 0 ? 'from' : offset ? offset : index === keyframes.length - 1 ? 'to' : ''\n }`;\n\n const cssProperties = Object.entries(keyframe)\n .filter(([property]) => property !== 'offset')\n .map(([property, value]) => `${property}: ${value};`)\n .join('');\n\n cssKeyframes.push(`${keyframeDeclaration} { ${cssProperties} }`);\n });\n\n return `@keyframes ${animationName} { ${cssKeyframes.join(' ')} }`;\n }\n}\n","import { inject, Injectable, RendererFactory2 } from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\n\n/**@internal*/\n@Injectable({ providedIn: 'root' })\nexport class ViewTransitionsService {\n private readonly _rendererFactory = inject(RendererFactory2);\n private readonly _renderer = this._rendererFactory.createRenderer(null, null);\n private readonly _document = inject(DOCUMENT);\n\n setOutAnimation(outAnimation: string, transitionName: string) {\n const elementId = `view-transition-out-${transitionName}`;\n\n const styleElement = this._document.getElementById(elementId) || this._document.createElement('style');\n\n styleElement.innerHTML = `\n ::view-transition-old(${transitionName}){\n animation: ${outAnimation};\n }\n `;\n styleElement.id = elementId;\n\n if (!this._document.getElementById(elementId)) this._renderer.appendChild(this._document.head, styleElement);\n }\n\n setInAnimation(inAnimation: string, transitionName: string) {\n const elementId = `view-transition-in-${transitionName}`;\n\n const styleElement = this._document.getElementById(elementId) || this._document.createElement('style');\n\n styleElement.innerHTML = `\n ::view-transition-new(${transitionName}){\n animation: ${inAnimation};\n }\n `;\n styleElement.id = elementId;\n\n if (!this._document.getElementById(elementId)) this._renderer.appendChild(this._document.head, styleElement);\n }\n}\n","import { Directive, effect, ElementRef, inject, input, Renderer2 } from '@angular/core';\nimport { KeyframesTransition } from './keyframes-transition';\nimport { CssKeyframesTransition } from './css-keyframes-transition';\nimport { KeyframesService } from './keyframes.service';\nimport { ViewTransitionsService } from './view-transitions.service';\nimport { isValidViewTransitionName } from './utils';\n\n/**\n * Configure view transitions for the element\n */\n@Directive({\n standalone: true,\n selector: '[transitionName]',\n})\nexport class TransitionNameDirective {\n /**\n * Set the `view-transition-name` property to assign transitions to that element\n */\n transitionName = input.required<string>();\n /**\n * Configure the animation when the element enters the view\n */\n inAnimation = input<KeyframesTransition | CssKeyframesTransition>();\n /**\n * Configure the animation when the element leaves the view\n */\n outAnimation = input<KeyframesTransition | CssKeyframesTransition>();\n\n private readonly _el = inject(ElementRef);\n private readonly _renderer = inject(Renderer2);\n private readonly _keyframesService = inject(KeyframesService);\n private readonly _viewTransitionsService = inject(ViewTransitionsService);\n\n constructor() {\n //transitionName\n effect(() => {\n const transitionName = this.transitionName();\n\n this._renderer.setStyle(this._el.nativeElement, 'view-transition-name', transitionName);\n\n queueMicrotask(() => {\n if (!isValidViewTransitionName(transitionName))\n console.warn(\n `The transition name \"${transitionName}\" is potentially invalid. Please use a valid CSS <custom-ident> value and avoid forbidden values like \"unset\", \"initial\", \"inherit\" and \"none\".`\n );\n });\n });\n\n //inAnimation\n effect(async () => {\n const inAnimation = this.inAnimation();\n\n if (!inAnimation) return;\n\n if ('keyframesName' in inAnimation) {\n const animation = inAnimation as CssKeyframesTransition;\n this._viewTransitionsService.setInAnimation(\n `${animation.duration}ms ${animation.keyframesName} ${animation.reverse ? 'reverse' : ''}`,\n this.transitionName()\n );\n }\n\n if ('keyframes' in inAnimation) {\n const animation = inAnimation as KeyframesTransition;\n const keyframesName = this._keyframesService.setKeyframes(animation.keyframes);\n this._viewTransitionsService.setInAnimation(\n `${animation.duration}ms ${keyframesName} ${animation.reverse ? 'reverse' : ''}`,\n this.transitionName()\n );\n }\n });\n\n //outAnimation\n effect(async () => {\n const outAnimation = this.outAnimation();\n\n if (!outAnimation) return;\n\n if ('keyframesName' in outAnimation) {\n const animation = outAnimation as CssKeyframesTransition;\n this._viewTransitionsService.setOutAnimation(\n `${animation.duration}ms ${animation.keyframesName} ${animation.reverse ? 'reverse' : ''}`,\n this.transitionName()\n );\n }\n\n if ('keyframes' in outAnimation) {\n const animation = outAnimation as KeyframesTransition;\n const keyframesName = this._keyframesService.setKeyframes(animation.keyframes);\n this._viewTransitionsService.setOutAnimation(\n `${animation.duration}ms ${keyframesName} ${animation.reverse ? 'reverse' : ''}`,\n this.transitionName()\n );\n }\n });\n }\n}\n","import { EnvironmentProviders, inject, provideAppInitializer } from '@angular/core';\nimport { KeyframesTransition } from './keyframes-transition';\nimport { CssKeyframesTransition } from './css-keyframes-transition';\nimport { ViewTransitionsService } from './view-transitions.service';\nimport { KeyframesService } from './keyframes.service';\n\n/**\n * Override the default View Transition API cross-fade animation\n * @param inAnimation\n * @param outAnimation\n */\nexport function provideDefaultViewTransition(\n inAnimation: KeyframesTransition | CssKeyframesTransition,\n outAnimation: KeyframesTransition | CssKeyframesTransition\n): EnvironmentProviders {\n const factory = (viewTransitionService: ViewTransitionsService, keyframesService: KeyframesService) => {\n return () => {\n if ('keyframesName' in inAnimation) {\n const animation = inAnimation as CssKeyframesTransition;\n viewTransitionService.setInAnimation(\n `${animation.duration}ms ${animation.keyframesName} ${animation.reverse ? 'reverse' : ''}`,\n 'root'\n );\n }\n\n if ('keyframes' in inAnimation) {\n const animation = inAnimation as KeyframesTransition;\n const keyframesName = keyframesService.setKeyframes(animation.keyframes);\n viewTransitionService.setInAnimation(\n `${animation.duration}ms ${keyframesName} ${animation.reverse ? 'reverse' : ''}`,\n 'root'\n );\n }\n\n if ('keyframesName' in outAnimation) {\n const animation = outAnimation as CssKeyframesTransition;\n viewTransitionService.setOutAnimation(\n `${animation.duration}ms ${animation.keyframesName} ${animation.reverse ? 'reverse' : ''}`,\n 'root'\n );\n }\n\n if ('keyframes' in outAnimation) {\n const animation = outAnimation as KeyframesTransition;\n const keyframesName = keyframesService.setKeyframes(animation.keyframes);\n viewTransitionService.setOutAnimation(\n `${animation.duration}ms ${keyframesName} ${animation.reverse ? 'reverse' : ''}`,\n 'root'\n );\n }\n };\n };\n\n return provideAppInitializer(() => {\n const initializerFn = factory(inject(ViewTransitionsService), inject(KeyframesService));\n return initializerFn();\n });\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -30,15 +30,15 @@
|
|
|
30
30
|
},
|
|
31
31
|
"sideEffects": false,
|
|
32
32
|
"module": "fesm2022/ngx-easy-view-transitions.mjs",
|
|
33
|
-
"typings": "
|
|
33
|
+
"typings": "types/ngx-easy-view-transitions.d.ts",
|
|
34
34
|
"exports": {
|
|
35
35
|
"./package.json": {
|
|
36
36
|
"default": "./package.json"
|
|
37
37
|
},
|
|
38
38
|
".": {
|
|
39
|
-
"types": "./
|
|
39
|
+
"types": "./types/ngx-easy-view-transitions.d.ts",
|
|
40
40
|
"default": "./fesm2022/ngx-easy-view-transitions.mjs"
|
|
41
41
|
}
|
|
42
42
|
},
|
|
43
|
-
"version": "3.1.
|
|
43
|
+
"version": "3.1.2"
|
|
44
44
|
}
|
|
@@ -0,0 +1,218 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { OnInit, EnvironmentProviders } from '@angular/core';
|
|
3
|
+
|
|
4
|
+
declare const none: Keyframe[];
|
|
5
|
+
declare const scaleIn: Keyframe[];
|
|
6
|
+
declare const scaleOut: Keyframe[];
|
|
7
|
+
declare const fadeIn: Keyframe[];
|
|
8
|
+
declare const fadeOut: Keyframe[];
|
|
9
|
+
declare const fadeInUp: Keyframe[];
|
|
10
|
+
declare const fadeOutUp: Keyframe[];
|
|
11
|
+
declare const fadeInDown: Keyframe[];
|
|
12
|
+
declare const fadeOutDown: Keyframe[];
|
|
13
|
+
declare const fadeInRight: Keyframe[];
|
|
14
|
+
declare const fadeOutRight: Keyframe[];
|
|
15
|
+
declare const fadeInLeft: Keyframe[];
|
|
16
|
+
declare const fadeOutLeft: Keyframe[];
|
|
17
|
+
declare const flipInX: Keyframe[];
|
|
18
|
+
declare const flipOutX: Keyframe[];
|
|
19
|
+
declare const flipInY: Keyframe[];
|
|
20
|
+
declare const flipOutY: Keyframe[];
|
|
21
|
+
declare const rotateIn: Keyframe[];
|
|
22
|
+
declare const rotateOut: Keyframe[];
|
|
23
|
+
declare const bounceIn: Keyframe[];
|
|
24
|
+
declare const bounceOut: Keyframe[];
|
|
25
|
+
declare const blurIn: Keyframe[];
|
|
26
|
+
declare const blurOut: Keyframe[];
|
|
27
|
+
declare const perspectiveIn: Keyframe[];
|
|
28
|
+
declare const perspectiveOut: Keyframe[];
|
|
29
|
+
declare const skewIn: Keyframe[];
|
|
30
|
+
declare const skewOut: Keyframe[];
|
|
31
|
+
declare const revealCircleIn: Keyframe[];
|
|
32
|
+
declare const revealCircleOut: Keyframe[];
|
|
33
|
+
declare const parallaxIn: Keyframe[];
|
|
34
|
+
declare const parallaxOut: Keyframe[];
|
|
35
|
+
declare const tiltIn: Keyframe[];
|
|
36
|
+
declare const tiltOut: Keyframe[];
|
|
37
|
+
declare const glitchIn: Keyframe[];
|
|
38
|
+
declare const curtainIn: Keyframe[];
|
|
39
|
+
declare const curtainOut: Keyframe[];
|
|
40
|
+
declare const depthFlipIn: Keyframe[];
|
|
41
|
+
declare const depthFlipOut: Keyframe[];
|
|
42
|
+
declare const distortWarpIn: Keyframe[];
|
|
43
|
+
declare const distortWarpOut: Keyframe[];
|
|
44
|
+
declare const coverFlipIn: Keyframe[];
|
|
45
|
+
declare const coverFlipOut: Keyframe[];
|
|
46
|
+
|
|
47
|
+
declare const defaultTransitions_d_blurIn: typeof blurIn;
|
|
48
|
+
declare const defaultTransitions_d_blurOut: typeof blurOut;
|
|
49
|
+
declare const defaultTransitions_d_bounceIn: typeof bounceIn;
|
|
50
|
+
declare const defaultTransitions_d_bounceOut: typeof bounceOut;
|
|
51
|
+
declare const defaultTransitions_d_coverFlipIn: typeof coverFlipIn;
|
|
52
|
+
declare const defaultTransitions_d_coverFlipOut: typeof coverFlipOut;
|
|
53
|
+
declare const defaultTransitions_d_curtainIn: typeof curtainIn;
|
|
54
|
+
declare const defaultTransitions_d_curtainOut: typeof curtainOut;
|
|
55
|
+
declare const defaultTransitions_d_depthFlipIn: typeof depthFlipIn;
|
|
56
|
+
declare const defaultTransitions_d_depthFlipOut: typeof depthFlipOut;
|
|
57
|
+
declare const defaultTransitions_d_distortWarpIn: typeof distortWarpIn;
|
|
58
|
+
declare const defaultTransitions_d_distortWarpOut: typeof distortWarpOut;
|
|
59
|
+
declare const defaultTransitions_d_fadeIn: typeof fadeIn;
|
|
60
|
+
declare const defaultTransitions_d_fadeInDown: typeof fadeInDown;
|
|
61
|
+
declare const defaultTransitions_d_fadeInLeft: typeof fadeInLeft;
|
|
62
|
+
declare const defaultTransitions_d_fadeInRight: typeof fadeInRight;
|
|
63
|
+
declare const defaultTransitions_d_fadeInUp: typeof fadeInUp;
|
|
64
|
+
declare const defaultTransitions_d_fadeOut: typeof fadeOut;
|
|
65
|
+
declare const defaultTransitions_d_fadeOutDown: typeof fadeOutDown;
|
|
66
|
+
declare const defaultTransitions_d_fadeOutLeft: typeof fadeOutLeft;
|
|
67
|
+
declare const defaultTransitions_d_fadeOutRight: typeof fadeOutRight;
|
|
68
|
+
declare const defaultTransitions_d_fadeOutUp: typeof fadeOutUp;
|
|
69
|
+
declare const defaultTransitions_d_flipInX: typeof flipInX;
|
|
70
|
+
declare const defaultTransitions_d_flipInY: typeof flipInY;
|
|
71
|
+
declare const defaultTransitions_d_flipOutX: typeof flipOutX;
|
|
72
|
+
declare const defaultTransitions_d_flipOutY: typeof flipOutY;
|
|
73
|
+
declare const defaultTransitions_d_glitchIn: typeof glitchIn;
|
|
74
|
+
declare const defaultTransitions_d_none: typeof none;
|
|
75
|
+
declare const defaultTransitions_d_parallaxIn: typeof parallaxIn;
|
|
76
|
+
declare const defaultTransitions_d_parallaxOut: typeof parallaxOut;
|
|
77
|
+
declare const defaultTransitions_d_perspectiveIn: typeof perspectiveIn;
|
|
78
|
+
declare const defaultTransitions_d_perspectiveOut: typeof perspectiveOut;
|
|
79
|
+
declare const defaultTransitions_d_revealCircleIn: typeof revealCircleIn;
|
|
80
|
+
declare const defaultTransitions_d_revealCircleOut: typeof revealCircleOut;
|
|
81
|
+
declare const defaultTransitions_d_rotateIn: typeof rotateIn;
|
|
82
|
+
declare const defaultTransitions_d_rotateOut: typeof rotateOut;
|
|
83
|
+
declare const defaultTransitions_d_scaleIn: typeof scaleIn;
|
|
84
|
+
declare const defaultTransitions_d_scaleOut: typeof scaleOut;
|
|
85
|
+
declare const defaultTransitions_d_skewIn: typeof skewIn;
|
|
86
|
+
declare const defaultTransitions_d_skewOut: typeof skewOut;
|
|
87
|
+
declare const defaultTransitions_d_tiltIn: typeof tiltIn;
|
|
88
|
+
declare const defaultTransitions_d_tiltOut: typeof tiltOut;
|
|
89
|
+
declare namespace defaultTransitions_d {
|
|
90
|
+
export {
|
|
91
|
+
defaultTransitions_d_blurIn as blurIn,
|
|
92
|
+
defaultTransitions_d_blurOut as blurOut,
|
|
93
|
+
defaultTransitions_d_bounceIn as bounceIn,
|
|
94
|
+
defaultTransitions_d_bounceOut as bounceOut,
|
|
95
|
+
defaultTransitions_d_coverFlipIn as coverFlipIn,
|
|
96
|
+
defaultTransitions_d_coverFlipOut as coverFlipOut,
|
|
97
|
+
defaultTransitions_d_curtainIn as curtainIn,
|
|
98
|
+
defaultTransitions_d_curtainOut as curtainOut,
|
|
99
|
+
defaultTransitions_d_depthFlipIn as depthFlipIn,
|
|
100
|
+
defaultTransitions_d_depthFlipOut as depthFlipOut,
|
|
101
|
+
defaultTransitions_d_distortWarpIn as distortWarpIn,
|
|
102
|
+
defaultTransitions_d_distortWarpOut as distortWarpOut,
|
|
103
|
+
defaultTransitions_d_fadeIn as fadeIn,
|
|
104
|
+
defaultTransitions_d_fadeInDown as fadeInDown,
|
|
105
|
+
defaultTransitions_d_fadeInLeft as fadeInLeft,
|
|
106
|
+
defaultTransitions_d_fadeInRight as fadeInRight,
|
|
107
|
+
defaultTransitions_d_fadeInUp as fadeInUp,
|
|
108
|
+
defaultTransitions_d_fadeOut as fadeOut,
|
|
109
|
+
defaultTransitions_d_fadeOutDown as fadeOutDown,
|
|
110
|
+
defaultTransitions_d_fadeOutLeft as fadeOutLeft,
|
|
111
|
+
defaultTransitions_d_fadeOutRight as fadeOutRight,
|
|
112
|
+
defaultTransitions_d_fadeOutUp as fadeOutUp,
|
|
113
|
+
defaultTransitions_d_flipInX as flipInX,
|
|
114
|
+
defaultTransitions_d_flipInY as flipInY,
|
|
115
|
+
defaultTransitions_d_flipOutX as flipOutX,
|
|
116
|
+
defaultTransitions_d_flipOutY as flipOutY,
|
|
117
|
+
defaultTransitions_d_glitchIn as glitchIn,
|
|
118
|
+
defaultTransitions_d_none as none,
|
|
119
|
+
defaultTransitions_d_parallaxIn as parallaxIn,
|
|
120
|
+
defaultTransitions_d_parallaxOut as parallaxOut,
|
|
121
|
+
defaultTransitions_d_perspectiveIn as perspectiveIn,
|
|
122
|
+
defaultTransitions_d_perspectiveOut as perspectiveOut,
|
|
123
|
+
defaultTransitions_d_revealCircleIn as revealCircleIn,
|
|
124
|
+
defaultTransitions_d_revealCircleOut as revealCircleOut,
|
|
125
|
+
defaultTransitions_d_rotateIn as rotateIn,
|
|
126
|
+
defaultTransitions_d_rotateOut as rotateOut,
|
|
127
|
+
defaultTransitions_d_scaleIn as scaleIn,
|
|
128
|
+
defaultTransitions_d_scaleOut as scaleOut,
|
|
129
|
+
defaultTransitions_d_skewIn as skewIn,
|
|
130
|
+
defaultTransitions_d_skewOut as skewOut,
|
|
131
|
+
defaultTransitions_d_tiltIn as tiltIn,
|
|
132
|
+
defaultTransitions_d_tiltOut as tiltOut,
|
|
133
|
+
};
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
/**
|
|
137
|
+
* Exclude an element from view transitions
|
|
138
|
+
*/
|
|
139
|
+
declare class NoTransitionDirective implements OnInit {
|
|
140
|
+
private readonly _el;
|
|
141
|
+
private readonly _rendererFactory;
|
|
142
|
+
private readonly _renderer;
|
|
143
|
+
private readonly _document;
|
|
144
|
+
ngOnInit(): void;
|
|
145
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NoTransitionDirective, never>;
|
|
146
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<NoTransitionDirective, "[noTransition]", never, {}, {}, never, never, true, never>;
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
/**
|
|
150
|
+
* Provide custom view transition animation via [`Keyframe`](https://developer.mozilla.org/en-US/docs/Web/API/Web_Animations_API/Keyframe_Formats) objects rule
|
|
151
|
+
*/
|
|
152
|
+
interface KeyframesTransition {
|
|
153
|
+
/**
|
|
154
|
+
* Animation in [`Keyframe`](https://developer.mozilla.org/en-US/docs/Web/API/Web_Animations_API/Keyframe_Formats) format
|
|
155
|
+
*/
|
|
156
|
+
keyframes: Keyframe[];
|
|
157
|
+
/**
|
|
158
|
+
* Duration of the transition in ms
|
|
159
|
+
*/
|
|
160
|
+
duration: number;
|
|
161
|
+
/**
|
|
162
|
+
* Wether the animation should be played reversed
|
|
163
|
+
*/
|
|
164
|
+
reverse?: boolean;
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
/**
|
|
168
|
+
* Provide custom animation via CSS [`@keyframes`](https://developer.mozilla.org/en-US/docs/Web/CSS/@keyframes) rule
|
|
169
|
+
*/
|
|
170
|
+
interface CssKeyframesTransition {
|
|
171
|
+
/**
|
|
172
|
+
* Name of the CSS [`@keyframes`](https://developer.mozilla.org/en-US/docs/Web/CSS/@keyframes) rule
|
|
173
|
+
*/
|
|
174
|
+
keyframesName: string;
|
|
175
|
+
/**
|
|
176
|
+
* Duration of the transition in ms
|
|
177
|
+
*/
|
|
178
|
+
duration: number;
|
|
179
|
+
/**
|
|
180
|
+
* Wether the animation should be played reversed
|
|
181
|
+
*/
|
|
182
|
+
reverse?: boolean;
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
/**
|
|
186
|
+
* Configure view transitions for the element
|
|
187
|
+
*/
|
|
188
|
+
declare class TransitionNameDirective {
|
|
189
|
+
/**
|
|
190
|
+
* Set the `view-transition-name` property to assign transitions to that element
|
|
191
|
+
*/
|
|
192
|
+
transitionName: i0.InputSignal<string>;
|
|
193
|
+
/**
|
|
194
|
+
* Configure the animation when the element enters the view
|
|
195
|
+
*/
|
|
196
|
+
inAnimation: i0.InputSignal<KeyframesTransition | CssKeyframesTransition | undefined>;
|
|
197
|
+
/**
|
|
198
|
+
* Configure the animation when the element leaves the view
|
|
199
|
+
*/
|
|
200
|
+
outAnimation: i0.InputSignal<KeyframesTransition | CssKeyframesTransition | undefined>;
|
|
201
|
+
private readonly _el;
|
|
202
|
+
private readonly _renderer;
|
|
203
|
+
private readonly _keyframesService;
|
|
204
|
+
private readonly _viewTransitionsService;
|
|
205
|
+
constructor();
|
|
206
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TransitionNameDirective, never>;
|
|
207
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TransitionNameDirective, "[transitionName]", never, { "transitionName": { "alias": "transitionName"; "required": true; "isSignal": true; }; "inAnimation": { "alias": "inAnimation"; "required": false; "isSignal": true; }; "outAnimation": { "alias": "outAnimation"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
/**
|
|
211
|
+
* Override the default View Transition API cross-fade animation
|
|
212
|
+
* @param inAnimation
|
|
213
|
+
* @param outAnimation
|
|
214
|
+
*/
|
|
215
|
+
declare function provideDefaultViewTransition(inAnimation: KeyframesTransition | CssKeyframesTransition, outAnimation: KeyframesTransition | CssKeyframesTransition): EnvironmentProviders;
|
|
216
|
+
|
|
217
|
+
export { defaultTransitions_d as DefaultTransitions, NoTransitionDirective, TransitionNameDirective, provideDefaultViewTransition };
|
|
218
|
+
export type { CssKeyframesTransition, KeyframesTransition };
|
package/index.d.ts
DELETED
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
export * as DefaultTransitions from './lib/default-transitions';
|
|
2
|
-
export * from './lib/no-transition.directive';
|
|
3
|
-
export * from './lib/transition-name.directive';
|
|
4
|
-
export * from './lib/default-view-transition.provider';
|
|
5
|
-
export { KeyframesTransition } from './lib/keyframes-transition';
|
|
6
|
-
export { CssKeyframesTransition } from './lib/css-keyframes-transition';
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Provide custom animation via CSS [`@keyframes`](https://developer.mozilla.org/en-US/docs/Web/CSS/@keyframes) rule
|
|
3
|
-
*/
|
|
4
|
-
export interface CssKeyframesTransition {
|
|
5
|
-
/**
|
|
6
|
-
* Name of the CSS [`@keyframes`](https://developer.mozilla.org/en-US/docs/Web/CSS/@keyframes) rule
|
|
7
|
-
*/
|
|
8
|
-
keyframesName: string;
|
|
9
|
-
/**
|
|
10
|
-
* Duration of the transition in ms
|
|
11
|
-
*/
|
|
12
|
-
duration: number;
|
|
13
|
-
/**
|
|
14
|
-
* Wether the animation should be played reversed
|
|
15
|
-
*/
|
|
16
|
-
reverse?: boolean;
|
|
17
|
-
}
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
export declare const none: Keyframe[];
|
|
2
|
-
export declare const scaleIn: Keyframe[];
|
|
3
|
-
export declare const scaleOut: Keyframe[];
|
|
4
|
-
export declare const fadeIn: Keyframe[];
|
|
5
|
-
export declare const fadeOut: Keyframe[];
|
|
6
|
-
export declare const fadeInUp: Keyframe[];
|
|
7
|
-
export declare const fadeOutUp: Keyframe[];
|
|
8
|
-
export declare const fadeInDown: Keyframe[];
|
|
9
|
-
export declare const fadeOutDown: Keyframe[];
|
|
10
|
-
export declare const fadeInRight: Keyframe[];
|
|
11
|
-
export declare const fadeOutRight: Keyframe[];
|
|
12
|
-
export declare const fadeInLeft: Keyframe[];
|
|
13
|
-
export declare const fadeOutLeft: Keyframe[];
|
|
14
|
-
export declare const flipInX: Keyframe[];
|
|
15
|
-
export declare const flipOutX: Keyframe[];
|
|
16
|
-
export declare const flipInY: Keyframe[];
|
|
17
|
-
export declare const flipOutY: Keyframe[];
|
|
18
|
-
export declare const rotateIn: Keyframe[];
|
|
19
|
-
export declare const rotateOut: Keyframe[];
|
|
20
|
-
export declare const bounceIn: Keyframe[];
|
|
21
|
-
export declare const bounceOut: Keyframe[];
|
|
22
|
-
export declare const blurIn: Keyframe[];
|
|
23
|
-
export declare const blurOut: Keyframe[];
|
|
24
|
-
export declare const perspectiveIn: Keyframe[];
|
|
25
|
-
export declare const perspectiveOut: Keyframe[];
|
|
26
|
-
export declare const skewIn: Keyframe[];
|
|
27
|
-
export declare const skewOut: Keyframe[];
|
|
28
|
-
export declare const revealCircleIn: Keyframe[];
|
|
29
|
-
export declare const revealCircleOut: Keyframe[];
|
|
30
|
-
export declare const parallaxIn: Keyframe[];
|
|
31
|
-
export declare const parallaxOut: Keyframe[];
|
|
32
|
-
export declare const tiltIn: Keyframe[];
|
|
33
|
-
export declare const tiltOut: Keyframe[];
|
|
34
|
-
export declare const glitchIn: Keyframe[];
|
|
35
|
-
export declare const curtainIn: Keyframe[];
|
|
36
|
-
export declare const curtainOut: Keyframe[];
|
|
37
|
-
export declare const depthFlipIn: Keyframe[];
|
|
38
|
-
export declare const depthFlipOut: Keyframe[];
|
|
39
|
-
export declare const distortWarpIn: Keyframe[];
|
|
40
|
-
export declare const distortWarpOut: Keyframe[];
|
|
41
|
-
export declare const coverFlipIn: Keyframe[];
|
|
42
|
-
export declare const coverFlipOut: Keyframe[];
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { EnvironmentProviders } from '@angular/core';
|
|
2
|
-
import { KeyframesTransition } from './keyframes-transition';
|
|
3
|
-
import { CssKeyframesTransition } from './css-keyframes-transition';
|
|
4
|
-
/**
|
|
5
|
-
* Override the default View Transition API cross-fade animation
|
|
6
|
-
* @param inAnimation
|
|
7
|
-
* @param outAnimation
|
|
8
|
-
*/
|
|
9
|
-
export declare function provideDefaultViewTransition(inAnimation: KeyframesTransition | CssKeyframesTransition, outAnimation: KeyframesTransition | CssKeyframesTransition): EnvironmentProviders;
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Provide custom view transition animation via [`Keyframe`](https://developer.mozilla.org/en-US/docs/Web/API/Web_Animations_API/Keyframe_Formats) objects rule
|
|
3
|
-
*/
|
|
4
|
-
export interface KeyframesTransition {
|
|
5
|
-
/**
|
|
6
|
-
* Animation in [`Keyframe`](https://developer.mozilla.org/en-US/docs/Web/API/Web_Animations_API/Keyframe_Formats) format
|
|
7
|
-
*/
|
|
8
|
-
keyframes: Keyframe[];
|
|
9
|
-
/**
|
|
10
|
-
* Duration of the transition in ms
|
|
11
|
-
*/
|
|
12
|
-
duration: number;
|
|
13
|
-
/**
|
|
14
|
-
* Wether the animation should be played reversed
|
|
15
|
-
*/
|
|
16
|
-
reverse?: boolean;
|
|
17
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { OnInit } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
/**
|
|
4
|
-
* Exclude an element from view transitions
|
|
5
|
-
*/
|
|
6
|
-
export declare class NoTransitionDirective implements OnInit {
|
|
7
|
-
private readonly _el;
|
|
8
|
-
private readonly _rendererFactory;
|
|
9
|
-
private readonly _renderer;
|
|
10
|
-
private readonly _document;
|
|
11
|
-
ngOnInit(): void;
|
|
12
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<NoTransitionDirective, never>;
|
|
13
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<NoTransitionDirective, "[noTransition]", never, {}, {}, never, never, true, never>;
|
|
14
|
-
}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { KeyframesTransition } from './keyframes-transition';
|
|
2
|
-
import { CssKeyframesTransition } from './css-keyframes-transition';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
/**
|
|
5
|
-
* Configure view transitions for the element
|
|
6
|
-
*/
|
|
7
|
-
export declare class TransitionNameDirective {
|
|
8
|
-
/**
|
|
9
|
-
* Set the `view-transition-name` property to assign transitions to that element
|
|
10
|
-
*/
|
|
11
|
-
transitionName: import("@angular/core").InputSignal<string>;
|
|
12
|
-
/**
|
|
13
|
-
* Configure the animation when the element enters the view
|
|
14
|
-
*/
|
|
15
|
-
inAnimation: import("@angular/core").InputSignal<KeyframesTransition | CssKeyframesTransition | undefined>;
|
|
16
|
-
/**
|
|
17
|
-
* Configure the animation when the element leaves the view
|
|
18
|
-
*/
|
|
19
|
-
outAnimation: import("@angular/core").InputSignal<KeyframesTransition | CssKeyframesTransition | undefined>;
|
|
20
|
-
private readonly _el;
|
|
21
|
-
private readonly _keyframesService;
|
|
22
|
-
private readonly _viewTransitionsService;
|
|
23
|
-
constructor();
|
|
24
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<TransitionNameDirective, never>;
|
|
25
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<TransitionNameDirective, "[transitionName]", never, { "transitionName": { "alias": "transitionName"; "required": true; "isSignal": true; }; "inAnimation": { "alias": "inAnimation"; "required": false; "isSignal": true; }; "outAnimation": { "alias": "outAnimation"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
|
|
26
|
-
}
|
package/lib/utils.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|