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

Major state refactor #493

Merged
merged 141 commits into from
Jun 22, 2018
Merged
Changes from 1 commit
Commits
Show all changes
141 commits
Select commit Hold shift + click to select a range
c0fe54f
initial
alexreardon May 2, 2018
5883efd
Why does everything need to be some complicated?
alexreardon May 2, 2018
511e911
fixing reordering
alexreardon May 2, 2018
eab420d
changing key
alexreardon May 2, 2018
6c7dad0
collector
alexreardon May 3, 2018
c8e2c79
wip
alexreardon May 3, 2018
8617353
updating droppable dimension publisher
alexreardon May 3, 2018
bed898d
yum
alexreardon May 3, 2018
d951a2d
progress
alexreardon May 4, 2018
513d0b6
progress
alexreardon May 4, 2018
0805272
Merge branch 'master' of github.com:atlassian/react-beautiful-dnd int…
alexreardon May 4, 2018
7ef1da9
cancel drag on any uncaught errors
alexreardon May 6, 2018
756c7a3
initial
alexreardon May 6, 2018
c18cf5d
more accurate placeholder
alexreardon May 6, 2018
3a785c3
moving things around a little
alexreardon May 7, 2018
bc948ec
removing box-sizing
alexreardon May 7, 2018
9f616a0
wip
alexreardon May 7, 2018
184696c
fresh slate
alexreardon May 7, 2018
589ef1e
lets see how we go
alexreardon May 7, 2018
0f1fa90
pushing forward
alexreardon May 7, 2018
ed8a743
moving forward
alexreardon May 7, 2018
8946249
progressing
alexreardon May 8, 2018
cc70c39
moving
alexreardon May 8, 2018
72944e3
moving to middleware
alexreardon May 8, 2018
2ebe6cc
progress
alexreardon May 9, 2018
5521315
yolo
alexreardon May 9, 2018
af9c215
moving away from thunks
alexreardon May 9, 2018
2dfb621
killing it
alexreardon May 9, 2018
ce2e8ad
adding hook placeholder
alexreardon May 10, 2018
597a236
Merge branch 'master' of github.com:atlassian/react-beautiful-dnd int…
alexreardon May 11, 2018
d7b8c9c
upgrading hooks
alexreardon May 13, 2018
4c43a70
progress
alexreardon May 13, 2018
bebb771
Merge branch 'master' of github.com:atlassian/react-beautiful-dnd int…
alexreardon May 13, 2018
f7b265b
hooks are dead. long live hooks
alexreardon May 14, 2018
37dd5db
improving hooks
alexreardon May 14, 2018
53cbb39
progress
alexreardon May 14, 2018
d936e96
cleanup
alexreardon May 14, 2018
7f77585
getting into it
alexreardon May 14, 2018
7ea6a1a
today smells like success
alexreardon May 14, 2018
bac8217
bulk publish flow improvement
alexreardon May 15, 2018
2d7ecc1
yummy test
alexreardon May 15, 2018
a0fd7e8
adding a post drag end abort test
alexreardon May 15, 2018
25b5b36
moving files around
alexreardon May 15, 2018
85da3f4
improving things
alexreardon May 16, 2018
65b7eb0
surely something valuable
alexreardon May 16, 2018
9d0725b
fixing flow types
alexreardon May 17, 2018
beb3be8
cancel drop animating
alexreardon May 17, 2018
962212a
more drop tests
alexreardon May 17, 2018
ffe6d81
window scroll is a little nicer
alexreardon May 17, 2018
1f3812b
reorganing reducer imports
alexreardon May 17, 2018
d6adc0e
wip
alexreardon May 17, 2018
85305a5
Merge branch 'master' of github.com:atlassian/react-beautiful-dnd int…
alexreardon May 17, 2018
bb28a9d
original
alexreardon May 17, 2018
ad6ef18
wip
alexreardon May 17, 2018
9e0708f
moving direction movement into reducer
alexreardon May 17, 2018
cef948c
fixing infinite auto scroll recursion
alexreardon May 17, 2018
6725051
lots o tests
alexreardon May 18, 2018
2ea4a74
starting to look at auto scrolling
alexreardon May 18, 2018
d8d2710
fixing fluid scroller tests
alexreardon May 18, 2018
481f7ab
wip
alexreardon May 18, 2018
637cd00
removing old code
alexreardon May 18, 2018
d484233
almost done with fluid scroller
alexreardon May 18, 2018
a9a64c5
finishing remaining fluid scroller tests
alexreardon May 18, 2018
9daafd1
improving api
alexreardon May 18, 2018
311f1cb
jump scroller
alexreardon May 20, 2018
f9ef7a1
minor changes
alexreardon May 21, 2018
572df8b
moving things around a lot
alexreardon May 21, 2018
f5df39a
viewport is back in action
alexreardon May 21, 2018
edc21bb
drastically improved viewport
alexreardon May 21, 2018
23f50d5
test test tests
alexreardon May 21, 2018
c46f68b
removing older debug
alexreardon May 21, 2018
49b022a
testing++
alexreardon May 23, 2018
04ce4e8
more tests
alexreardon May 23, 2018
3bb4f07
dimension marshal
alexreardon May 23, 2018
966b2c6
more dimension marshal tests
alexreardon May 23, 2018
6182601
hooks integration is a go
alexreardon May 24, 2018
7576193
test wip
alexreardon May 24, 2018
947748e
fixing middleware tests
alexreardon May 24, 2018
3d80f27
lift
alexreardon May 24, 2018
b5aa18d
adding more stories
alexreardon May 25, 2018
e095ec7
wip
alexreardon May 25, 2018
e788c3e
wip
alexreardon May 27, 2018
5a5d2e7
bumping deps
alexreardon Jun 5, 2018
3c0677c
comments
alexreardon Jun 5, 2018
28b74f5
wip post drop updates
alexreardon Jun 5, 2018
eba6d05
fix moveable. fix autoscroll for window
alexreardon Jun 6, 2018
77b3cfd
fixing droppable scrolling
alexreardon Jun 6, 2018
b4df9d4
fixing dimension tests
alexreardon Jun 6, 2018
36a5fde
adding jest typeahead
alexreardon Jun 7, 2018
e6b1a64
bulk replace getting some love
alexreardon Jun 7, 2018
d57cfd4
getting tests ready
alexreardon Jun 7, 2018
00fd3eb
getting closer
alexreardon Jun 8, 2018
d9b9157
working, but not well
alexreardon Jun 8, 2018
ffc440a
progress
alexreardon Jun 12, 2018
fe77d8c
its happening
alexreardon Jun 12, 2018
59c3dc3
using style marshal to clear transitions will collecting
alexreardon Jun 12, 2018
8275cc7
new strategy for draggable dimension correcting
alexreardon Jun 12, 2018
bdf35bc
logging
alexreardon Jun 12, 2018
abb3abc
yeah
alexreardon Jun 12, 2018
2e9b757
updating types
alexreardon Jun 13, 2018
b17857d
yep
alexreardon Jun 13, 2018
b2c52aa
crazy simple use case now working
alexreardon Jun 13, 2018
c5a4dee
getting ready
alexreardon Jun 13, 2018
db7bd19
wip
alexreardon Jun 13, 2018
1bdced5
moving things around
alexreardon Jun 13, 2018
e802a06
loving it
alexreardon Jun 13, 2018
fdef7ae
correctly shifting draggable post update
alexreardon Jun 14, 2018
2add044
placeholder
alexreardon Jun 14, 2018
302d60c
now passing type down through context
alexreardon Jun 14, 2018
212365b
moving forward
alexreardon Jun 15, 2018
60ccbd4
renaming
alexreardon Jun 15, 2018
a6002a9
why hello there my old friend
alexreardon Jun 15, 2018
adfe9a9
new registration tests
alexreardon Jun 15, 2018
c542979
Merge branch 'master' of github.com:atlassian/react-beautiful-dnd int…
alexreardon Jun 15, 2018
41ecab2
more tests
alexreardon Jun 17, 2018
b816d09
dimension marshal tests wrapping up
alexreardon Jun 17, 2018
3e1aa00
finishing sub test
alexreardon Jun 17, 2018
59479bc
draggable and droppable dimension components and tests
alexreardon Jun 18, 2018
59c4c17
its happening
alexreardon Jun 18, 2018
3b4638e
tests everywhere
alexreardon Jun 18, 2018
9a1ef92
renaming and adding tests
alexreardon Jun 18, 2018
de452ca
connected draggable
alexreardon Jun 19, 2018
c396b92
fixing middleware tests
alexreardon Jun 19, 2018
3a012dc
more middleware tests
alexreardon Jun 19, 2018
8db4a5e
fixing middleware tests
alexreardon Jun 19, 2018
c0557bf
moving testing utilities out of connected draggable
alexreardon Jun 19, 2018
25d6f85
connected droppable
alexreardon Jun 19, 2018
e2bd8c6
connected droppable tests
alexreardon Jun 19, 2018
3a9ae20
dropping
alexreardon Jun 20, 2018
89487bb
finishing connected droppable tests
alexreardon Jun 20, 2018
a6fe9cb
draggable tests
alexreardon Jun 20, 2018
b990562
dimensions getting some love
alexreardon Jun 20, 2018
b99c2c3
removing old bulk replace
alexreardon Jun 20, 2018
d962533
fixing tests
alexreardon Jun 20, 2018
b514662
more tests
alexreardon Jun 20, 2018
dd1910d
fixing drag handle
alexreardon Jun 21, 2018
4a4d1cb
fixing touch sensor test
alexreardon Jun 21, 2018
9372d1e
ignoring pesky website cache directory
alexreardon Jun 21, 2018
de8fee6
fixing flow
alexreardon Jun 21, 2018
a0ccc4f
fixing linting
alexreardon Jun 21, 2018
9b28d51
it is okay to end a drag while preparing
alexreardon Jun 21, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
cleanup
alexreardon committed May 14, 2018
commit d936e962033b88698d86540a68b057640ab95cb1
84 changes: 43 additions & 41 deletions src/state/middleware/hooks.js
Original file line number Diff line number Diff line change
@@ -79,6 +79,15 @@ const getExpiringAnnounce = (announce: Announce) => {
return result;
};

