/* 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 Promise = require("bluebird"); const React = require("react"); const Redux = require("react-redux"); const d = require("dotty"); const Submit = require("../components/submit"); const api = require("../lib/api"); const user = require("../redux/reducers/user").actions; module.exports = function UserProfile() { const dispatch = Redux.useDispatch(); const account = Redux.useSelector(state => state.user.account); const [errorMsg, setError] = React.useState(""); const [statusMsg, setStatus] = React.useState(""); function onTextChange(key) { return function (e) { dispatch(user.setAccountVal([key, e.target.value])); }; } function onCheckChange(key) { return function (e) { dispatch(user.setAccountVal([key, e.target.checked])); }; } function onFileChange(key) { return function (e) { let old = d.get(account, key); if (old != undefined) { URL.revokeObjectURL(old); // no error revoking a non-Object URL as provided by instance } let file = e.target.files[0]; let objectURL = URL.createObjectURL(file); dispatch(user.setAccountVal([key, objectURL])); dispatch(user.setAccountVal([`${key}File`, file])); }; } const submit = (e) => { e.preventDefault(); setStatus("PATCHing"); setError(""); return Promise.try(() => { return dispatch(api.user.updateAccount()); }).then(() => { setStatus("Saved!"); }).catch((e) => { setError(e.message); setStatus(""); }); }; return (

Profile

{account.header
{account.avatar
{account.display_name.trim().length > 0 ? account.display_name : account.username}
@{account.username}

Header

{account.headerFile ? account.headerFile.name : "no file selected"}

Avatar

{account.avatarFile ? account.avatarFile.name : "no file selected"}