2022-08-08 10:40:51 +02:00
/ *
2022-09-09 20:43:55 +02:00
GoToSocial
Copyright ( C ) 2021 - 2022 GoToSocial Authors admin @ gotosocial . org
2022-08-08 10:40:51 +02:00
2022-09-09 20:43:55 +02:00
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 .
2022-08-08 10:40:51 +02:00
2022-09-09 20:43:55 +02:00
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 .
2022-08-08 10:40:51 +02:00
2022-09-09 20:43:55 +02:00
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/>.
2022-08-08 10:40:51 +02:00
* /
2022-09-07 13:51:16 +02:00
"use strict" ;
2022-08-08 10:40:51 +02:00
2022-09-09 01:39:43 +02:00
const Promise = require ( "bluebird" ) ;
const React = require ( "react" ) ;
2022-09-11 19:05:06 +02:00
const Redux = require ( "react-redux" ) ;
2022-09-11 23:02:23 +02:00
const d = require ( "dotty" ) ;
2022-09-09 01:39:43 +02:00
const Submit = require ( "../components/submit" ) ;
2022-09-11 19:42:13 +02:00
const api = require ( "../lib/api" ) ;
2022-09-11 23:02:23 +02:00
const user = require ( "../redux/reducers/user" ) . actions ;
2022-09-11 19:42:13 +02:00
2022-09-11 19:05:06 +02:00
module . exports = function UserProfile ( ) {
2022-09-11 19:42:13 +02:00
const dispatch = Redux . useDispatch ( ) ;
2022-09-11 19:05:06 +02:00
const account = Redux . useSelector ( state => state . user . account ) ;
2022-09-09 01:39:43 +02:00
const [ errorMsg , setError ] = React . useState ( "" ) ;
const [ statusMsg , setStatus ] = React . useState ( "" ) ;
2022-09-11 23:02:23 +02:00
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 ] ) ) ;
} ;
}
2022-09-09 01:39:43 +02:00
const submit = ( e ) => {
e . preventDefault ( ) ;
setStatus ( "PATCHing" ) ;
setError ( "" ) ;
return Promise . try ( ( ) => {
2022-09-11 23:02:23 +02:00
return dispatch ( api . user . updateAccount ( ) ) ;
2022-09-11 19:42:13 +02:00
} ) . then ( ( ) => {
2022-09-09 01:39:43 +02:00
setStatus ( "Saved!" ) ;
} ) . catch ( ( e ) => {
setError ( e . message ) ;
setStatus ( "" ) ;
} ) ;
} ;
return (
2022-09-11 19:42:13 +02:00
< div className = "user-profile" >
2022-09-11 21:59:39 +02:00
< h1 > Profile < / h 1 >
< div className = "overview" >
< div className = "profile" >
< div className = "headerimage" >
< img className = "headerpreview" src = { account . header } alt = { account . header ? ` header image for ${ account . username } ` : "None set" } / >
< / d i v >
< div className = "basic" >
< div id = "profile-basic-filler2" > < / d i v >
< span className = "avatar" > < img className = "avatarpreview" src = { account . avatar } alt = { account . avatar ? ` avatar image for ${ account . username } ` : "None set" } / > < / s p a n >
< div className = "displayname" > { account . display _name . trim ( ) . length > 0 ? account . display _name : account . username } < / d i v >
< div className = "username" > < span > @ { account . username } < / s p a n > < / d i v >
< / d i v >
< / d i v >
< div className = "files" >
2022-09-11 19:42:13 +02:00
< div >
2022-09-11 21:59:39 +02:00
< h3 > Header < / h 3 >
2022-09-11 19:42:13 +02:00
< label htmlFor = "header" className = "file-input button" > Browse … < / l a b e l >
2022-09-11 23:02:23 +02:00
< span > { account . headerFile ? account . headerFile . name : "no file selected" } < / s p a n >
< input className = "hidden" id = "header" type = "file" accept = "image/*" onChange = { onFileChange ( "header" ) } / >
2022-09-09 01:39:43 +02:00
< / d i v >
2022-09-11 19:42:13 +02:00
< div >
2022-09-11 21:59:39 +02:00
< h3 > Avatar < / h 3 >
2022-09-11 19:42:13 +02:00
< label htmlFor = "avatar" className = "file-input button" > Browse … < / l a b e l >
2022-09-11 23:02:23 +02:00
< span > { account . avatarFile ? account . avatarFile . name : "no file selected" } < / s p a n >
< input className = "hidden" id = "avatar" type = "file" accept = "image/*" onChange = { onFileChange ( "avatar" ) } / >
2022-09-09 01:39:43 +02:00
< / d i v >
< / d i v >
2022-09-11 19:42:13 +02:00
< / d i v >
< div className = "labelinput" >
2022-09-11 21:59:39 +02:00
< label htmlFor = "displayname" > Name < / l a b e l >
2022-09-11 23:02:23 +02:00
< input id = "displayname" type = "text" value = { account . display _name } onChange = { onTextChange ( "display_name" ) } placeholder = "A GoToSocial user" / >
2022-09-11 19:42:13 +02:00
< / d i v >
< div className = "labelinput" >
< label htmlFor = "bio" > Bio < / l a b e l >
2022-09-11 23:02:23 +02:00
< textarea id = "bio" value = { account . source . note } onChange = { onTextChange ( "source.note" ) } placeholder = "Just trying out GoToSocial, my pronouns are they/them and I like sloths." / >
2022-09-11 19:42:13 +02:00
< / d i v >
< div className = "labelcheckbox" >
2022-09-11 21:59:39 +02:00
< label htmlFor = "locked" > Manually approve follow requests ? < / l a b e l >
2022-09-11 23:02:23 +02:00
< input id = "locked" type = "checkbox" checked = { account . locked } onChange = { onCheckChange ( "locked" ) } / >
2022-09-11 19:42:13 +02:00
< / d i v >
< Submit onClick = { submit } label = "Save profile info" errorMsg = { errorMsg } statusMsg = { statusMsg } / >
< / d i v >
2022-09-09 01:39:43 +02:00
) ;
2022-09-07 13:51:16 +02:00
} ;