Как сделать Material-UI Dialog изменяемого размера - PullRequest
1 голос
/ 26 апреля 2020

У меня есть проект, требующий изменения размера и перетаскивания диалогового окна. В документации Material-UI Dialog есть шаги, чтобы сделать его перетаскиваемым. Я хочу выяснить изменяемый размер. Любые предложения о том, как?

Пример кода можно найти здесь .

ОБНОВЛЕНИЕ:

Функциональная и машинописная версия @ Khabir ответ ниже

    import Button from '@material-ui/core/Button'
    import Dialog from '@material-ui/core/Dialog'
    import DialogActions from '@material-ui/core/DialogActions'
    import DialogContent from '@material-ui/core/DialogContent'
    import DialogContentText from '@material-ui/core/DialogContentText'
    import DialogTitle from '@material-ui/core/DialogTitle'
    import Paper, { PaperProps } from '@material-ui/core/Paper'
    import { makeStyles, Theme } from '@material-ui/core/styles'
    import TextField from '@material-ui/core/TextField'
    import React from 'react'
    import Draggable from 'react-draggable'
    import { ResizableBox } from 'react-resizable'

    const useStyles = makeStyles((theme: Theme) => ({
        resizable: {
            position: 'relative',
            '& .react-resizable-handle': {
                position: 'absolute',    
                width: 20,  
                height: 20,   
                bottom: 0,
                right: 0,
                background:"url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+')",
                'background-position': 'bottom right',
                padding: '0 3px 3px 0',
                'background-repeat': 'no-repeat',
                'background-origin': 'content-box',
                'box-sizing': 'border-box',
                cursor: 'se-resize',
            },
        },
    }))

    const PaperComponent = (props: PaperProps) => {
        return (
            <Draggable
                handle="#draggable-dialog-title"
                cancel={'[class*="MuiDialogContent-root"]'}
            >
                <Paper {...props} />
            </Draggable>
        )
    }

    export const DialogComponent = () => {
        const [open, setOpen] = React.useState<boolean>(false)
        const handleClickOpen = () => {
            setOpen(true)
        }

        const handleClose = () => {
            setOpen(false)
        }

        const classes = useStyles()

        return (
            <div>
                <Button onClick={handleClickOpen}>Open dd form dialog</Button>
                {open && (
                    <Dialog
                        open={true}
                        onClose={handleClose}
                        maxWidth={false}
                        PaperComponent={PaperComponent}
                        aria-labelledby="draggable-dialog-title"
                    >
                        <ResizableBox
                            height={400}
                            width={600}
                            className={classes.resizable}
                        >
                            <DialogTitle
                                style={{ cursor: 'move' }}
                                id="draggable-dialog-title"
                            >
                                Subscribe
                            </DialogTitle>

                            <DialogContent>
                                <DialogContentText>
                                    To subscribe to this website, please enter your email address here. We will send updates occasionally.
                                </DialogContentText>

                                <TextField
                                    autoFocus
                                    margin="dense"
                                    id="name"
                                    label="Email Address"
                                    type="email"
                                    fullWidth
                                />
                            </DialogContent>

                            <DialogActions>
                                <Button onClick={handleClose} color="primary">
                                    Cancel
                                </Button>
                                <Button onClick={handleClose} color="primary">
                                    Subscribe
                                </Button>
                            </DialogActions>
                        </ResizableBox>
                    </Dialog>
                )}
            </div>
        )
    }

машинописный текст 3.8.3 @ material-ui / core 4.9.7

1 Ответ

1 голос
/ 26 апреля 2020

Привет, я объединил две функции вместе. пожалуйста, проверьте пример. Он поддерживает перетаскивание и изменение размера.

import React from "react";
import Button from "@material-ui/core/Button";
import Draggable from "react-draggable";
import {withStyles} from "@material-ui/core/styles";
import TextField from "@material-ui/core/TextField";
import Dialog from "@material-ui/core/Dialog";
import DialogActions from "@material-ui/core/DialogActions";
import DialogContent from "@material-ui/core/DialogContent";
import DialogContentText from "@material-ui/core/DialogContentText";
import DialogTitle from "@material-ui/core/DialogTitle";
import {ResizableBox} from "react-resizable";
import Paper from "@material-ui/core/Paper";

const styles = theme => ({
    resizable: {
        position: "relative",
        "& .react-resizable-handle": {
            position: "absolute",
            width: 20,
            height: 20,
            bottom: 0,
            right: 0,
            background:
                "url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+')",
            "background-position": "bottom right",
            padding: "0 3px 3px 0",
            "background-repeat": "no-repeat",
            "background-origin": "content-box",
            "box-sizing": "border-box",
            cursor: "se-resize"
        }
    }
});

function PaperComponent(props) {
    return (
        <Draggable handle="#draggable-dialog-title" cancel={'[class*="MuiDialogContent-root"]'}>
            <Paper {...props} />
        </Draggable>
    );
}

class DraggableResizableDialog extends React.Component {
    state = {
        open: false
    };

    handleClickOpen = () => {
        this.setState({open: true});
    };

    handleClose = () => {
        this.setState({open: false});
    };

    render() {
        return (
            <div>
                <Button onClick={this.handleClickOpen}>Open dd form dialog</Button>
                {this.state.open && (
                    <Dialog
                        open={true}
                        onClose={this.handleClose}
                        maxWidth={false}
                        PaperComponent={PaperComponent}
                        aria-labelledby="draggable-dialog-title"
                    >
                        <ResizableBox
                            height={400}
                            width={600}
                            className={this.props.classes.resizable}
                        >
                            <DialogTitle style={{ cursor: 'move' }} id="draggable-dialog-title">Subscribe</DialogTitle>
                            <DialogContent>
                                <DialogContentText>
                                    To subscribe to this website, please enter your email address
                                    here. We will send updates occasionally.
                                </DialogContentText>
                                <TextField
                                    autoFocus
                                    margin="dense"
                                    id="name"
                                    label="Email Address"
                                    type="email"
                                    fullWidth
                                />
                            </DialogContent>
                            <DialogActions>
                                <Button onClick={this.handleClose} color="primary">
                                    Cancel
                                </Button>
                                <Button onClick={this.handleClose} color="primary">
                                    Subscribe
                                </Button>
                            </DialogActions>
                        </ResizableBox>
                    </Dialog>
                )}
            </div>
        );
    }
}

export default withStyles(styles)(DraggableResizableDialog);

Источник: Draggable Изменяемый размер

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...