UNPKG

@selfcommunity/react-ui

Version:

React UI Components to integrate a Community created with SelfCommunity Platform.

76 lines (68 loc) 3.04 kB
import { __rest } from "tslib"; import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime"; import { useState } from 'react'; import { styled } from '@mui/material/styles'; import classNames from 'classnames'; import { useThemeProps } from '@mui/system'; import { Button } from '@mui/material'; import { FormattedMessage } from 'react-intl'; import { useSCUser } from '@selfcommunity/react-core'; import BaseDialog from '../../shared/BaseDialog'; import AccountDataPortability from '../AccountDataPortability'; const PREFIX = 'SCAccountDataPortabilityButtonn'; const classes = { root: `${PREFIX}-root`, dialogRoot: `${PREFIX}-dialog-root` }; const Root = styled(Button, { name: PREFIX, slot: 'Root', overridesResolver: (props, styles) => [styles.root, styles.voted] })(({ theme }) => ({})); const DialogRoot = styled(BaseDialog, { name: PREFIX, slot: 'Root', overridesResolver: (props, styles) => styles.dialogRoot })(({ theme }) => ({})); /** * > API documentation for the Community-JS Account Data Portability Button component. Learn about the available props and the CSS API. * * * This component display a button that open a Dialog that display the [AccountDataPortability](/docs/sdk/community-js/react-ui/Components/AccountDataPortability) component. #### Import ```jsx import {AccountDataPortabilityButton} from '@selfcommunity/react-ui'; ``` #### Component Name The name `SCAccountDataPortabilityButton` can be used when providing style overrides in the theme. #### CSS |Rule Name|Global class|Description| |---|---|---| |root|.SCAccountDataPortabilityButtonn-root|Styles applied to the root element.| |dialogRoot|.SCAccountDataPortabilityButtonn-dialog-root|Styles applied to the dialog root element.| * @param inProps */ export default function AccountDataPortabilityButton(inProps) { // PROPS const props = useThemeProps({ props: inProps, name: PREFIX }); const { className } = props, rest = __rest(props, ["className"]); // STATE const [open, setOpen] = useState(false); // CONTEXT const scUserContext = useSCUser(); // HANDLERS const handleOpen = () => { setOpen(true); }; const handleClose = () => { setOpen(false); }; // RENDER if (!scUserContext.user) { return null; } return (_jsxs(_Fragment, { children: [_jsx(Root, Object.assign({ onClick: handleOpen, className: classNames(classes.root, className) }, rest, { children: _jsx(FormattedMessage, { id: "ui.accountDataPortabilityButton.buttonLabel", defaultMessage: "ui.accountDataPortabilityButton.buttonLabel" }) })), open && (_jsx(DialogRoot, Object.assign({ title: _jsx(FormattedMessage, { id: "ui.accountDataPortabilityButton.dialogTitle", defaultMessage: "ui.accountDataPortabilityButton.dialogTitle", values: { username: scUserContext.user.username } }), onClose: handleClose, open: open, DialogContentProps: {} }, { children: _jsx(AccountDataPortability, {}) })))] })); }