summaryrefslogtreecommitdiff
path: root/web/source/settings/admin/emoji/detail.js
diff options
context:
space:
mode:
authorLibravatar f0x52 <f0x@cthu.lu>2022-12-11 16:00:23 +0100
committerLibravatar GitHub <noreply@github.com>2022-12-11 16:00:23 +0100
commit4b8d7bd952dd97091d1baddeab10213e9c38cef3 (patch)
tree368b80e82590ca85c031b9d720dc7dd7c4fbbb6b /web/source/settings/admin/emoji/detail.js
parent[docs] Serve static assets with nginx (#1251) (diff)
downloadgotosocial-4b8d7bd952dd97091d1baddeab10213e9c38cef3.tar.xz
[frogend] Emoji copy "Steal this look" (#1222)
* split emoji into local and remote, allow looking up remote emoji by toot url * optimize some/all filtering * fix local emoji routes * implement copy action * shortcode validation, don't wipe form on error * copy & disable PATCH * remove local toot acceptance for testing * unused import * parse emoji from account and status, get web_url from status uri * fix url parse * submit button loading info * actually send category * code cleanup, distinguish between account and status responses * use loading icons * fix loading icon on federation page * require Loading element * remove unused require * query explanation, small accessibility tweaks
Diffstat (limited to 'web/source/settings/admin/emoji/detail.js')
-rw-r--r--web/source/settings/admin/emoji/detail.js168
1 files changed, 0 insertions, 168 deletions
diff --git a/web/source/settings/admin/emoji/detail.js b/web/source/settings/admin/emoji/detail.js
deleted file mode 100644
index 51e291448..000000000
--- a/web/source/settings/admin/emoji/detail.js
+++ /dev/null
@@ -1,168 +0,0 @@
-/*
- GoToSocial
- Copyright (C) 2021-2022 GoToSocial Authors admin@gotosocial.org
-
- 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 <http://www.gnu.org/licenses/>.
-*/
-
-"use strict";
-
-const React = require("react");
-
-const { useRoute, Link, Redirect } = require("wouter");
-
-const { CategorySelect } = require("./category-select");
-const { useComboBoxInput, useFileInput } = require("../../components/form");
-
-const query = require("../../lib/query");
-const FakeToot = require("../../components/fake-toot");
-
-const base = "/settings/admin/custom-emoji";
-
-module.exports = function EmojiDetailRoute() {
- let [_match, params] = useRoute(`${base}/:emojiId`);
- if (params?.emojiId == undefined) {
- return <Redirect to={base}/>;
- } else {
- return (
- <div className="emoji-detail">
- <Link to={base}><a>&lt; go back</a></Link>
- <EmojiDetailData emojiId={params.emojiId}/>
- </div>
- );
- }
-};
-
-function EmojiDetailData({emojiId}) {
- const {currentData: emoji, isLoading, error} = query.useGetEmojiQuery(emojiId);
-
- if (error) {
- return (
- <div className="error accent">
- {error.status}: {error.data.error}
- </div>
- );
- } else if (isLoading) {
- return "Loading...";
- } else {
- return <EmojiDetail emoji={emoji}/>;
- }
-}
-
-function EmojiDetail({emoji}) {
- const [modifyEmoji, modifyResult] = query.useEditEmojiMutation();
-
- const [isNewCategory, setIsNewCategory] = React.useState(false);
-
- const [categoryState, _resetCategory, { category }] = useComboBoxInput("category", {defaultValue: emoji.category});
-
- const [onFileChange, _resetFile, { image, imageURL, imageInfo }] = useFileInput("image", {
- withPreview: true,
- maxSize: 50 * 1024
- });
-
- function modifyCategory() {
- modifyEmoji({id: emoji.id, category: category.trim()});
- }
-
- function modifyImage() {
- modifyEmoji({id: emoji.id, image: image});
- }
-
- React.useEffect(() => {
- if (category != emoji.category && !categoryState.open && !isNewCategory && category.trim().length > 0) {
- console.log("updating to", category);
- modifyEmoji({id: emoji.id, category: category.trim()});
- }
- }, [isNewCategory, category, categoryState.open, emoji.category, emoji.id, modifyEmoji]);
-
- return (
- <>
- <div className="emoji-header">
- <img src={emoji.url} alt={emoji.shortcode} title={emoji.shortcode}/>
- <div>
- <h2>{emoji.shortcode}</h2>
- <DeleteButton id={emoji.id}/>
- </div>
- </div>
-
- <div className="left-border">
- <h2>Modify this emoji {modifyResult.isLoading && "(processing..)"}</h2>
-
- {modifyResult.error && <div className="error">
- {modifyResult.error.status}: {modifyResult.error.data.error}
- </div>}
-
- <div className="update-category">
- <CategorySelect
- value={category}
- categoryState={categoryState}
- setIsNew={setIsNewCategory}
- >
- <button style={{visibility: (isNewCategory ? "initial" : "hidden")}} onClick={modifyCategory}>
- Create
- </button>
- </CategorySelect>
- </div>
-
- <div className="update-image">
- <b>Image</b>
- <div className="form-field file">
- <label className="file-input button" htmlFor="image">
- Browse
- </label>
- {imageInfo}
- <input
- className="hidden"
- type="file"
- id="image"
- name="Image"
- accept="image/png,image/gif"
- onChange={onFileChange}
- />
- </div>
-
- <button onClick={modifyImage} disabled={image == undefined}>Replace image</button>
-
- <FakeToot>
- Look at this new custom emoji <img
- className="emoji"
- src={imageURL ?? emoji.url}
- title={`:${emoji.shortcode}:`}
- alt={emoji.shortcode}
- /> isn&apos;t it cool?
- </FakeToot>
- </div>
- </div>
- </>
- );
-}
-
-function DeleteButton({id}) {
- // TODO: confirmation dialog?
- const [deleteEmoji, deleteResult] = query.useDeleteEmojiMutation();
-
- let text = "Delete";
- if (deleteResult.isLoading) {
- text = "Deleting...";
- }
-
- if (deleteResult.isSuccess) {
- return <Redirect to={base}/>;
- }
-
- return (
- <button className="danger" onClick={() => deleteEmoji(id)} disabled={deleteResult.isLoading}>{text}</button>
- );
-} \ No newline at end of file