mirror of
https://github.com/movie-web/movie-web.git
synced 2024-11-14 08:45:08 +01:00
Merge pull request #975 from qtchaos/fix/button-navigate
When navigating to own pages, use `useNavigate()`
This commit is contained in:
commit
27aff99969
@ -1,5 +1,6 @@
|
||||
import classNames from "classnames";
|
||||
import { ReactNode, useCallback } from "react";
|
||||
import { useNavigate } from "react-router-dom";
|
||||
|
||||
import { Icon, Icons } from "@/components/Icon";
|
||||
import { Spinner } from "@/components/layout/Spinner";
|
||||
@ -20,6 +21,7 @@ interface Props {
|
||||
}
|
||||
|
||||
export function Button(props: Props) {
|
||||
const navigate = useNavigate();
|
||||
const { onClick, href, loading } = props;
|
||||
const cb = useCallback(
|
||||
(
|
||||
@ -31,10 +33,14 @@ export function Button(props: Props) {
|
||||
if (loading) return;
|
||||
if (href && !onClick) {
|
||||
event.preventDefault();
|
||||
if (!href.includes("http")) {
|
||||
navigate(href);
|
||||
} else {
|
||||
window.open(href, "_blank", "noreferrer");
|
||||
}
|
||||
} else onClick?.(event);
|
||||
},
|
||||
[onClick, href, loading],
|
||||
[loading, href, onClick, navigate],
|
||||
);
|
||||
|
||||
let colorClasses = "bg-white hover:bg-gray-200 text-black";
|
||||
|
Loading…
Reference in New Issue
Block a user