DrawioViewerScript.tsx 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. import { useCallback } from 'react';
  2. import type { IGraphViewerGlobal } from '@growi/remark-drawio';
  3. import Head from 'next/head';
  4. import { useViewerMinJsUrl } from './use-viewer-min-js-url';
  5. declare global {
  6. // eslint-disable-next-line vars-on-top, no-var
  7. var GraphViewer: IGraphViewerGlobal;
  8. }
  9. export const DrawioViewerScript = (): JSX.Element => {
  10. const viewerMinJsSrc = useViewerMinJsUrl();
  11. const loadedHandler = useCallback(() => {
  12. // disable useResizeSensor and checkVisibleState
  13. // for preventing resize event by viewer.min.js
  14. GraphViewer.useResizeSensor = false;
  15. GraphViewer.prototype.checkVisibleState = false;
  16. // Set responsive option.
  17. // refs: https://github.com/jgraph/drawio/blob/v13.9.1/src/main/webapp/js/diagramly/GraphViewer.js#L89-L95
  18. // GraphViewer.prototype.responsive = true;
  19. // Set z-index ($zindex-dropdown + 200) for lightbox.
  20. // 'lightbox' is like a modal dialog that appears when click on a drawio diagram.
  21. // z-index refs: https://github.com/twbs/bootstrap/blob/v4.6.2/scss/_variables.scss#L681
  22. GraphViewer.prototype.lightboxZIndex = 1200;
  23. GraphViewer.prototype.toolbarZIndex = 1200;
  24. GraphViewer.processElements();
  25. }, []);
  26. return (
  27. <Head>
  28. <script
  29. type="text/javascript"
  30. async
  31. src={viewerMinJsSrc}
  32. onLoad={loadedHandler}
  33. />
  34. </Head>
  35. );
  36. };