const getDragStart = (critical: Critical): DragStart => ({
draggableId: critical.draggable.id,
type: critical.droppable.type,
source: {
droppableId: critical.droppable.id,
index: critical.draggable.index,
},
});

export default (getHooks: () => Hooks, announce: Announce) => {
const execute = (
hook: ?AnyHookFn,
@@ -104,85 +113,78 @@ export default (getHooks: () => Hooks, announce: Announce) => {
};

const publisher = (() => {
let publishedStart: ?DragStart = null;
let lastLocation: ?DraggableLocation = null;
const isDragStartPublished = (): boolean => Boolean(publishedStart);

const start = (initial: DragStart) => {
invariant(!isDragStartPublished(), 'Cannot fire onDragStart as a drag start has already been published');
publishedStart = initial;
lastLocation = initial.source;
withTimings('onDragStart', () => execute(getHooks().onDragStart, initial, messagePreset.onDragStart));
let lastCritical: ?Critical = null;
let isDragStartPublished: boolean = false;

const start = (critical: Critical) => {
invariant(!isDragStartPublished, 'Cannot fire onDragStart as a drag start has already been published');
const data: DragStart = getDragStart(critical);
isDragStartPublished = true;
lastCritical = critical;
lastLocation = data.source;
withTimings('onDragStart', () => execute(getHooks().onDragStart, data, messagePreset.onDragStart));
};

const move = (location: ?DraggableLocation) => {
invariant(isDragStartPublished(), 'Cannot fire onDragMove when onDragStart has not been called');
// Passing in the critical location again as it can change during a drag
const move = (critical: Critical, location: ?DraggableLocation) => {
invariant(isDragStartPublished, 'Cannot fire onDragMove when onDragStart has not been called');

// No change to publish
if (areLocationsEqual(lastLocation, location)) {
return;
}

lastLocation = location;
const update: DragUpdate = {
...publishedStart,
const data: DragUpdate = {
...getDragStart(critical),
destination: location,
};
lastLocation = location;
lastCritical = critical;

withTimings('onDragUpdate', () => execute(getHooks().onDragUpdate, update, messagePreset.onDragUpdate));
withTimings('onDragUpdate', () => execute(getHooks().onDragUpdate, data, messagePreset.onDragUpdate));
};

const end = (result: DropResult) => {
invariant(isDragStartPublished(), 'Cannot fire onDragEnd when there is no matching onDragStart');
publishedStart = null;
const drop = (result: DropResult) => {
invariant(isDragStartPublished, 'Cannot fire onDragEnd when there is no matching onDragStart');
lastLocation = null;
lastCritical = null;
withTimings('onDragEnd', () => execute(getHooks().onDragEnd, result, messagePreset.onDragEnd));
};

const cancel = () => {
invariant(publishedStart, 'Cannot cancel when onDragStart not fired');
// A non user initiated cancel
const abort = () => {
invariant(isDragStartPublished && lastCritical, 'Cannot cancel when onDragStart not fired');

const result: DropResult = {
draggableId: publishedStart.draggableId,
type: publishedStart.type,
source: publishedStart.source,
...getDragStart(lastCritical),
destination: null,
reason: 'CANCEL',
};

end(result);
drop(result);
};

return {
start,
move,
end,
cancel,
drop,
abort,
isDragStartPublished,
};
})();

return (store: Store) => (next: (Action) => mixed) => (action: Action): mixed => {
if (action.type === 'INITIAL_PUBLISH') {
const critical: Critical = action.payload.critical;
const source: DraggableLocation = {
index: critical.draggable.index,
droppableId: critical.droppable.id,
};
const start: DragStart = {
draggableId: critical.draggable.id,
type: critical.droppable.type,
source,
};
publisher.start(start);
publisher.start(critical);
next(action);
return;
}

// Drag end
if (action.type === 'DROP_COMPLETE') {
const result: DropResult = action.payload;
publisher.end(result);
publisher.drop(result);
next(action);
return;
}
@@ -191,8 +193,8 @@ export default (getHooks: () => Hooks, announce: Announce) => {
// we should fire a onDragEnd hook
if (action.type === 'CLEAN') {
// Unmatched drag start call - need to cancel
if (publisher.isDragStartPublished()) {
publisher.cancel();
if (publisher.isDragStartPublished) {
publisher.abort();
}

next(action);
@@ -202,7 +204,7 @@ export default (getHooks: () => Hooks, announce: Announce) => {
// ## Perform drag updates

// No drag updates required
if (!publisher.isDragStartPublished()) {
if (!publisher.isDragStartPublished) {
next(action);
return;
}
@@ -212,7 +214,7 @@ export default (getHooks: () => Hooks, announce: Announce) => {

const state: State = store.getState();
if (state.phase === 'DRAGGING') {
publisher.move(state.impact.destination);
publisher.move(state.critical, state.impact.destination);
}
};
};
Empty file.
Empty file.
Empty file.
Original file line number Diff line number Diff line change
@@ -15,28 +15,41 @@ describe('drop', () => {

});

it('should call the onDragEnd with the drop reason', () => {

});

it('should throw an exception if there was no drag start published', () => {

});
});

describe('cancel', () => {
it('should publish an on drag end with no destination', () => {
describe('update', () => {
it('should call onDragUpdate if the position has changed', () => {

});

// the start location can change after a dynamic update
it('should use the current critical descriptor as the start location', () => {
it('should not call onDragUpdate if the position has not changed from the last update', () => {

});

it('should not do anything if a drag start had not been published', () => {
it('should not call onDragUpdate if there is no movement from the initial location', () => {

});
});

describe('update', () => {
describe('abort', () => {
it('should use the last citical descriptor as the start location', () => {

});

it('should publish an on drag end with no destination even if there is a current destination', () => {

});

it('should not do anything if a drag start had not been published', () => {

});
});

describe('announcements', () => {