javascriptcssreactjsfluent-uifluentui-react

Fluent UI Modal dialog resizing and not taking whole screen


I have Fluent UI modal dialog that I am showing in my site very similar to below example.

https://codesandbox.io/s/practical-boyd-m5rw2k?file=/example.tsx

EDIT: The code in codesandbox.io is the same as the one below:

import * as React from "react";
import {
  Dialog,
  DialogTrigger,
  DialogSurface,
  DialogTitle,
  DialogBody,
  DialogContent,
  DialogActions,
  Button,
  makeStyles,
  shorthands
} from "@fluentui/react-components";

const useStyles = makeStyles({
  dialog: {
    maxWidth: "fit-content",
    width: "52.875rem",
    ...shorthands.borderRadius("1rem")
  },

  title: {
    paddingBottom: "1rem"
  },

  dialogContent: {
    maxHeight: "50rem",
    paddingRight: "2.5rem"
  }
});

export const ScrollingLongContent = () => {
  const styles = useStyles();

  return (
    <Dialog>
      <DialogTrigger disableButtonEnhancement>
        <Button>Open dialog</Button>
      </DialogTrigger>
      <DialogSurface className={styles.dialog}>
        <DialogBody>
          <DialogTitle className={styles.title}>Dialog title</DialogTitle>
          <DialogContent className={styles.dialogContent}>
            <p>
              Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do
              eiusmod tempor incididunt ut labore et dolore magna aliqua. Nisl
              pretium fusce id velit ut tortor. Leo vel fringilla est
              ullamcorper. Eget est lorem ipsum dolor sit amet consectetur
              adipiscing elit. In mollis nunc sed id semper risus in hendrerit
              gravida. Ullamcorper sit amet risus nullam eget felis eget. Dolor
              sed viverra ipsum nunc aliquet bibendum. Facilisi morbi tempus
              iaculis urna id volutpat. Porta non pulvinar neque laoreet
              suspendisse. Nunc id cursus metus aliquam eleifend mi in. A
              iaculis at erat pellentesque adipiscing commodo. Proin nibh nisl
              condimentum id. In hac habitasse platea dictumst vestibulum
              rhoncus est. Non tellus orci ac auctor augue mauris augue neque.
              Enim nulla aliquet porttitor lacus luctus accumsan tortor.
              Nascetur ridiculus mus mauris vitae ultricies leo integer.
              Ullamcorper eget nulla facilisi etiam dignissim. Leo in vitae
              turpis massa sed elementum tempus egestas sed.
            </p>
            <p>
              Ut enim blandit volutpat maecenas volutpat. Venenatis urna cursus
              eget nunc scelerisque viverra mauris. Neque aliquam vestibulum
              morbi blandit. Porttitor eget dolor morbi non. Nisi quis eleifend
              quam adipiscing vitae. Aliquam ultrices sagittis orci a
              scelerisque purus semper. Interdum varius sit amet mattis
              vulputate enim nulla aliquet. Ut sem viverra aliquet eget sit amet
              tellus cras. Sit amet tellus cras adipiscing enim eu turpis
              egestas. Amet cursus sit amet dictum sit amet justo donec enim.
              Neque gravida in fermentum et sollicitudin ac. Arcu cursus euismod
              quis viverra nibh cras pulvinar mattis nunc. Ultrices eros in
              cursus turpis massa tincidunt dui. Nisl rhoncus mattis rhoncus
              urna neque viverra justo. Odio pellentesque diam volutpat commodo
              sed egestas. Nunc mi ipsum faucibus vitae aliquet nec ullamcorper.
              Ipsum nunc aliquet bibendum enim. Faucibus ornare suspendisse sed
              nisi lacus sed. Sapien nec sagittis aliquam malesuada bibendum
              arcu vitae elementum. Metus vulputate eu scelerisque felis
              imperdiet.
            </p>
            <p>
              Consequat interdum varius sit amet mattis vulputate enim. Amet
              cursus sit amet dictum sit amet justo. Eget aliquet nibh praesent
              tristique magna sit. Ut consequat semper viverra nam libero justo.
              Pharetra massa massa ultricies mi. Sem viverra aliquet eget sit
              amet. Pulvinar mattis nunc sed blandit libero volutpat sed.
              Pharetra diam sit amet nisl suscipit adipiscing bibendum.
              Consectetur adipiscing elit ut aliquam. Volutpat diam ut venenatis
              tellus in metus vulputate. Scelerisque in dictum non consectetur a
              erat. Venenatis lectus magna fringilla urna porttitor rhoncus.
              Vitae congue mauris rhoncus aenean vel elit. Neque laoreet
              suspendisse interdum consectetur. Ultrices gravida dictum fusce ut
              placerat orci. Bibendum ut tristique et egestas quis ipsum
              suspendisse. Mattis rhoncus urna neque viverra justo nec ultrices
              dui. Elit duis tristique sollicitudin nibh sit amet.
            </p>
            <p>
              At risus viverra adipiscing at. Interdum posuere lorem ipsum dolor
              sit amet consectetur adipiscing elit. Nunc vel risus commodo
              viverra maecenas. Sit amet est placerat in egestas erat imperdiet
              sed euismod. Turpis egestas maecenas pharetra convallis posuere.
              Egestas tellus rutrum tellus pellentesque eu tincidunt tortor
              aliquam. Dolor sit amet consectetur adipiscing elit. Aliquam purus
              sit amet luctus venenatis lectus magna fringilla. Scelerisque
              fermentum dui faucibus in ornare quam viverra. Egestas maecenas
              pharetra convallis posuere morbi leo urna. A diam sollicitudin
              tempor id eu nisl nunc. Lectus sit amet est placerat.
            </p>
            <p>
              Mattis ullamcorper velit sed ullamcorper morbi tincidunt ornare
              massa eget. At tellus at urna condimentum mattis pellentesque id
              nibh. Dui faucibus in ornare quam. Tincidunt id aliquet risus
              feugiat in ante metus dictum. Adipiscing commodo elit at imperdiet
              dui. Dolor sed viverra ipsum nunc. Sodales neque sodales ut etiam
              sit amet nisl. Hendrerit dolor magna eget est lorem ipsum dolor
              sit amet. Mattis molestie a iaculis at erat pellentesque
              adipiscing. Adipiscing elit duis tristique sollicitudin nibh sit
              amet commodo nulla. Fringilla urna porttitor rhoncus dolor purus.
            </p>
            <p>
              Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do
              eiusmod tempor incididunt ut labore et dolore magna aliqua. Nisl
              pretium fusce id velit ut tortor. Leo vel fringilla est
              ullamcorper. Eget est lorem ipsum dolor sit amet consectetur
              adipiscing elit. In mollis nunc sed id semper risus in hendrerit
              gravida. Ullamcorper sit amet risus nullam eget felis eget. Dolor
              sed viverra ipsum nunc aliquet bibendum. Facilisi morbi tempus
              iaculis urna id volutpat. Porta non pulvinar neque laoreet
              suspendisse. Nunc id cursus metus aliquam eleifend mi in. A
              iaculis at erat pellentesque adipiscing commodo. Proin nibh nisl
              condimentum id. In hac habitasse platea dictumst vestibulum
              rhoncus est. Non tellus orci ac auctor augue mauris augue neque.
              Enim nulla aliquet porttitor lacus luctus accumsan tortor.
              Nascetur ridiculus mus mauris vitae ultricies leo integer.
              Ullamcorper eget nulla facilisi etiam dignissim. Leo in vitae
              turpis massa sed elementum tempus egestas sed.
            </p>
            <p>
              Ut enim blandit volutpat maecenas volutpat. Venenatis urna cursus
              eget nunc scelerisque viverra mauris. Neque aliquam vestibulum
              morbi blandit. Porttitor eget dolor morbi non. Nisi quis eleifend
              quam adipiscing vitae. Aliquam ultrices sagittis orci a
              scelerisque purus semper. Interdum varius sit amet mattis
              vulputate enim nulla aliquet. Ut sem viverra aliquet eget sit amet
              tellus cras. Sit amet tellus cras adipiscing enim eu turpis
              egestas. Amet cursus sit amet dictum sit amet justo donec enim.
              Neque gravida in fermentum et sollicitudin ac. Arcu cursus euismod
              quis viverra nibh cras pulvinar mattis nunc. Ultrices eros in
              cursus turpis massa tincidunt dui. Nisl rhoncus mattis rhoncus
              urna neque viverra justo. Odio pellentesque diam volutpat commodo
              sed egestas. Nunc mi ipsum faucibus vitae aliquet nec ullamcorper.
              Ipsum nunc aliquet bibendum enim. Faucibus ornare suspendisse sed
              nisi lacus sed. Sapien nec sagittis aliquam malesuada bibendum
              arcu vitae elementum. Metus vulputate eu scelerisque felis
              imperdiet.
            </p>
            <p>
              Consequat interdum varius sit amet mattis vulputate enim. Amet
              cursus sit amet dictum sit amet justo. Eget aliquet nibh praesent
              tristique magna sit. Ut consequat semper viverra nam libero justo.
              Pharetra massa massa ultricies mi. Sem viverra aliquet eget sit
              amet. Pulvinar mattis nunc sed blandit libero volutpat sed.
              Pharetra diam sit amet nisl suscipit adipiscing bibendum.
              Consectetur adipiscing elit ut aliquam. Volutpat diam ut venenatis
              tellus in metus vulputate. Scelerisque in dictum non consectetur a
              erat. Venenatis lectus magna fringilla urna porttitor rhoncus.
              Vitae congue mauris rhoncus aenean vel elit. Neque laoreet
              suspendisse interdum consectetur. Ultrices gravida dictum fusce ut
              placerat orci. Bibendum ut tristique et egestas quis ipsum
              suspendisse. Mattis rhoncus urna neque viverra justo nec ultrices
              dui. Elit duis tristique sollicitudin nibh sit amet.
            </p>
            <p>
              At risus viverra adipiscing at. Interdum posuere lorem ipsum dolor
              sit amet consectetur adipiscing elit. Nunc vel risus commodo
              viverra maecenas. Sit amet est placerat in egestas erat imperdiet
              sed euismod. Turpis egestas maecenas pharetra convallis posuere.
              Egestas tellus rutrum tellus pellentesque eu tincidunt tortor
              aliquam. Dolor sit amet consectetur adipiscing elit. Aliquam purus
              sit amet luctus venenatis lectus magna fringilla. Scelerisque
              fermentum dui faucibus in ornare quam viverra. Egestas maecenas
              pharetra convallis posuere morbi leo urna. A diam sollicitudin
              tempor id eu nisl nunc. Lectus sit amet est placerat.
            </p>
            <p>
              Mattis ullamcorper velit sed ullamcorper morbi tincidunt ornare
              massa eget. At tellus at urna condimentum mattis pellentesque id
              nibh. Dui faucibus in ornare quam. Tincidunt id aliquet risus
              feugiat in ante metus dictum. Adipiscing commodo elit at imperdiet
              dui. Dolor sed viverra ipsum nunc. Sodales neque sodales ut etiam
              sit amet nisl. Hendrerit dolor magna eget est lorem ipsum dolor
              sit amet. Mattis molestie a iaculis at erat pellentesque
              adipiscing. Adipiscing elit duis tristique sollicitudin nibh sit
              amet commodo nulla. Fringilla urna porttitor rhoncus dolor purus.
            </p>
          </DialogContent>
          <DialogActions>
            <DialogTrigger disableButtonEnhancement>
              <Button appearance="secondary">Close</Button>
            </DialogTrigger>
            <Button appearance="primary">Do Something</Button>
          </DialogActions>
        </DialogBody>
      </DialogSurface>
    </Dialog>
  );
};

The dialog renders well but it takes the whole screen when I zoom in with my browser or I use a screen with a lower resolution. Is there a way I can maintain a padding between the modal dialog and the overall host, so it never goes to the entire screen?

This is how it looks when it looks good: enter image description here

And this is how it looks when I zoom in. It just takes the whole screen: enter image description here


Solution

  • You can add any one margin to the dialog.
    Also some more css properties to make it look normal, because actually the code in this component is pretty dirty... Here's what you need to add:

    const useStyles = makeStyles({
      dialog: {
        '--margin': "1rem",
        maxWidth: "calc(100% - var(--margin))",
        maxHeight: "calc(100% - var(--margin))",
        //...
      },
      //...
      dialogBody: {
        minHeight: 0,
      },
      dialogActions: {
        marginTop: "1rem"
      }
    });
    

    Codesandbox