Release v4.1 (#229)

* refactor: remove custom icon packs

* fix: command not work on windows

* fix: make open_window command async

* feat: improve commands

* feat: improve

* refactor: column

* feat: improve thread column

* feat: improve

* feat: add stories column

* feat: improve

* feat: add search column

* feat: add reset password

* feat: add subscription

* refactor: settings

* chore: improve commands

* fix: crash on production

* feat: use tauri store plugin for cache

* feat: new icon

* chore: update icon for windows

* chore: improve some columns

* chore: polish code
This commit is contained in:
雨宮蓮
2024-08-27 19:37:30 +07:00
committed by GitHub
parent 26ae473521
commit 61ad96ca63
318 changed files with 5564 additions and 8458 deletions

View File

@@ -1,7 +1,9 @@
import { commands } from "@/commands.gen";
import { cn } from "@/commons";
import { Spinner } from "@/components";
import { NostrAccount } from "@/system";
import { useEffect, useState } from "react";
import { message } from "@tauri-apps/plugin-dialog";
import { useEffect, useState, useTransition } from "react";
import { useUserContext } from "./provider";
export function UserFollowButton({
@@ -13,18 +15,20 @@ export function UserFollowButton({
}) {
const user = useUserContext();
const [loading, setLoading] = useState(false);
const [followed, setFollowed] = useState(false);
const [isPending, startTransition] = useTransition();
const toggleFollow = async () => {
setLoading(true);
const toggleFollow = () => {
startTransition(async () => {
const res = await commands.toggleContact(user.pubkey, null);
const toggle = await NostrAccount.toggleContact(user.pubkey);
if (toggle) {
setFollowed((prev) => !prev);
setLoading(false);
}
if (res.status === "ok") {
setFollowed((prev) => !prev);
} else {
await message(res.error, { kind: "error" });
return;
}
});
};
useEffect(() => {
@@ -42,11 +46,11 @@ export function UserFollowButton({
return (
<button
type="button"
disabled={loading}
disabled={isPending}
onClick={() => toggleFollow()}
className={cn("w-max", className)}
>
{loading ? (
{isPending ? (
<Spinner className="size-4" />
) : followed ? (
!simple ? (