mirror of
https://github.com/wekan/wekan.git
synced 2025-12-24 03:10:12 +01:00
Implement multi-selection
The UI and the internal APIs are still rough around the edges but the feature is basically working. You can now select multiple cards and move them together or (un|)assign them a label.
This commit is contained in:
parent
6457615e6a
commit
2c0030da62
45 changed files with 883 additions and 933 deletions
|
|
@ -1,3 +1,6 @@
|
|||
// XXX Switch to Flow-Router?
|
||||
var previousRoute;
|
||||
|
||||
Router.configure({
|
||||
loadingTemplate: 'spinner',
|
||||
notFoundTemplate: 'notfound',
|
||||
|
|
@ -6,24 +9,43 @@ Router.configure({
|
|||
onBeforeAction: function() {
|
||||
var options = this.route.options;
|
||||
|
||||
var loggedIn = Tracker.nonreactive(function() {
|
||||
return !! Meteor.userId();
|
||||
});
|
||||
|
||||
// Redirect logged in users to Boards view when they try to open Login or
|
||||
// signup views.
|
||||
if (Meteor.userId() && options.redirectLoggedInUsers) {
|
||||
if (loggedIn && options.redirectLoggedInUsers) {
|
||||
return this.redirect('Boards');
|
||||
}
|
||||
|
||||
// Authenticated
|
||||
if (! Meteor.userId() && options.authenticated) {
|
||||
if (! loggedIn && options.authenticated) {
|
||||
return this.redirect('atSignIn');
|
||||
}
|
||||
|
||||
// Reset default sessions
|
||||
Session.set('error', false);
|
||||
|
||||
Tracker.nonreactive(function() {
|
||||
EscapeActions.executeLowerThan(40);
|
||||
if (! options.noEscapeActions &&
|
||||
! (previousRoute && previousRoute.options.noEscapeActions))
|
||||
EscapeActions.executeAll();
|
||||
});
|
||||
|
||||
previousRoute = this.route;
|
||||
|
||||
this.next();
|
||||
}
|
||||
});
|
||||
|
||||
// We want to execute our EscapeActions.executeLowerThan method any time the
|
||||
// route is changed, but not if the stays the same but only the parameters
|
||||
// change (eg when a user is navigation from a card A to a card B). This is why
|
||||
// we can’t put this function in the above `onBeforeAction` that is being run
|
||||
// too many times, instead we register a dependency only on the route name and
|
||||
// use Tracker.autorun. The following paragraph explains the problem quite well:
|
||||
// https://github.com/meteorhacks/flow-router#routercurrent-is-evil
|
||||
// Tracker.autorun(function(computation) {
|
||||
// routeName.get();
|
||||
// if (! computation.firstRun) {
|
||||
// EscapeActions.executeLowerThan('inlinedForm');
|
||||
// }
|
||||
// });
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue