import * as React from 'react'; import {useEffect, useState} from 'react'; import { CardActions, CardContent, FormControl, Select, Stack, Table, TableBody, TableCell, TableHead, TableRow, useMediaQuery } from "@mui/material"; import Typography from "@mui/material/Typography"; import Paper from "@mui/material/Paper"; import repository from "../app/Repository"; import {Paragraph} from "./styles"; import EditIcon from '@mui/icons-material/Edit'; import CloseIcon from "@mui/icons-material/Close"; import IconButton from "@mui/material/IconButton"; import Container from "@mui/material/Container"; import TextField from "@mui/material/TextField"; import MenuItem from "@mui/material/MenuItem"; import Card from "@mui/material/Card"; import Button from "@mui/material/Button"; import db from "../app/db"; import {useLiveQuery} from "dexie-react-hooks"; import theme from "./theme"; import Dialog from "@mui/material/Dialog"; import DialogTitle from "@mui/material/DialogTitle"; import DialogContent from "@mui/material/DialogContent"; import DialogActions from "@mui/material/DialogActions"; const Preferences = (props) => { return ( ); }; const Notifications = () => { return ( Notifications ); }; const MinPriority = () => { const minPriority = useLiveQuery(() => repository.getMinPriority()); const handleChange = async (ev) => { await repository.setMinPriority(ev.target.value); } if (!minPriority) { return null; // While loading } return ( ) }; const DeleteAfter = () => { const deleteAfter = useLiveQuery(async () => repository.getDeleteAfter()); const handleChange = async (ev) => { await repository.setDeleteAfter(ev.target.value); } if (!deleteAfter) { return null; // While loading } return ( ) }; const PrefGroup = (props) => { return (
{props.children}
) }; const Pref = (props) => { return ( <>
{props.title}
{props.children}
); }; const DefaultServer = (props) => { return ( Default server This server is used as a default when adding new topics. ); }; const Users = () => { const [dialogKey, setDialogKey] = useState(0); const [dialogOpen, setDialogOpen] = useState(false); const users = useLiveQuery(() => db.users.toArray()); const handleAddClick = () => { setDialogKey(prev => prev+1); setDialogOpen(true); }; const handleDialogCancel = () => { setDialogOpen(false); }; const handleDialogSubmit = async (user) => { setDialogOpen(false); try { await db.users.add(user); console.debug(`[Preferences] User ${user.username} for ${user.baseUrl} added`); } catch (e) { console.log(`[Preferences] Error adding user.`, e); } }; return ( Manage users Add/remove users for your protected topics here. Please note that username and password are stored in the browser's local storage. {users?.length > 0 && } ); }; const UserTable = (props) => { const [dialogKey, setDialogKey] = useState(0); const [dialogOpen, setDialogOpen] = useState(false); const [dialogUser, setDialogUser] = useState(null); const handleEditClick = (user) => { setDialogKey(prev => prev+1); setDialogUser(user); setDialogOpen(true); }; const handleDialogCancel = () => { setDialogOpen(false); }; const handleDialogSubmit = async (user) => { setDialogOpen(false); try { await db.users.put(user); // put() is an upsert console.debug(`[Preferences] User ${user.username} for ${user.baseUrl} updated`); } catch (e) { console.log(`[Preferences] Error updating user.`, e); } }; const handleDeleteClick = async (user) => { try { await db.users.delete(user.baseUrl); console.debug(`[Preferences] User ${user.username} for ${user.baseUrl} deleted`); } catch (e) { console.error(`[Preferences] Error deleting user for ${user.baseUrl}`, e); } }; return ( User Service URL {props.users?.map(user => ( {user.username} {user.baseUrl} handleEditClick(user)}> handleDeleteClick(user)}> ))}
); }; const UserDialog = (props) => { const [baseUrl, setBaseUrl] = useState(""); const [username, setUsername] = useState(""); const [password, setPassword] = useState(""); const fullScreen = useMediaQuery(theme.breakpoints.down('sm')); const editMode = props.user !== null; const addButtonEnabled = (() => { if (editMode) { return username.length > 0 && password.length > 0; } const baseUrlExists = props.users?.map(user => user.baseUrl).includes(baseUrl); return !baseUrlExists && username.length > 0 && password.length > 0; })(); const handleSubmit = async () => { props.onSubmit({ baseUrl: baseUrl, username: username, password: password }) }; useEffect(() => { if (editMode) { setBaseUrl(props.user.baseUrl); setUsername(props.user.username); setPassword(props.user.password); } }, []); return ( {editMode ? "Edit user" : "Add user"} {!editMode && setBaseUrl(ev.target.value)} type="url" fullWidth variant="standard" />} setUsername(ev.target.value)} type="text" fullWidth variant="standard" /> setPassword(ev.target.value)} fullWidth variant="standard" /> ); }; export default Preferences;