From 7a1e6394831fb07e303c5ed0900dfe1ea4820de5 Mon Sep 17 00:00:00 2001 From: tobi <31960611+tsmethurst@users.noreply.github.com> Date: Wed, 24 Apr 2024 12:12:47 +0200 Subject: [chore] Refactor settings panel routing (and other fixes) (#2864) --- .../settings/views/admin/emoji/remote/index.tsx | 46 ++++ .../views/admin/emoji/remote/steal-this-look.tsx | 235 +++++++++++++++++++++ 2 files changed, 281 insertions(+) create mode 100644 web/source/settings/views/admin/emoji/remote/index.tsx create mode 100644 web/source/settings/views/admin/emoji/remote/steal-this-look.tsx (limited to 'web/source/settings/views/admin/emoji/remote') diff --git a/web/source/settings/views/admin/emoji/remote/index.tsx b/web/source/settings/views/admin/emoji/remote/index.tsx new file mode 100644 index 000000000..5521d1115 --- /dev/null +++ b/web/source/settings/views/admin/emoji/remote/index.tsx @@ -0,0 +1,46 @@ +/* + GoToSocial + Copyright (C) GoToSocial Authors admin@gotosocial.org + SPDX-License-Identifier: AGPL-3.0-or-later + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU Affero General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU Affero General Public License for more details. + + You should have received a copy of the GNU Affero General Public License + along with this program. If not, see . +*/ + +import React, { useMemo } from "react"; + +import StealThisLook from "./steal-this-look"; + +import Loading from "../../../../components/loading"; +import { Error } from "../../../../components/error"; +import { useListEmojiQuery } from "../../../../lib/query/admin/custom-emoji"; + +export default function RemoteEmoji() { + // Local emoji are queried for + // shortcode collision detection + const { + data: emoji = [], + isLoading, + error + } = useListEmojiQuery({ filter: "domain:local" }); + + const emojiCodes = useMemo(() => new Set(emoji.map((e) => e.shortcode)), [emoji]); + + return ( + <> +

Custom Emoji (remote)

+ {error && } + {isLoading ? : } + + ); +} diff --git a/web/source/settings/views/admin/emoji/remote/steal-this-look.tsx b/web/source/settings/views/admin/emoji/remote/steal-this-look.tsx new file mode 100644 index 000000000..43d0b83e1 --- /dev/null +++ b/web/source/settings/views/admin/emoji/remote/steal-this-look.tsx @@ -0,0 +1,235 @@ +/* + GoToSocial + Copyright (C) GoToSocial Authors admin@gotosocial.org + SPDX-License-Identifier: AGPL-3.0-or-later + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU Affero General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU Affero General Public License for more details. + + You should have received a copy of the GNU Affero General Public License + along with this program. If not, see . +*/ + +import React, { useCallback, useEffect } from "react"; + +import { useTextInput, useComboBoxInput, useCheckListInput } from "../../../../lib/form"; + +import useFormSubmit from "../../../../lib/form/submit"; + +import CheckList from "../../../../components/check-list"; +import { CategorySelect } from '../category-select'; + +import { TextInput } from "../../../../components/form/inputs"; +import MutationButton from "../../../../components/form/mutation-button"; +import { Error } from "../../../../components/error"; +import { useSearchItemForEmojiMutation, usePatchRemoteEmojisMutation } from "../../../../lib/query/admin/custom-emoji"; + +export default function StealThisLook({ emojiCodes }) { + const [searchStatus, result] = useSearchItemForEmojiMutation(); + const urlField = useTextInput("url"); + + function submitSearch(e) { + e.preventDefault(); + if (urlField.value !== undefined && urlField.value.trim().length != 0) { + searchStatus(urlField.value); + } + } + + return ( +
+

Steal this look

+
+
+ +
+ +