Skip to content

Commit efd344c

Browse files
authored
feat: Add resizeable panels (eslint#68)
1 parent b61d954 commit efd344c

File tree

6 files changed

+52
-20
lines changed

6 files changed

+52
-20
lines changed

package-lock.json

Lines changed: 12 additions & 0 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

package.json

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -87,6 +87,7 @@
8787
"npm-run-all": "^4.1.5",
8888
"postcss": "^8",
8989
"prettier": "^3.3.3",
90+
"react-resizable-panels": "^2.1.2",
9091
"tailwindcss": "^3.4.4",
9192
"typescript": "^5.5.3",
9293
"typescript-eslint": "^8.3.0",

src/App.tsx

Lines changed: 33 additions & 19 deletions
Original file line numberDiff line numberDiff line change
@@ -5,6 +5,7 @@ import { tools } from "./lib/tools";
55
import { Editor } from "./components/editor";
66
import { ToolSelector } from "./components/tool-selector";
77
import { ThemeProvider } from "./components/theme-provider";
8+
import { Panel, PanelGroup, PanelResizeHandle } from "react-resizable-panels";
89

910
function App() {
1011
const { language, tool, code, setCode } = useExplorer();
@@ -15,26 +16,39 @@ function App() {
1516
<div className="flex flex-col h-screen">
1617
<Navbar />
1718
<div className="h-full overflow-hidden">
18-
<div className="grid sm:grid-cols-2 divide-x border-t h-full">
19-
<Editor
20-
value={code[language]}
21-
onChange={value => {
22-
setCode({ ...code, [language]: value });
23-
}}
24-
/>
25-
<div className="bg-muted overflow-auto h-[70dvh] sm:h-full relative flex flex-col">
26-
<div className="flex sm:items-center flex-col sm:flex-row justify-between p-4 gap-2 z-10">
27-
<ToolSelector />
28-
<div className="flex items-center gap-1">
29-
{activeTool.options.map(
30-
(Option, index) => (
31-
<Option key={index} />
32-
),
33-
)}
19+
<div className="border-t h-full">
20+
<PanelGroup
21+
direction="horizontal"
22+
className="border-t h-full"
23+
>
24+
<Panel defaultSize={50} minSize={25}>
25+
<Editor
26+
value={code[language]}
27+
onChange={value => {
28+
setCode({
29+
...code,
30+
[language]: value,
31+
});
32+
}}
33+
/>
34+
</Panel>
35+
<PanelResizeHandle className="w-2 bg-gutter dark:bg-gray-600 bg-gray-200 bg-no-repeat bg-center" />
36+
<Panel defaultSize={50} minSize={25}>
37+
<div className="bg-muted overflow-auto h-[70dvh] sm:h-full relative flex flex-col">
38+
<div className="flex sm:items-center flex-col sm:flex-row justify-between p-4 gap-2 z-10">
39+
<ToolSelector />
40+
<div className="flex items-center gap-1">
41+
{activeTool.options.map(
42+
(Option, index) => (
43+
<Option key={index} />
44+
),
45+
)}
46+
</div>
47+
</div>
48+
<activeTool.component />
3449
</div>
35-
</div>
36-
<activeTool.component />
37-
</div>
50+
</Panel>
51+
</PanelGroup>
3852
</div>
3953
</div>
4054
</div>

src/assets/gutter.png

91 Bytes
Loading

src/logo.svg

Lines changed: 0 additions & 1 deletion
This file was deleted.

tailwind.config.js

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -71,6 +71,12 @@ module.exports = {
7171
"accordion-down": "accordion-down 0.2s ease-out",
7272
"accordion-up": "accordion-up 0.2s ease-out",
7373
},
74+
backgroundImage: {
75+
gutter: "url('./assets/gutter.png')",
76+
},
77+
backgroundPosition: {
78+
center: "50%",
79+
},
7480
},
7581
},
7682
plugins: [

0 commit comments

Comments
 (0)