From 117888cf59c10330671f43bbce949a3984761c91 Mon Sep 17 00:00:00 2001 From: tobi <31960611+tsmethurst@users.noreply.github.com> Date: Mon, 8 Aug 2022 10:40:51 +0200 Subject: [feature] Add first iteration of a user panel at `/user` (#736) * start work on user panel * parse source first before checking if empty form * newline * set avi + header nicely * add posts settings * render signin a bit nicer on mobile * return OK json on successful change * return unauthorized on bad password * clarify message on insecure password * make login a bit prettier * add alt text + border round image previews * add logout button * add password change * styling updates * redirect /auth/edit to /user * update tests * fix validation tests * better labels, link to more info * make submit button generic component * move submit button inside forms * add autocomplete labels to password fields * fix indentation (thx eslint) * update eslintrc * eslint: no-unescaped-entities * initial deduplication between user and admin panel * add default status/post format setting * user panel styling for inputs * update user panel styling, include normalize css * add placeholder text * input padding Co-authored-by: f0x --- web/source/panels/user/index.js | 41 ++++++++++++++++++++++++++++++++++++----- 1 file changed, 36 insertions(+), 5 deletions(-) (limited to 'web/source/panels/user/index.js') diff --git a/web/source/panels/user/index.js b/web/source/panels/user/index.js index 7adc320d8..bb8b263d6 100644 --- a/web/source/panels/user/index.js +++ b/web/source/panels/user/index.js @@ -22,10 +22,41 @@ const Promise = require("bluebird"); const React = require("react"); const ReactDom = require("react-dom"); -// require("./style.css"); - -function App() { - return "hello world - user panel"; +const createPanel = require("../lib/panel"); + +const Basic = require("./basic"); +const Posts = require("./posts"); +const Security = require("./security"); + +require("../base.css"); +require("./style.css"); + +function UserPanel({oauth}) { + const [account, setAccount] = React.useState({}); + const [errorMsg, setError] = React.useState(""); + const [statusMsg, setStatus] = React.useState("Fetching user info"); + + React.useEffect(() => { + Promise.try(() => { + return oauth.apiRequest("/api/v1/accounts/verify_credentials", "GET"); + }).then((json) => { + setAccount(json); + }).catch((e) => { + setError(e.message); + setStatus(""); + }); + }, [oauth, setAccount, setError, setStatus]); + + return ( + +
+ +
+ + + +
+ ); } -ReactDom.render(, document.getElementById("root")); \ No newline at end of file +createPanel("GoToSocial User Panel", ["read write"], UserPanel); \ No newline at end of file -- cgit v1.2.3