-
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
anyone has reactjs using gristack example #735
Comments
As much as I like gridstack and have been using it for about two years, if you're in a pure react environment I'd recommend looking into this one: https://github.com/STRML/react-grid-layout |
Unfortunately, react-grid-layout doesn't work well on mobile (touch) devices. Is there another alternative? I also like gridstack, but the (fixed) dependencies on jQuery and jQueryUI are a problem for me. |
@derwaldgeist The dependencies will be removed in version 1. This has been delayed for no particularly good reason, but the dependencies will be removed. The resize/dragging functionality will need to be supplemented (I've only been working with one other plugin but any plugin should work - you'll also be able to roll your own if you'd like). @eagoo shoot. I'm sorry. I think there are a few other react tickets open, but I'll leave this open for now. If anyone (anyone!) wants to participate in getting gridstack and react working in harmony, please do so. I'd be happy to link a working example it in the readme. |
@eagoo I'm currently using React with this right now, and I prefer it over react-grid-layout because it uses absolute positioning rather than transformations to move things around, meaning any children with fixed positions aren't thrown off position. The way you want to set it up is by letting React mount your initial widget(s) to the DOM first through its render, then with the lifecycle method
After each time you are adding a widget with React, make sure to then use the API method makeWidget() inside React's lifeycle method
When you remove a widget with React, you must first remove it from the grid system with the API method removeWidget(). Use the React lifecycle method
I hope this was helpful for anyone wishing to incorporate this great plugin with React. @radiolips I don't have an easy-to-read example currently, but I might be able to come up with something in the future if you need it. The setup shouldn't be too complex. |
@derwaldgeist thanks for your effort releasing V1.0. I'm working on a project based on react. Is it possible to use the develop branch right now without the jquery dependency? |
@ramigg I'm not the maintainer, just a potential user :-) |
@derwaldgeist my mistake :) |
@jtheberge can you provide a gist or simple example repo of this working would be helpful |
Closing this ticket, but if someone gets in touch with me with a good react example, I'd be happy to link to it in the README. @ramigg this is obviously a very late response, but the 1.0 code isn't here. There will be a 0.x release probably this weekend, and I'll begin to get back on the 1.0 bandwagon. |
Please refer this repo: https://github.com/Inder2108/react-gridstack-example |
@Inder2108 Thank you, will take a look. but it would be best to use the gridstack npm package (instead of CDN) as that would show actual download usage and help this package. |
@Inder2108 could you modify your example with gridstack 2.2 which you can now import { GridStack } from 'gridstack';
import 'gridstack/dist/gridstack.css'; and use npm package instead of CDN ? and does it follow @jtheberge example above ? (which matches the concept in VueJS example we supply) |
The example app (https://github.com/Inder2108/react-gridstack-example) is now updated to use imports instead of CDN urls in index.html. The example uses "useEffect" instead of "componentDidMount" and other lifecycle hooks as mentioned in @Jtheberg 's example above. |
@Inder2108 thanks for the update - wondering why you didn't use 'componentDidMount' instead... and would be great to get a more complete example than just init() - adding widget and tracking changes, etc... |
I had a functional component in my case so used useEffect - since "componentDidMount" is available for Class based React Components. Will update the example for both "useEffect" and "componentDidMount" and add widgets and tracking examples soon. |
Thank you - that's quite a helpful pointer. Before reading this I was trying to figure out why just mapping grid-stack-items inside the gridstack container didn't work as expected I'm struggling to make this work with a controlled component (where the items are received as props). Do you have any pointer? |
An example based on the post by jtheberge above: import { useEffect, createRef, useRef } from 'react'
import 'gridstack/dist/gridstack.min.css'
import { GridStack } from 'gridstack'
import 'gridstack/dist/h5/gridstack-dd-native'
export default ({someArray}) => {
const refs = useRef({})
if (Object.keys(refs.current).length !== someArray.length) {
someArray.forEach(({ id }) => {
refs.current[id] = refs.current[id] || createRef()
})
}
useEffect(() => {
const grid = GridStack.init()
grid.removeAll(false)
someArray.forEach(({ id }) => {
grid.makeWidget(refs.current[id].current)
})
}, [someArray])
return (
<div className="grid-stack">
{someArray?.map((item, i) => {
return (
<div
ref={refs.current[item.id]}
key={item.id}
className={clsx('grid-stack-item', 'debug')}
gs-w="12"
>
<div className="grid-stack-item-content">
<Item {... etc} />
</div>
</div>
)
})}
</div>
)
} |
@ZachSAEON do you mind updating https://github.com/gridstack/gridstack.js/blob/develop/demo/react.html in a code review instead ? |
Hi. I'm not sure what you mean by a code review, I added a hooks example to the demo folder as a pull request. My example does not completely work as intended though, since sometimes the items switch position when new items are added. The unexpected behavior is in the react-hooks.html file in the pull request, and can be seen as follows:
The order is now Could it be that since I'm removing all items and re-adding them from an array in the original order that this is causing problems (I don't know how the gridstack library works)? useEffect(() => {
const grid = GridStack.init()
grid.removeAll(false) // This seems like it is likely to be a problem
someArray.forEach(({ id }) => {
grid.makeWidget(refs.current[id].current)
})
}, [someArray]) Is it possible to check if a dom node has already been made into a widget? This seems like it might be a better idea: useEffect(() => {
const grid = GridStack.init()
items.forEach(({ id }) => {
if (!grid.getWidgetById(refs.current[id].current)) {
grid.makeWidget(refs.current[id].current)
}
})
}, [items]) (Also. I think I read in the docs somewhere that calling |
oh I didn't see this before your review. Yep all issues you brought up here I commented on them... better to do that in the review than pollute this bug thread. |
* Added example using a controlled React component and hooks. #735 * Updated in response to feedback on #1531 * Fixed state-management bug where old state values were set instead of new state values Co-authored-by: Zach Smith <[email protected]>
while https://github.com/pitrho/react-gridstack is not working
The text was updated successfully, but these errors were encountered: