mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-10-31 02:22:26 -05:00 
			
		
		
		
	
		
			
	
	
		
			131 lines
		
	
	
	
		
			3.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
		
		
			
		
	
	
			131 lines
		
	
	
	
		
			3.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
|  | /* | ||
|  | 	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); | ||
|  | 		}, | ||
|  | 	} | ||
|  | }); |