summaryrefslogtreecommitdiff
path: root/web/source/settings-panel/redux/reducers/admin.js
diff options
context:
space:
mode:
authorLibravatar f0x52 <f0x@cthu.lu>2022-10-03 16:46:38 +0200
committerLibravatar GitHub <noreply@github.com>2022-10-03 16:46:38 +0200
commit5249294a166c901469eeac1d3297e913b4a125e7 (patch)
treed68ff7bebbc0135d23c18520417c668155aa56f2 /web/source/settings-panel/redux/reducers/admin.js
parent[performance] add user cache and database (#879) (diff)
downloadgotosocial-5249294a166c901469eeac1d3297e913b4a125e7.tar.xz
[chore] Bundler restructure (#880)
* re-structure bundler, settings panel files * add more info logging * tidy up CSS syntax errors * split into lib/ files * livereloading server * fix factor function for production builds * remove testing console.log * default to production env, saves 300kb bundle size
Diffstat (limited to 'web/source/settings-panel/redux/reducers/admin.js')
-rw-r--r--web/source/settings-panel/redux/reducers/admin.js131
1 files changed, 0 insertions, 131 deletions
diff --git a/web/source/settings-panel/redux/reducers/admin.js b/web/source/settings-panel/redux/reducers/admin.js
deleted file mode 100644
index 20d3d748d..000000000
--- a/web/source/settings-panel/redux/reducers/admin.js
+++ /dev/null
@@ -1,131 +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 { createSlice } = require("@reduxjs/toolkit");
-const defaultValue = require("default-value");
-
-function sortBlocks(blocks) {
- return blocks.sort((a, b) => { // alphabetical sort
- return a.domain.localeCompare(b.domain);
- });
-}
-
-function emptyBlock() {
- return {
- public_comment: "",
- private_comment: "",
- obfuscate: false
- };
-}
-
-function emptyEmojiForm() {
- return {
- shortcode: ""
- };
-}
-
-module.exports = createSlice({
- name: "admin",
- initialState: {
- loadedBlockedInstances: false,
- blockedInstances: undefined,
- bulkBlock: {
- list: "",
- exportType: "plain",
- ...emptyBlock()
- },
- newInstanceBlocks: {},
- emoji: {},
- newEmoji: emptyEmojiForm()
- },
- reducers: {
- setBlockedInstances: (state, { payload }) => {
- state.blockedInstances = {};
- sortBlocks(payload).forEach((entry) => {
- state.blockedInstances[entry.domain] = entry;
- });
- state.loadedBlockedInstances = true;
- },
-
- newDomainBlock: (state, { payload: [domain, data] }) => {
- if (data == undefined) {
- data = {
- new: true,
- domain,
- ...emptyBlock()
- };
- }
- state.newInstanceBlocks[domain] = data;
- },
-
- setDomainBlock: (state, { payload: [domain, data = {}] }) => {
- state.blockedInstances[domain] = data;
- },
-
- removeDomainBlock: (state, {payload: domain}) => {
- delete state.blockedInstances[domain];
- },
-
- updateDomainBlockVal: (state, { payload: [domain, key, val] }) => {
- state.newInstanceBlocks[domain][key] = val;
- },
-
- updateBulkBlockVal: (state, { payload: [key, val] }) => {
- state.bulkBlock[key] = val;
- },
-
- resetBulkBlockVal: (state, { _payload }) => {
- state.bulkBlock = {
- list: "",
- exportType: "plain",
- ...emptyBlock()
- };
- },
-
- exportToField: (state, { _payload }) => {
- state.bulkBlock.list = Object.values(state.blockedInstances).map((entry) => {
- return entry.domain;
- }).join("\n");
- },
-
- setEmoji: (state, {payload}) => {
- state.emoji = {};
- payload.forEach((emoji) => {
- if (emoji.category == undefined) {
- emoji.category = "Unsorted";
- }
- state.emoji[emoji.category] = defaultValue(state.emoji[emoji.category], []);
- state.emoji[emoji.category].push(emoji);
- });
- },
-
- updateNewEmojiVal: (state, { payload: [key, val] }) => {
- state.newEmoji[key] = val;
- },
-
- addEmoji: (state, {payload: emoji}) => {
- if (emoji.category == undefined) {
- emoji.category = "Unsorted";
- }
- state.emoji[emoji.category] = defaultValue(state.emoji[emoji.category], []);
- state.emoji[emoji.category].push(emoji);
- },
- }
-}); \ No newline at end of file