Skip to content
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

V3 Alpha Issues #78

Open
5 of 11 tasks
JakeSidSmith opened this issue Mar 16, 2017 · 47 comments
Open
5 of 11 tasks

V3 Alpha Issues #78

JakeSidSmith opened this issue Mar 16, 2017 · 47 comments
Labels

Comments

@JakeSidSmith
Copy link
Owner

JakeSidSmith commented Mar 16, 2017

If you've been testing out the V3 alpha, please post your issues here.

It'd also be good to know if V3 has fixed any existing issues you've had.

Reported issues

  • Remove engines from package.json (stupid yarn)
  • Unknown reorderId error when unmounting a group
  • Dragging to a space between items in another group should still place the item in this group
  • Auto-scroll toGroup when dragging to another group (not fromGroup)
  • Do not drag to new group if outside visible area (check root node collision)
  • Serious performance issues with 30+ reorder components
  • Inputs do not retain DOM state when dragging between lists
  • Gatsby window is not defined (move listeners to componentDidMount)
  • Avoid use of deprecated methods

Requested features

  • Option to start reorder only after movement
  • Handle / draggable area
@wmertens
Copy link

wmertens commented Apr 7, 2017

Seems to work great - just one annoyance, the click/drag behavior doesn't seem very natural when you use a hold time, and if you use a short hold time, it intercepts clicks on internal targets.

For it to feel natural, it should only start reordering once you actually touch/click + drag a few pixels. Then the hold time doesn't matter…

In any case, this was super easy to implement 👍

@wmertens
Copy link

wmertens commented Apr 7, 2017

I wonder if it would be better to get the onClick from React, and the rest from document, so that the normal event bubbling works in React?

Also, would it be possible to have a drag handle instead of the whole element?

@wmertens
Copy link

wmertens commented Apr 7, 2017

For supporting a handle, perhaps allow specifying a handle classname and only if the click target has the handle class, proceed with the reorder?

@wmertens
Copy link

wmertens commented Apr 7, 2017

BTW, I did have one problem: Yarn doesn't like to install the npm package because the Node version is capped at v6. I don't see that line in package.json on the rework branch, so could you push a new version?

@JakeSidSmith
Copy link
Owner Author

You can't install the alpha, or do you mean to push a new major version?

@wmertens
Copy link

wmertens commented Apr 10, 2017

@JakeSidSmith If I run yarn add react-reorder, it will complain that my Node is too new to work with the package, because of the version limit on engine. I think there shouldn't be a version limit at all, seeing as how this is meant for the browser?

As you can see in https://unpkg.com/[email protected]/package.json, the package has

"engines": {
  "node": "6.9.1",
  "npm": "3.10.8"
}

@JakeSidSmith
Copy link
Owner Author

@wmertens didn't realise that was in the alpha package.json.

I will remove.

[Insert giant rant about yarn here]

@JakeSidSmith
Copy link
Owner Author

@wmertens published alpha.1.

@niftykins
Copy link

In v3 children are no longer wrapped in a div which has the event handlers applied to it, but instead have the event handlers applied to the child directly. This results in children that are custom components being passed the event handlers as props that have to manually be applied to the resulting DOM element.

