/* 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 . */ "use strict"; const React = require("react"); const {Link} = require("wouter"); const splitFilterN = require("split-filter-n"); const NewEmojiForm = require("./new-emoji"); const query = require("../../lib/query"); const base = "/settings/admin/custom-emoji"; module.exports = function EmojiOverview() { const { data: emoji = [], isLoading, error } = query.useGetAllEmojiQuery({filter: "domain:local"}); // split all emoji over an object keyed by the category names (or Unsorted) const emojiByCategory = React.useMemo(() => splitFilterN( emoji, [], (entry) => entry.category ?? "Unsorted" ), [emoji]); return ( <>

Custom Emoji

{error &&
{error}
} {isLoading ? "Loading..." : <> } ); }; function EmojiList({emoji, emojiByCategory}) { return (

Overview

{emoji.length == 0 && "No local emoji yet, add one below"} {Object.entries(emojiByCategory).map(([category, entries]) => { return ; })}
); } function EmojiCategory({category, entries}) { return (
{category}
{entries.map((e) => { return ( {/* */} {e.shortcode} ); })}
); }