Skip to content

Commit

Permalink
Merge pull request ppy#11747 from nanaya/profile-sortable-delay
Browse files Browse the repository at this point in the history
Fix profile page reorder not working without full reload
  • Loading branch information
notbakaneko authored Dec 17, 2024
2 parents 94838db + e2faccc commit 1f46b13
Showing 1 changed file with 32 additions and 30 deletions.
62 changes: 32 additions & 30 deletions resources/js/profile-page/main.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -120,37 +120,39 @@ export default class Main extends React.Component<Props> {
// pageScan does not need to run at 144 fps...
$(window).on(scrollEventId, throttle(() => this.pageScan(), 20));

if (this.pages.current != null) {
$(this.pages.current).sortable({
cursor: 'move',
handle: '.js-profile-page-extra--sortable-handle',
items: '.js-sortable--page',
revert: 150,
scrollSpeed: 10,
update: this.updateOrder,
});
}
this.disposers.add(core.reactTurbolinks.runAfterPageLoad(() => {
if (this.pages.current != null) {
$(this.pages.current).sortable({
cursor: 'move',
handle: '.js-profile-page-extra--sortable-handle',
items: '.js-sortable--page',
revert: 150,
scrollSpeed: 10,
update: this.updateOrder,
});
}

if (this.tabs.current != null) {
$(this.tabs.current).sortable({
axis: 'x',
cursor: 'move',
disabled: !this.controller.withEdit,
items: '.js-sortable--tab',
revert: 150,
scrollSpeed: 0,
start: () => {
// Somehow click event still goes through when dragging.
// This prevents triggering onTabClick.
window.clearTimeout(this.timeouts.draggingTab);
this.draggingTab = true;
},
stop: () => {
this.timeouts.draggingTab = window.setTimeout(() => this.draggingTab = false, 500);
},
update: this.updateOrder,
});
}
if (this.tabs.current != null) {
$(this.tabs.current).sortable({
axis: 'x',
cursor: 'move',
disabled: !this.controller.withEdit,
items: '.js-sortable--tab',
revert: 150,
scrollSpeed: 0,
start: () => {
// Somehow click event still goes through when dragging.
// This prevents triggering onTabClick.
window.clearTimeout(this.timeouts.draggingTab);
this.draggingTab = true;
},
stop: () => {
this.timeouts.draggingTab = window.setTimeout(() => this.draggingTab = false, 500);
},
update: this.updateOrder,
});
}
}));

// preserve scroll if existing saved state but force position to reset
// on refresh to avoid browser setting scroll position at the bottom on reload.
Expand Down

0 comments on commit 1f46b13

Please sign in to comment.