mirror of
https://github.com/cheeaun/phanpy.git
synced 2025-01-04 16:47:19 +03:00
153 lines
5.5 KiB
React
153 lines
5.5 KiB
React
|
import './settings.css';
|
||
|
|
||
|
import { Menu, MenuItem } from '@szhsin/react-menu';
|
||
|
import { useReducer, useState } from 'preact/hooks';
|
||
|
|
||
|
import Avatar from '../components/avatar';
|
||
|
import Icon from '../components/icon';
|
||
|
import Link from '../components/link';
|
||
|
import NameText from '../components/name-text';
|
||
|
import { api } from '../utils/api';
|
||
|
import states from '../utils/states';
|
||
|
import store from '../utils/store';
|
||
|
|
||
|
function Accounts({ onClose }) {
|
||
|
const { masto } = api();
|
||
|
// Accounts
|
||
|
const accounts = store.local.getJSON('accounts');
|
||
|
const currentAccount = store.session.get('currentAccount');
|
||
|
const moreThanOneAccount = accounts.length > 1;
|
||
|
const [currentDefault, setCurrentDefault] = useState(0);
|
||
|
|
||
|
const [_, reload] = useReducer((x) => x + 1, 0);
|
||
|
|
||
|
return (
|
||
|
<div id="settings-container" class="sheet" tabIndex="-1">
|
||
|
<header class="header-grid">
|
||
|
<h2>Accounts</h2>
|
||
|
<div class="header-side">
|
||
|
<Link to="/login" class="button plain" onClick={onClose}>
|
||
|
<Icon icon="plus" /> <span>Account</span>
|
||
|
</Link>
|
||
|
</div>
|
||
|
</header>
|
||
|
<main>
|
||
|
<section>
|
||
|
<ul class="accounts-list">
|
||
|
{accounts.map((account, i) => {
|
||
|
const isCurrent = account.info.id === currentAccount;
|
||
|
const isDefault = i === (currentDefault || 0);
|
||
|
return (
|
||
|
<li key={i + account.id}>
|
||
|
<div>
|
||
|
{moreThanOneAccount && (
|
||
|
<span class={`current ${isCurrent ? 'is-current' : ''}`}>
|
||
|
<Icon icon="check-circle" alt="Current" />
|
||
|
</span>
|
||
|
)}
|
||
|
<Avatar
|
||
|
url={account.info.avatarStatic}
|
||
|
size="xxl"
|
||
|
onDblClick={async () => {
|
||
|
if (isCurrent) {
|
||
|
try {
|
||
|
const info = await masto.v1.accounts.fetch(
|
||
|
account.info.id,
|
||
|
);
|
||
|
console.log('fetched account info', info);
|
||
|
account.info = info;
|
||
|
store.local.setJSON('accounts', accounts);
|
||
|
reload();
|
||
|
} catch (e) {}
|
||
|
}
|
||
|
}}
|
||
|
/>
|
||
|
<NameText
|
||
|
account={account.info}
|
||
|
showAcct
|
||
|
onClick={() => {
|
||
|
states.showAccount = `${account.info.username}@${account.instanceURL}`;
|
||
|
}}
|
||
|
/>
|
||
|
</div>
|
||
|
<div class="actions">
|
||
|
{isDefault && moreThanOneAccount && (
|
||
|
<>
|
||
|
<span class="tag">Default</span>{' '}
|
||
|
</>
|
||
|
)}
|
||
|
{!isCurrent && (
|
||
|
<button
|
||
|
type="button"
|
||
|
class="light"
|
||
|
onClick={() => {
|
||
|
store.session.set('currentAccount', account.info.id);
|
||
|
location.reload();
|
||
|
}}
|
||
|
>
|
||
|
<Icon icon="transfer" /> Switch
|
||
|
</button>
|
||
|
)}
|
||
|
<Menu
|
||
|
align="end"
|
||
|
menuButton={
|
||
|
<button
|
||
|
type="button"
|
||
|
title="More"
|
||
|
class="plain more-button"
|
||
|
>
|
||
|
<Icon icon="more" size="l" alt="More" />
|
||
|
</button>
|
||
|
}
|
||
|
>
|
||
|
{moreThanOneAccount && (
|
||
|
<MenuItem
|
||
|
disabled={isDefault}
|
||
|
onClick={() => {
|
||
|
// Move account to the top of the list
|
||
|
accounts.splice(i, 1);
|
||
|
accounts.unshift(account);
|
||
|
store.local.setJSON('accounts', accounts);
|
||
|
setCurrentDefault(i);
|
||
|
}}
|
||
|
>
|
||
|
<Icon icon="check-circle" />
|
||
|
<span>Set as default</span>
|
||
|
</MenuItem>
|
||
|
)}
|
||
|
<MenuItem
|
||
|
disabled={!isCurrent}
|
||
|
onClick={() => {
|
||
|
const yes = confirm('Log out?');
|
||
|
if (!yes) return;
|
||
|
accounts.splice(i, 1);
|
||
|
store.local.setJSON('accounts', accounts);
|
||
|
// location.reload();
|
||
|
location.href = '/';
|
||
|
}}
|
||
|
>
|
||
|
<Icon icon="exit" />
|
||
|
<span>Log out</span>
|
||
|
</MenuItem>
|
||
|
</Menu>
|
||
|
</div>
|
||
|
</li>
|
||
|
);
|
||
|
})}
|
||
|
</ul>
|
||
|
{moreThanOneAccount && (
|
||
|
<p>
|
||
|
<small>
|
||
|
Note: <i>Default</i> account will always be used for first load.
|
||
|
Switched accounts will persist during the session.
|
||
|
</small>
|
||
|
</p>
|
||
|
)}
|
||
|
</section>
|
||
|
</main>
|
||
|
</div>
|
||
|
);
|
||
|
}
|
||
|
|
||
|
export default Accounts;
|