Skip to content

Commit

Permalink
Added example using a controlled React component and hooks. gridstack…
Browse files Browse the repository at this point in the history
  • Loading branch information
Zach Smith authored and zachsa committed Dec 10, 2020
1 parent 7014975 commit 65d70da
Show file tree
Hide file tree
Showing 3 changed files with 96 additions and 1 deletion.
1 change: 1 addition & 0 deletions demo/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ <h1>Demos</h1>
<li><a href="nested.html">Nested grids</a></li>
<li><a href="responsive.html">Responsive</a></li>
<li><a href="react.html">ReactJS</a></li>
<li><a href="react-hooks.html">ReactJS (Hooks)</a></li>
<li><a href="right-to-left(rtl).html">Right-To-Left (RTL)</a></li>
<li><a href="serialization.html">Serialization</a></li>
<li><a href="static.html">Static</a></li>
Expand Down
94 changes: 94 additions & 0 deletions demo/react-hooks.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,94 @@
<!DOCTYPE html>
<html>

<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Gridstack.js React integration example</title>
<link rel="stylesheet" href="demo.css" />
<script src="../dist/gridstack-h5.js"></script>

<!-- Scripts to use react inside html -->
<script src="https://unpkg.com/react@16/umd/react.production.min.js"></script>
<script src="https://unpkg.com/react-dom@16/umd/react-dom.production.min.js"></script>
<script src="https://unpkg.com/[email protected]/babel.min.js"></script>
</head>

<body>
<div id="root"></div>
</body>

<script type="text/babel">
const { useState, useEffect, createRef, useRef } = React

const Item = ({ id }) => <div>I am item: {id}</div>

const ControlledStack = ({ items, addItem }) => {
const refs = useRef({})

if (Object.keys(refs.current).length !== items.length) {
items.forEach(({ id }) => {
refs.current[id] = refs.current[id] || createRef()
})
}

useEffect(() => {
const grid = GridStack.init()
grid.removeAll(false)
items.forEach(({ id }) => {
grid.makeWidget(refs.current[id].current)
})
}, [items])

return (
<div>
<button onClick={addItem}>Add new widget</button>
<div className="grid-stack">
{items.map((item, i) => {
return (
<div
ref={refs.current[item.id]}
key={item.id}
className={'grid-stack-item'}
gs-w="12"
>
<div className="grid-stack-item-content">
<Item {...item} />
</div>
</div>
)
})}
</div>
</div>
)
}

const App = props => {
const [items, setItems] = useState([
{ id: 'item-1' },
{ id: 'item-2' }
])

return (
<div>
<h1>Using GridStack.js with controlled React component and hooks</h1>
<p>
As with any virtualDOM-based framework, you need to check if React
has rendered the DOM (or any updates to it){" "}
<strong>before</strong> you initialize GridStack or call its
methods. This example shows how to make rendered components widgets:
</p>
<ol>
<li>Render items, each with a reference</li>
<li>Convert each rendered item to a widget using the reference and the <a href="https://github.com/gridstack/gridstack.js/tree/develop/doc#makewidgetel">
makeWidget</a> function</li>
</ol>
<ControlledStack items={items} addItem={() => setItems([...items, { id: `item-${items.length + 1}` }])} />
</div>
)
}

ReactDOM.render(<App />, document.getElementById("root"))
</script>

</html>
2 changes: 1 addition & 1 deletion doc/CHANGES.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ Change log
<!-- DON'T EDIT THIS SECTION, INSTEAD RE-RUN doctoc TO UPDATE -->
**Table of Contents** *generated with [DocToc](http://doctoc.herokuapp.com/)*

- [3.1.2 (2020-12-7)](#311-2020-12-7)
- [3.1.2 (2020-12-7)](#312-2020-12-7)
- [3.1.0 (2020-12-4)](#310-2020-12-4)
- [3.0.0 (2020-11-29)](#300-2020-11-29)
- [2.2.0 (2020-11-7)](#220-2020-11-7)
Expand Down

0 comments on commit 65d70da

Please sign in to comment.