Now: (child Item component isn't wrapped)
image

Before: (child Task component was wrapped in a div)
image

(I realise they're images of different examples :( )

Am I meant to manually pass down style, className, onMouseDown, onTouchDown, and data-dragged to the resulting DOM element or am I doing something wrong to not be getting the old "wrapped" element behaviour?

@niftykins
Copy link

When a Reorder component with a reorderGroup prop is unmounted an Unknown reorderId error is thrown.

This block of code is where the error is thrown as a result of registering a component with a reorderGroup not adding the id to the reorderComponents object.

@JakeSidSmith
Copy link
Owner Author

@niftykins thanks for your feedback.

The new version works by cloning any children of the Reorder component, and adds the listeners it needs to handle the reordering at this point. There is no wrapper. Is the problem that your events are not being fired?

As for the reorderId thing, I'll try to take a look when I have a chance, that definitely sounds like a bug.

@niftykins
Copy link

niftykins commented Apr 24, 2017

(Note: code is typed out from memory so I could be forgetting to include some things)

If I change a set of children from

this.state.list.map(function (item) {
  return (
    <li
      key={item.name}
      className={[classNames.listItem, classNames.listItem2].join(' ')}
      style={{color: item.color}}
    >
      {item.name}
    </li>
  );
}.bind(this)).toArray()

to

this.state.list.map(function (item) {
  return <Item key={item.name} item={item} />;
}.bind(this)).toArray()

I have to manually apply all the props that react-reorder adds in order to achieve the same functionality, thus the resulting component becomes:

function Item(props) {
  return (
    <li
      onMouseDown={props.onMouseDown}
      onTouchStart={props.onTouchStart}
      className={[classNames.listItem, classNames.listItem2, props.className].join(' ')}
      style={Object.assign({}, props.style, {color: props.item.color})}
      data-placeholder={props['data-placeholder']}
      data-dragged={props['data-dragged']}
    >
      {props.item.name}
    </li>
  );
}

Having to manually apply the props isn't much of an issue. It just took me awhile to figure out why my reorderable items weren't able to be "picked up" anymore after factoring them out and turning them into stateless components - so there could probably be some mention of the requirement in the README.

@JakeSidSmith
Copy link
Owner Author

Oh, that is hella weird. At the point that Reorder adds the props, the element should have already been resolved. https://facebook.github.io/react/docs/react-api.html#cloneelement

Will do some investigation at some point. @niftykins, if you want to tweak the examples to demonstrate this, as you did for the unmount issue, that'd be really helpful. :)

@niftykins
Copy link

@JakeSidSmith niftykins@a406b5b has a modified example for Lock Vertical

@wmertens
Copy link

wmertens commented Aug 6, 2017

As for the last two blockers for v3, aren't those new features that could be implemented after v3 is released?

@JakeSidSmith
Copy link
Owner Author

Yeah, will probably release after the unmounting thing is sorted. Though I also want to take a look into the above mentioned thing about manually passing props down. There's probably a nicer way to handle this.

@wmertens
Copy link

wmertens commented Aug 6, 2017 via email

@JakeSidSmith
Copy link
Owner Author

@wmertens I had considered this, but having already written v3 in es5, it's quite a bit of work, mainly due to a lack of auto-binding in ES6. Possibly will do this in a future v3.

@wmertens
Copy link

wmertens commented Aug 6, 2017 via email

@JakeSidSmith
Copy link
Owner Author

Id' wait until after v3 is released as it's pretty stable at the moment, and will require some retesting.

@JakeSidSmith
Copy link
Owner Author

JakeSidSmith commented Aug 6, 2017

@wmertens you can start work on that if you like, but things may change a bit while you're doing it.

I imagine there'll be a lot of conflicts.

@JakeSidSmith
Copy link
Owner Author

Just released 3.0.0-alpha.2 with fix for mounting / unmounting reorder groups.

@JakeSidSmith
Copy link
Owner Author

JakeSidSmith commented Aug 6, 2017

@niftykins been playing around with the issue of passing props to the items in the list. Seems the 2 easiest things to do are:

Wrap your component in a regular element

{
  items.map(item => (
    <div className="class" key={item.key}>
      <Item customProp={thing} />
    </div>
  ))
}

Call a stateless functional component with your props

const Item = ({key, thing}) => (
  <li key={key} customProp={thing}>
    Content
  </li>
);

{
  items.map(item => Item({key: item.key, thing}))
}

Perhaps not ideal, but the way reorder works internally now has many more benefits.

@JakeSidSmith
Copy link
Owner Author

Update, probably even easier to just have this if it'd work for your use case:

const Item = (thing, item, index) => (
  <li key={item.key} customProp={thing}>
    Content
  </li>
);

{
  items.map(Item.bind(null, thing))
}

@niftykins
Copy link

Yeah I'm fine with the way it works now, it was just a bit of a surprise because it changed how it worked and I wasn't sure if it was intended or not.

The following approach is what I've been using and has been working alright for me (have to take care to merge values when using ones react-reorder uses too, which is easy enough).

function Item({item, ...otherProps}) {
  return (
    <div {...otherProps}>
      {item.name}
    </div>
  );
}

@niftykins
Copy link

I've found another issue :(

Took the time to the alpha version in the project I'm working on over the weekend because a feature I wanted to implement required the kanban style drag and drop. What I discovered is that when there's 30+ (my use-case was a calendar view) reorder components dragging elements around the screen is noticeably lagged.

Upon digging into this I discovered that each reorder component adds a mousemove event, which down the line (triggerGroup) iterates over all of the components in that group and each of them call setState. For a group of 30 components that equals 900 setState calls every time the mouse moves.

Throttling the calls to the move event and triggerGroup didn't seem to fix the issue and I eventually just made it skip the iteration over the group when triggerGroup was called via the mousemove flow which seemed to make the issue go away.

You can view the changes here: niftykins@e8eab16

This seemed more of a hack fix just to get it working, I'm sure with a better understanding of how everything works together you'll be able to come up with something better.

@ndugger
Copy link

ndugger commented Nov 28, 2017

To pile onto @niftykins discovery, I'm finding some performance issue while dragging in IE11. Now, I don't expect IE to be as fast as say chrome, but I've only got 12 items to drag around on the screen, and the translation from dragging is coming off as really laggy. I might have to find a different library if it persists, which I'd really rather not do, since yours works the best.

If you could dig into what niftykins said about the triggerGroup, that would be very helpful.

@JakeSidSmith
Copy link
Owner Author

JakeSidSmith commented Nov 28, 2017

@ndugger I've since been doing some digging into general performance improvements in React applications. Can you tell me:

Are your reorderable items or any of their props created in the render method, or mapStateToProps?

Are you using fat arrows or bind in your JSX?

A code snippet would be very useful. :)

@ndugger
Copy link

ndugger commented Nov 28, 2017

I'll try to get a MVCE set up for you; in the meantime, you should experiment with using CSS translation instead of using a fixed position with top and left. I think translation would be much more performant.

@JakeSidSmith
Copy link
Owner Author

That it would. I will consider that. 👍

@JakeSidSmith
Copy link
Owner Author

Holy sh*t. I now see the issue. Just managed to reproduce myself. Didn't realise you guys meant the issue happens when there's a lot of Reorder components. I thought you meant the items within them.

@ndugger @niftykins

Will definitely spend some time on this. That performance is unacceptable.

May have a big re-write of the store.

@JakeSidSmith
Copy link
Owner Author

JakeSidSmith commented Nov 28, 2017

@ndugger @niftykins you will be very happy to hear that I have fixed the performance issue.

Just published with version 3.0.0-alpha.3

Thank you both for testing the alpha version and reporting issues. 🙂

@JakeSidSmith
Copy link
Owner Author

And have now published 3.0.0-alpha.4 with translate to offset the items. @ndugger

Let me know if your performance issues are resolved. 🙂

@JakeSidSmith
Copy link
Owner Author

Note to self: Mutate styles when translating the dragged item's offset to improve performance.

@ndugger
Copy link

ndugger commented Nov 28, 2017

At first glance, it seems improved. I will test more on IE11 as soon as I can and report back. You're pretty awesome for being so on the ball here.

@JakeSidSmith
Copy link
Owner Author

I will probably rewrite my store anyway, for sanity. But for today this should be a suitable fix. :)

