mirror of
https://github.com/plankanban/planka.git
synced 2025-07-18 20:59:44 +02:00
135 lines
3 KiB
JavaScript
135 lines
3 KiB
JavaScript
import { call, put, select, take } from 'redux-saga/effects';
|
|
import { push } from '../../../lib/redux-router';
|
|
|
|
import request from '../request';
|
|
import selectors from '../../../selectors';
|
|
import actions from '../../../actions';
|
|
import api from '../../../api';
|
|
import ActionTypes from '../../../constants/ActionTypes';
|
|
import Paths from '../../../constants/Paths';
|
|
|
|
export function* goToRoot() {
|
|
yield put(push(Paths.ROOT));
|
|
}
|
|
|
|
export function* goToProject(projectId) {
|
|
yield put(push(Paths.PROJECTS.replace(':id', projectId)));
|
|
}
|
|
|
|
export function* goToBoard(boardId) {
|
|
yield put(push(Paths.BOARDS.replace(':id', boardId)));
|
|
}
|
|
|
|
export function* goToCard(cardId) {
|
|
yield put(push(Paths.CARDS.replace(':id', cardId)));
|
|
}
|
|
|
|
export function* handleLocationChange() {
|
|
const pathsMatch = yield select(selectors.selectPathsMatch);
|
|
|
|
if (!pathsMatch) {
|
|
return;
|
|
}
|
|
|
|
switch (pathsMatch.pattern.path) {
|
|
case Paths.LOGIN:
|
|
case Paths.OIDC_CALLBACK:
|
|
yield call(goToRoot);
|
|
|
|
return;
|
|
default:
|
|
}
|
|
|
|
const isInitializing = yield select(selectors.selectIsInitializing);
|
|
|
|
if (isInitializing) {
|
|
yield take(ActionTypes.CORE_INITIALIZE);
|
|
}
|
|
|
|
let board;
|
|
let users;
|
|
let projects;
|
|
let boardMemberships;
|
|
let labels;
|
|
let lists;
|
|
let cards;
|
|
let cardMemberships;
|
|
let cardLabels;
|
|
let tasks;
|
|
let attachments;
|
|
let deletedNotifications;
|
|
|
|
switch (pathsMatch.pattern.path) {
|
|
case Paths.BOARDS:
|
|
case Paths.CARDS: {
|
|
const currentBoard = yield select(selectors.selectCurrentBoard);
|
|
|
|
if (currentBoard && currentBoard.isFetching === null) {
|
|
yield put(actions.handleLocationChange.fetchBoard(currentBoard.id));
|
|
|
|
try {
|
|
({
|
|
item: board,
|
|
included: {
|
|
users,
|
|
projects,
|
|
boardMemberships,
|
|
labels,
|
|
lists,
|
|
cards,
|
|
cardMemberships,
|
|
cardLabels,
|
|
tasks,
|
|
attachments,
|
|
},
|
|
} = yield call(request, api.getBoard, currentBoard.id, true));
|
|
} catch (error) {} // eslint-disable-line no-empty
|
|
}
|
|
|
|
if (pathsMatch.pattern.path === Paths.CARDS) {
|
|
const notificationIds = yield select(selectors.selectNotificationIdsForCurrentCard);
|
|
|
|
if (notificationIds && notificationIds.length > 0) {
|
|
try {
|
|
({ items: deletedNotifications } = yield call(
|
|
request,
|
|
api.updateNotifications,
|
|
notificationIds,
|
|
{
|
|
isRead: true,
|
|
},
|
|
));
|
|
} catch (error) {} // eslint-disable-line no-empty
|
|
}
|
|
}
|
|
|
|
break;
|
|
}
|
|
default:
|
|
}
|
|
|
|
yield put(
|
|
actions.handleLocationChange(
|
|
board,
|
|
users,
|
|
projects,
|
|
boardMemberships,
|
|
labels,
|
|
lists,
|
|
cards,
|
|
cardMemberships,
|
|
cardLabels,
|
|
tasks,
|
|
attachments,
|
|
deletedNotifications,
|
|
),
|
|
);
|
|
}
|
|
|
|
export default {
|
|
goToRoot,
|
|
goToProject,
|
|
goToBoard,
|
|
goToCard,
|
|
handleLocationChange,
|
|
};
|