summaryrefslogtreecommitdiffstats
path: root/client/src/common/jsx/User.jsx
diff options
context:
space:
mode:
authorGravatar Piotr Russ <mail@pruss.it> 2020-11-16 00:10:28 +0100
committerGravatar Piotr Russ <mail@pruss.it> 2020-11-16 00:10:28 +0100
commite06ec920f7a5d784e674c4c4b4e6d1da3dc7391d (patch)
tree55713f725f77b44ebfec86e4eec3ce33e71458ca /client/src/common/jsx/User.jsx
downloadwebsite_creator-e06ec920f7a5d784e674c4c4b4e6d1da3dc7391d.tar.gz
website_creator-e06ec920f7a5d784e674c4c4b4e6d1da3dc7391d.tar.bz2
website_creator-e06ec920f7a5d784e674c4c4b4e6d1da3dc7391d.zip
api, login, auth
Diffstat (limited to 'client/src/common/jsx/User.jsx')
-rw-r--r--client/src/common/jsx/User.jsx38
1 files changed, 38 insertions, 0 deletions
diff --git a/client/src/common/jsx/User.jsx b/client/src/common/jsx/User.jsx
new file mode 100644
index 0000000..8b05d44
--- /dev/null
+++ b/client/src/common/jsx/User.jsx
@@ -0,0 +1,38 @@
+import React from 'react';
+import WithHover from './WithHover.jsx';
+
+const User = ({user, setUser, setHover, t, opened, setOpened}) => {
+ const handleLogout = () => {
+ setOpened(false);
+ setUser(null);
+ };
+ const handleChangePass = () => { setOpened(false) };
+ const handleRemoveUser = () => { setOpened(false) };
+
+ return (
+ <div className="user">
+ <WithHover setHover={setHover} message="click-to-change-user">
+ <span
+ className={`user__main-item${opened === 'user' ? ' user__main-item--active' : ''}`}
+ onClick={() => setOpened(opened !== 'user' ? 'user' : false)}
+ >
+ {user}
+ </span>
+ {
+ opened === 'user' && (
+ <div className="user__list" >
+ <WithHover setHover={setHover} message="click-to-logout">
+ <span className="user__item" onClick={handleLogout}>{t('logout')}</span>
+ </WithHover>
+ <WithHover setHover={setHover} message="click-to-change-user-settings">
+ <span className="user__item" onClick={handleChangePass}>{t('user-settings')}</span>
+ </WithHover>
+ </div>
+ )
+ }
+ </WithHover>
+ </div>
+ );
+};
+
+export default User;