@niftykins
Copy link

What's the advised way to handle click events (more specifically, block click events when dragging) on items (eg kanban where clicking on an item expands it into a more detailed view)? The issue I'm getting is when I reorder an item up (but not down, strangely) the onClick handler is also triggered upon mouse up, which is undesirable.

I've been able to reproduce it in the demo at https://github.com/niftykins/react-reorder/tree/click-function with some minor changes.

@CadiChris
Copy link

CadiChris commented Dec 21, 2017

@niftykins, to prevent the onClick handler to be triggered, I've used some CSS

.dragged: {
  pointer-events: none;
}

.dragged is the class applied to the dragged item, pointer-events indicates how it should behave regarding events.
https://caniuse.com/#search=pointer-events : This CSS property, when set to "none" allows elements to not receive hover/click events, instead the event will occur on anything behind it.

It works as expected for me !

@JakeSidSmith
Copy link
Owner Author

@niftykins have you set a holdTime? Is this only when the mouse does not move?

@niftykins
Copy link

@CadiChris that did the trick! thanks!

@JakeSidSmith Yes there's a hold time of 150ms, it occurs both when the mouse moves and when the mouse doesn't move.

@JakeSidSmith
Copy link
Owner Author

It should be super easy to fix with javascript. Which would be best as pointer-events is only supported in IE11+.

Will try to sort asap. :)

@JakeSidSmith JakeSidSmith mentioned this issue Apr 8, 2018
30 tasks
@r3wt
Copy link

r3wt commented May 18, 2018

not sure if this is dead, but just wanted to chime in on an issue i find annoying. it seems to glitch rapidly while dragging for me. needs some type of debounce or something

@mcculloughjchris
Copy link

mcculloughjchris commented Jun 5, 2018

@JakeSidSmith hey, you made a great plugin, super easy to implement. Currently I'm using Gatsby, and when I run gatsby build I get this error:

  684 |       componentWillMount: function () {
  685 |         store.registerReorderComponent(this);
> 686 |         window.addEventListener('mouseup', this.onWindowUp, {passive: false});
      | ^
  687 |         window.addEventListener('touchend', this.onWindowUp, {passive: false});
  688 |         window.addEventListener('mousemove', this.onWindowMove, {passive: false});
  689 |         window.addEventListener('touchmove', this.onWindowMove, {passive: false});


  WebpackError: window is not defined

Moving everything in componentWillMount to componentDidMount seems to fix the problem, and doesn't (appear) to break anything else. I think componentWillMount is being deprecated or already has been anyways. I would make a pull request but I'm not sure how to for alpha.

@JakeSidSmith
Copy link
Owner Author

@mcculloughjchris thanks for bringing this to my attention.

This issue covers what you have experienced: gatsbyjs/gatsby#309

It seems the best approach (due to the recent deprecation) is to move these to componentDidMount, rather than safe-guarding existence of the window object.

You can open a PR for v3 by forking this repo, checking out the rework branch, and then opening a PR against rework with your changes. 🙂

@JakeSidSmith
Copy link
Owner Author

@mcculloughjchris Merged #96 and published as 3.0.0-alpha.7. 🙂

@mcculloughjchris
Copy link

Thanks!

@tmm1
Copy link

tmm1 commented Nov 15, 2020

FYI with v17 we need to rename to UNSAFE_componentWillMount:

react_devtools_backend.js:2430 Warning: componentWillMount has been renamed, and is not recommended for use. See https://fb.me/react-unsafe-component-lifecycles for details.

* Move code with side effects to componentDidMount, and set initial state in the constructor.
* Rename componentWillMount to UNSAFE_componentWillMount to suppress this warning in non-strict mode. In React 17.x, only the UNSAFE_ name will work. To rename all deprecated lifecycles to their new names, you can run `npx react-codemod rename-unsafe-lifecycles` in your project source folder.

Please update the following components: Reorder

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

8 participants