1
0
Fork 0
mirror of https://github.com/sussy-code/smov.git synced 2025-01-20 02:21:25 +01:00

fix more transitions

This commit is contained in:
Jelle van Snik 2023-02-07 20:03:01 +01:00
parent 6224fb32c4
commit 3b4e9ce2ca

View file

@ -1,4 +1,4 @@
import { ReactNode } from "react"; import { Fragment, ReactNode } from "react";
import { import {
Transition as HeadlessTransition, Transition as HeadlessTransition,
TransitionClasses, TransitionClasses,
@ -16,15 +16,14 @@ interface Props {
function getClasses( function getClasses(
animation: TransitionAnimations, animation: TransitionAnimations,
extraClasses: string,
duration: string duration: string
): TransitionClasses { ): TransitionClasses {
if (animation === "slide-down") { if (animation === "slide-down") {
return { return {
leave: `transition-[transform,opacity] ${duration} ${extraClasses}`, leave: `transition-[transform,opacity] ${duration}`,
leaveFrom: "opacity-100 translate-y-0", leaveFrom: "opacity-100 translate-y-0",
leaveTo: "-translate-y-4 opacity-0", leaveTo: "-translate-y-4 opacity-0",
enter: `transition-[transform,opacity] ${duration} ${extraClasses}`, enter: `transition-[transform,opacity] ${duration}`,
enterFrom: "opacity-0 -translate-y-4", enterFrom: "opacity-0 -translate-y-4",
enterTo: "translate-y-0 opacity-100", enterTo: "translate-y-0 opacity-100",
}; };
@ -32,10 +31,10 @@ function getClasses(
if (animation === "slide-up") { if (animation === "slide-up") {
return { return {
leave: `transition-[transform,opacity] ${duration} ${extraClasses}`, leave: `transition-[transform,opacity] ${duration}`,
leaveFrom: "opacity-100 translate-y-0", leaveFrom: "opacity-100 translate-y-0",
leaveTo: "translate-y-4 opacity-0", leaveTo: "translate-y-4 opacity-0",
enter: `transition-[transform,opacity] ${duration} ${extraClasses}`, enter: `transition-[transform,opacity] ${duration}`,
enterFrom: "opacity-0 translate-y-4", enterFrom: "opacity-0 translate-y-4",
enterTo: "translate-y-0 opacity-100", enterTo: "translate-y-0 opacity-100",
}; };
@ -43,10 +42,10 @@ function getClasses(
if (animation === "fade") { if (animation === "fade") {
return { return {
leave: `transition-[transform,opacity] ${duration} ${extraClasses}`, leave: `transition-[transform,opacity] ${duration}`,
leaveFrom: "opacity-100", leaveFrom: "opacity-100",
leaveTo: "opacity-0", leaveTo: "opacity-0",
enter: `transition-[transform,opacity] ${duration} ${extraClasses}`, enter: `transition-[transform,opacity] ${duration}`,
enterFrom: "opacity-0", enterFrom: "opacity-0",
enterTo: "opacity-100", enterTo: "opacity-100",
}; };
@ -57,15 +56,11 @@ function getClasses(
export function Transition(props: Props) { export function Transition(props: Props) {
const duration = props.durationClass ?? "duration-200"; const duration = props.durationClass ?? "duration-200";
const classes = getClasses(props.animation, props.className ?? "", duration); const classes = getClasses(props.animation, duration);
return ( return (
<HeadlessTransition <HeadlessTransition show={props.show} as={Fragment} {...classes}>
show={props.show} <div className={props.className}>{props.children}</div>
{...classes}
entered={props.className}
>
{props.children}
</HeadlessTransition> </HeadlessTransition>
); );
} }