monaco-editor icon indicating copy to clipboard operation
monaco-editor copied to clipboard

[Bug] Got triggerDynamicRequireError when I try to integrate monaco-editor into Flipper

Open buptfarmer opened this issue 3 years ago • 0 comments

Reproducible in vscode.dev or in VS Code Desktop?

  • [X] Not reproducible in vscode.dev or VS Code Desktop

Reproducible in the monaco editor playground?

Monaco Editor Playground Code

I am integrating monaco-editor into project Flipper(https://github.com/facebook/flipper)

I hope it could be used as an normal component, but it load with an error thrown. 
'ReferenceError: triggerDynamicRequireError' , it seems that in monaco-editor which use require internally. and Flipper made a intercept of require call.

I wonder how can I integrate this monaco-editor in to flipper project.

"error" event intercepted: ReferenceError: triggerDynamicRequireError is not defined
at configureLoader (http://localhost:3000/app/src/init.bundle?platform=web&dev=true&minify=false:448476:5)

at HTMLScriptElement.loaderScript.onload (http://localhost:3000/app/src/init.bundle?platform=web&dev=true&minify=false:448454:14)


### Actual Behavior


"error" event intercepted: ReferenceError: triggerDynamicRequireError is not defined
at configureLoader (http://localhost:3000/app/src/init.bundle?platform=web&dev=true&minify=false:448476:5)

at HTMLScriptElement.loaderScript.onload (http://localhost:3000/app/src/init.bundle?platform=web&dev=true&minify=false:448454:14)

### Expected Behavior

load success

### Additional Context

https://github.com/facebook/flipper/issues/3723

To Reproduce
integrate monaco-editor into Flipper with code snippet

// PPEditor.tsx

/**
 * Copyright (c) Meta Platforms, Inc. and affiliates.
 *
 * This source code is licensed under the MIT license found in the
 * LICENSE file in the root directory of this source tree.
 *
 * @format
 */

import {Layout, styled, colors} from '../ui';
import React, {useEffect} from 'react';
import {Tab, Tabs, _Sidebar, theme} from 'flipper-plugin';
import {Button, Card, Image} from 'antd';
import {QRCode, toDataURL, toCanvas} from 'qrcode';
// import {Editor} from './Editor';
import Editor, {DiffEditor, useMonaco, loader} from '@monaco-editor/react';

const MainContainer = styled(Layout.Container)({
  background: theme.backgroundWash,
  padding: `${theme.space.large}px ${theme.space.large}px ${theme.space.large}px 0`,
  overflow: 'hidden',
});

function handleClick(event: any) {
  console.log('editor clicked:', event);
  const ipAddress = '11.11.11.11';
  const port = '6666';
  const id = 123;
  const ppJsonUrl = 'http://' + ipAddress + ':' + port + '/powerpage?&id=' + id;

  const qrcodeContent =
    'jym://com.jym.mall/open?pageType=powerpage&pp_debugger=true&ppJsonUrl=' +
    encodeURIComponent(ppJsonUrl);

  toDataURL(qrcodeContent, function (err, url) {
    console.log(url);
  });
  toCanvas(
    document.getElementById('qrcodeCanvas'),
    qrcodeContent,
    {errorCorrectionLevel: 'H'},
    function (error) {
      if (error) console.error(error);
      console.log('success!');
    },
  );
}

export function PPEditor() {
  const monaco = useMonaco();

  useEffect(() => {
    if (monaco) {
      console.log('here is the monaco instance:', monaco);
    }
  }, [monaco]);

  return (
    <MainContainer>
      <Layout.Horizontal>
        <Layout.Container borderRight width={200}>
          <Button
            type="primary"
            shape="default"
            size="middle"
            loading={false}
            disabled={false}
            onClick={handleClick}>
            点击生成二维码
          </Button>
          <Card title="二维码内容" id="queryPowerPageByIdResult">
            空
          </Card>
          <Card title="二维码">
            <Image
              width={150}
              height={150}
              src="error"
              fallback=""></Image>
          </Card>

          <div color={colors.blackAlpha30}>
            <canvas
              id="qrcodeCanvas"
              width={200}
              height={200}
              color={colors.green}></canvas>
          </div>
        </Layout.Container>
        <Layout.Container width={800} height={400}>
          content
          {/* <Editor
            height="90vh"
            defaultLanguage="javascript"
            defaultValue="// some comment"
          /> */}
        </Layout.Container>
      </Layout.Horizontal>
    </MainContainer>
  );
}

Environment
// package.json
    "@monaco-editor/loader": "^1.3.1",
    "@monaco-editor/react": "^4.4.4",
    "monaco-editor": "^0.33.0",
    "qrcode": "^1.5.0",

I am using the latest code of Flipper from branch main, with commit
commit https://github.com/facebook/flipper/commit/71503308f0016029b0915c21cc3e323b74248162 (HEAD -> main)
Author: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Date: Wed May 4 04:55:29 2022 -0700

buptfarmer avatar May 11 '22 09:05 buptfarmer