mirror of
https://github.com/ragestudio/comty.git
synced 2025-06-12 12:04:16 +00:00
improve Debug render
This commit is contained in:
parent
3c80ebe383
commit
10cb89046e
@ -423,7 +423,10 @@ class App extends React.Component {
|
|||||||
title: "Debug",
|
title: "Debug",
|
||||||
})
|
})
|
||||||
|
|
||||||
win.createDefaultWindow(loadable(() => import("./debug")))
|
win.createDefaultWindow(loadable(() => import("./debug")), {
|
||||||
|
width: 700,
|
||||||
|
height: 500,
|
||||||
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,17 +1,47 @@
|
|||||||
import React from "react"
|
import React from "react"
|
||||||
|
import loadable from "@loadable/component"
|
||||||
import * as antd from "antd"
|
import * as antd from "antd"
|
||||||
|
|
||||||
const DebuggersComponents = import.meta.glob("/src/debug/components/**/[a-z[]*.jsx")
|
const DebuggersComponentsPaths = {
|
||||||
|
...import.meta.glob("/src/debug/components/**/[a-z[]*.jsx"),
|
||||||
|
...import.meta.glob("/src/debug/components/**/[a-z[]*.tsx")
|
||||||
|
}
|
||||||
|
|
||||||
|
class DebuggerRender extends React.PureComponent {
|
||||||
|
state = {
|
||||||
|
error: null,
|
||||||
|
}
|
||||||
|
|
||||||
|
componentDidCatch(error, info) {
|
||||||
|
console.error(error, info)
|
||||||
|
this.setState({ error })
|
||||||
|
}
|
||||||
|
|
||||||
|
render() {
|
||||||
|
const { renderFile } = this.props
|
||||||
|
|
||||||
|
if (this.state.error) {
|
||||||
|
return <div>
|
||||||
|
<h1>Something went wrong</h1>
|
||||||
|
<pre>
|
||||||
|
{this.state.error.toString()}
|
||||||
|
</pre>
|
||||||
|
</div>
|
||||||
|
}
|
||||||
|
|
||||||
|
return React.createElement(loadable(renderFile, { fallback: <div>Loading...</div> }))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
export default (props) => {
|
export default (props) => {
|
||||||
const [activeDebugger, setActiveDebugger] = React.useState(null)
|
const [activeDebuggerFile, setActiveDebugger] = React.useState(null)
|
||||||
|
|
||||||
const handleDebbugerSelect = (key) => {
|
const handleDebbugerSelect = (key) => {
|
||||||
setActiveDebugger(key)
|
setActiveDebugger(key)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (activeDebugger) {
|
if (activeDebuggerFile) {
|
||||||
const Debugger = DebuggersComponents[activeDebugger]
|
const DebuggerFile = DebuggersComponentsPaths[activeDebuggerFile]
|
||||||
|
|
||||||
return <div className="debugger">
|
return <div className="debugger">
|
||||||
<div className="debugger_header">
|
<div className="debugger_header">
|
||||||
@ -19,8 +49,9 @@ export default (props) => {
|
|||||||
Back
|
Back
|
||||||
</antd.Button>
|
</antd.Button>
|
||||||
</div>
|
</div>
|
||||||
|
<div className="debugger_content">
|
||||||
<Debugger />
|
<DebuggerRender renderFile={DebuggerFile} />
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -28,13 +59,15 @@ export default (props) => {
|
|||||||
<h1>Select a debugger</h1>
|
<h1>Select a debugger</h1>
|
||||||
|
|
||||||
<div className="debuggerMenu">
|
<div className="debuggerMenu">
|
||||||
{Object.keys(DebuggersComponents).map((key, index) => {
|
{
|
||||||
return <div key={index} className="debuggerMenuItem">
|
Object.keys(DebuggersComponentsPaths).map((key, index) => {
|
||||||
<button onClick={() => handleDebbugerSelect(key)}>
|
return <div key={index} className="debuggerMenuItem">
|
||||||
{key}
|
<button onClick={() => handleDebbugerSelect(key)}>
|
||||||
</button>
|
{key}
|
||||||
</div>
|
</button>
|
||||||
})}
|
</div>
|
||||||
|
})
|
||||||
|
}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
Loading…
x
Reference in New Issue
Block a user