mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-10-31 12:12:25 -05:00 
			
		
		
		
	[frogend] Settings refactor (#1318)
* yakshave new form field structure * fully refactor user profile settings form * use rtk query api for profile settings * refactor user post settings * refactor password change form * refactor admin settings * FormWithData structure for user forms * admin actions refactor * whitespace * fix user settings data prop * remove superfluous logging * cleanup old code * refactor federation/suspend (overview, detail) * mostly abstracted (emoji) checkbox list * refactor parse-from-toot * refactor custom-emoji, progress on federation bulk * loading icon styling to prevent big spinny * refactor federation import-export interface * cleanup old files * [chore] Update/add license headers for 2023 * redux fixes * text-field exports * appease the linter * refactor authentication with RTK Query * fix login/logout state transition weirdness * fixes/cleanup * small linter-related fixes * add eslint license header check, fix existing files * remove old code, clarify comment * clarify suspend on subdomains * collapse if/else * fa-fw width info comment
This commit is contained in:
		
					parent
					
						
							
								974ec80a20
							
						
					
				
			
			
				commit
				
					
						9b139b6320
					
				
			
		
					 69 changed files with 3129 additions and 2663 deletions
				
			
		|  | @ -19,42 +19,43 @@ | |||
| "use strict"; | ||||
| 
 | ||||
| const React = require("react"); | ||||
| const Redux = require("react-redux"); | ||||
| 
 | ||||
| const Submit = require("../components/submit"); | ||||
| const query = require("../lib/query"); | ||||
| 
 | ||||
| const api = require("../lib/api"); | ||||
| const submit = require("../lib/submit"); | ||||
| const { useTextInput } = require("../lib/form"); | ||||
| const { TextInput } = require("../components/form/inputs"); | ||||
| 
 | ||||
| const MutationButton = require("../components/form/mutation-button"); | ||||
| 
 | ||||
| module.exports = function AdminActionPanel() { | ||||
| 	const dispatch = Redux.useDispatch(); | ||||
| 	const daysField = useTextInput("days", { defaultValue: 30 }); | ||||
| 
 | ||||
| 	const [days, setDays] = React.useState(30); | ||||
| 	const [mediaCleanup, mediaCleanupResult] = query.useMediaCleanupMutation(); | ||||
| 
 | ||||
| 	const [errorMsg, setError] = React.useState(""); | ||||
| 	const [statusMsg, setStatus] = React.useState(""); | ||||
| 
 | ||||
| 	const removeMedia = submit( | ||||
| 		() => dispatch(api.admin.mediaCleanup(days)), | ||||
| 		{setStatus, setError} | ||||
| 	); | ||||
| 	function submitMediaCleanup(e) { | ||||
| 		e.preventDefault(); | ||||
| 		mediaCleanup(daysField.value); | ||||
| 	} | ||||
| 
 | ||||
| 	return ( | ||||
| 		<> | ||||
| 			<h1>Admin Actions</h1> | ||||
| 			<div> | ||||
| 			<form onSubmit={submitMediaCleanup}> | ||||
| 				<h2>Media cleanup</h2> | ||||
| 				<p> | ||||
| 					Clean up remote media older than the specified number of days. | ||||
| 					If the remote instance is still online they will be refetched when needed. | ||||
| 					Also cleans up unused headers and avatars from the media cache. | ||||
| 				</p> | ||||
| 				<div> | ||||
| 					<label htmlFor="days">Days: </label> | ||||
| 					<input id="days" type="number" value={days} onChange={(e) => setDays(e.target.value)}/> | ||||
| 				</div> | ||||
| 				<Submit onClick={removeMedia} label="Remove media" errorMsg={errorMsg} statusMsg={statusMsg} /> | ||||
| 			</div> | ||||
| 				<TextInput | ||||
| 					field={daysField} | ||||
| 					label="Days" | ||||
| 					type="number" | ||||
| 					min="0" | ||||
| 					placeholder="30" | ||||
| 				/> | ||||
| 				<MutationButton label="Remove old media" result={mediaCleanupResult} /> | ||||
| 			</form> | ||||
| 		</> | ||||
| 	); | ||||
| }; | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue