import React, { cloneElement, Fragment } from "react"; import Avatar from "@material-ui/core/Avatar"; import PersonPinIcon from "@material-ui/icons/PersonPin"; import ContactMailIcon from "@material-ui/icons/ContactMail"; import DevicesIcon from "@material-ui/icons/Devices"; import SettingsInputComponentIcon from "@material-ui/icons/SettingsInputComponent"; import { ArrayInput, ArrayField, Datagrid, DateField, Create, Edit, List, Filter, Toolbar, SimpleForm, SimpleFormIterator, TabbedForm, FormTab, BooleanField, BooleanInput, PasswordInput, TextField, TextInput, ReferenceField, ReferenceManyField, SelectInput, BulkDeleteButton, DeleteButton, SaveButton, regex, useTranslate, Pagination, CreateButton, ExportButton, TopToolbar, sanitizeListRestProps, } from "react-admin"; import { ServerNoticeButton, ServerNoticeBulkButton } from "./ServerNotices"; import { DeviceRemoveButton } from "./devices"; import { makeStyles } from "@material-ui/core/styles"; const useStyles = makeStyles({ small: { height: "40px", width: "40px", }, large: { height: "120px", width: "120px", float: "right", }, }); const UserListActions = ({ currentSort, className, resource, filters, displayedFilters, exporter, // you can hide ExportButton if exporter = (null || false) filterValues, permanentFilter, hasCreate, // you can hide CreateButton if hasCreate = false basePath, selectedIds, onUnselectItems, showFilter, maxResults, total, ...rest }) => ( {filters && cloneElement(filters, { resource, showFilter, displayedFilters, filterValues, context: "button", })} ); const UserPagination = props => ( ); const UserFilter = props => ( ); const UserBulkActionButtons = props => { const translate = useTranslate(); return ( ); }; const AvatarField = ({ source, className, record = {} }) => ( ); export const UserList = props => { const classes = useStyles(); return ( } filterDefaultValues={{ guests: true, deactivated: false }} actions={} bulkActionButtons={} pagination={} > ); }; // https://matrix.org/docs/spec/appendices#user-identifiers const validateUser = regex( /^@[a-z0-9._=\-/]+:.*/, "synapseadmin.users.invalid_user_id" ); const UserEditToolbar = props => { const translate = useTranslate(); return ( ); }; export const UserCreate = props => ( ); const UserTitle = ({ record }) => { const translate = useTranslate(); return ( {translate("resources.users.name", { smart_count: 1, })}{" "} {record ? `"${record.displayname}"` : ""} ); }; export const UserEdit = props => { const classes = useStyles(); const translate = useTranslate(); return ( }> }> } > } path="threepid" > } path="devices" > } path="connections" > ); };