/*
	GoToSocial
	Copyright (C) 2021-2023 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 query = require("../lib/query");
const {
	useTextInput,
	useFileInput,
	useBoolInput
} = require("../lib/form");
const useFormSubmit = require("../lib/form/submit");
const {
	TextInput,
	TextArea,
	FileInput,
	Checkbox
} = require("../components/form/inputs");
const FormWithData = require("../lib/form/form-with-data");
const FakeProfile = require("../components/fake-profile");
const MutationButton = require("../components/form/mutation-button");
module.exports = function UserProfile() {
	return (
		
	);
};
function UserProfileForm({ data: profile }) {
	/*
		User profile update form keys
		- bool bot
		- bool locked
		- string display_name
		- string note
		- file avatar
		- file header
		- bool enable_rss
		- string custom_css (if enabled)
	*/
	const { data: instance } = query.useInstanceQuery();
	const allowCustomCSS = React.useMemo(() => {
		return instance?.configuration?.accounts?.allow_custom_css === true;
	}, [instance]);
	const form = {
		avatar: useFileInput("avatar", { withPreview: true }),
		header: useFileInput("header", { withPreview: true }),
		displayName: useTextInput("display_name", { defaultValue: profile.display_name }),
		note: useTextInput("note", { defaultValue: profile.source?.note }),
		customCSS: useTextInput("custom_css", { defaultValue: profile.custom_css }),
		bot: useBoolInput("bot", { defaultValue: profile.bot }),
		locked: useBoolInput("locked", { defaultValue: profile.locked }),
		enableRSS: useBoolInput("enable_rss", { defaultValue: profile.enable_rss }),
	};
	const [submitForm, result] = useFormSubmit(form, query.useUpdateCredentialsMutation());
	return (
		
	);
}