feat: 实现前端资源管理
This commit is contained in:
@@ -1,10 +1,10 @@
|
||||
import { ResourceBadge } from "@/components/resource";
|
||||
import { Card, CardContent } from "@/components/ui/card";
|
||||
import { Resource } from "@/lib/types/resource";
|
||||
import { PublicResource } from "@/lib/types/resource";
|
||||
import ResourceCardImage from "./ResourceCardImage";
|
||||
|
||||
interface ResourceCardProps extends React.HTMLProps<HTMLAnchorElement> {
|
||||
r: Resource;
|
||||
r: PublicResource;
|
||||
}
|
||||
|
||||
export function ResourceCard({ r, ...props }: ResourceCardProps) {
|
||||
|
||||
@@ -9,9 +9,9 @@ import { UserInfoEditor } from "./components/user-info-editor";
|
||||
import { User } from "@/lib/types/user";
|
||||
import { CreateUserEditor } from "./components/create-user-editor";
|
||||
import { AlertDialog, AlertDialogAction, AlertDialogCancel, AlertDialogContent, AlertDialogDescription, AlertDialogFooter, AlertDialogHeader, AlertDialogTitle } from "@/components/ui/alert-dialog";
|
||||
import { AdminApi } from "@/lib/api";
|
||||
import { toast } from "sonner";
|
||||
import { ApiError } from "next/dist/server/api-utils";
|
||||
import { AdminAPI } from "@/lib/api/client";
|
||||
|
||||
|
||||
export default function Page() {
|
||||
@@ -56,7 +56,7 @@ export default function Page() {
|
||||
const [deletedUserId, setDeletedUserId] = useState('');
|
||||
const handleUserDelete = async (userId: string) => {
|
||||
try {
|
||||
await AdminApi.user.remove(userId, false);
|
||||
await AdminAPI.removeUser(userId, false);
|
||||
toast.success('删除成功');
|
||||
handleUserDeleteLocal(userId, false);
|
||||
setDeletedUserId('');
|
||||
|
||||
@@ -13,13 +13,13 @@ import {
|
||||
import { Input } from "@/components/ui/input"
|
||||
import { Label } from "@/components/ui/label"
|
||||
import { Button } from "@/components/ui/button"
|
||||
import { AdminApi } from "@/lib/api"
|
||||
import { toast } from "sonner"
|
||||
import { ApiError } from "next/dist/server/api-utils"
|
||||
import { ResourceBadge } from "@/components/resource"
|
||||
import AddResourceTag from "./AddResourceTag"
|
||||
import { Textarea } from "@/components/ui/textarea"
|
||||
import { Plus } from "lucide-react"
|
||||
import { AdminAPI } from "@/lib/api/client"
|
||||
|
||||
|
||||
interface AddResourceProps {
|
||||
@@ -42,7 +42,7 @@ export default function AddResource({ children, refresh }: AddResourceProps) {
|
||||
const handleSubmit = async () => {
|
||||
try {
|
||||
setLoading(true);
|
||||
await AdminApi.web.resource.create({
|
||||
await AdminAPI.createResource({
|
||||
...formData,
|
||||
});
|
||||
toast.success("添加成功");
|
||||
|
||||
@@ -18,7 +18,6 @@ import AddResourceTag from "./AddResourceTag"
|
||||
import { Textarea } from "@/components/ui/textarea"
|
||||
import { Plus } from "lucide-react"
|
||||
import { Resource } from "@/lib/types/resource"
|
||||
import { AdminApi } from "@/lib/api"
|
||||
import useSWR from "swr"
|
||||
import { ApiError } from "next/dist/server/api-utils"
|
||||
import { Skeleton } from "@/components/ui/skeleton"
|
||||
@@ -33,6 +32,7 @@ import {
|
||||
AlertDialogTitle,
|
||||
AlertDialogTrigger,
|
||||
} from "@/components/ui/alert-dialog"
|
||||
import { AdminAPI } from "@/lib/api/client"
|
||||
|
||||
interface ResourceEditProps {
|
||||
children: React.ReactNode
|
||||
@@ -45,7 +45,7 @@ export default function ResourceEdit({ children, id, onRefresh }: ResourceEditPr
|
||||
|
||||
const { data: resource, isLoading, mutate } = useSWR<Resource>(
|
||||
open ? [`/api/admin/web/resource/${id}`] : null,
|
||||
() => AdminApi.web.resource.get(id),
|
||||
() => AdminAPI.getResource(id),
|
||||
{
|
||||
revalidateOnFocus: false,
|
||||
revalidateOnReconnect: false,
|
||||
@@ -57,7 +57,7 @@ export default function ResourceEdit({ children, id, onRefresh }: ResourceEditPr
|
||||
const handleSubmit = async () => {
|
||||
if (!resource) return;
|
||||
try {
|
||||
await AdminApi.web.resource.update(id, {
|
||||
await AdminAPI.updateResource(id, {
|
||||
title: resource.title,
|
||||
description: resource.description,
|
||||
imageUrl: resource.imageUrl,
|
||||
@@ -74,7 +74,7 @@ export default function ResourceEdit({ children, id, onRefresh }: ResourceEditPr
|
||||
|
||||
const handleRemove = async (id: string) => {
|
||||
try {
|
||||
await AdminApi.web.resource.remove(id);
|
||||
await AdminAPI.removeResource(id);
|
||||
toast.success("资源删除成功");
|
||||
onRefresh();
|
||||
setOpen(false);
|
||||
|
||||
Reference in New Issue
Block a user