38 lines
1 KiB
JavaScript
38 lines
1 KiB
JavaScript
import { find } from 'lodash';
|
|
import { inactiveId } from '../constants';
|
|
|
|
export default {
|
|
getLabelToggleState: state => (state.isShowingLabels ? 'on' : 'off'),
|
|
isSidebarOpen: state => state.activeId !== inactiveId,
|
|
isSwimlanesOn: state => {
|
|
if (!gon?.features?.boardsWithSwimlanes && !gon?.features?.swimlanes) {
|
|
return false;
|
|
}
|
|
|
|
return state.isShowingEpicsSwimlanes;
|
|
},
|
|
getIssueById: state => id => {
|
|
return state.issues[id] || {};
|
|
},
|
|
|
|
getIssues: (state, getters) => listId => {
|
|
const listIssueIds = state.issuesByListId[listId] || [];
|
|
return listIssueIds.map(id => getters.getIssueById(id));
|
|
},
|
|
|
|
getActiveIssue: state => {
|
|
return state.issues[state.activeId] || {};
|
|
},
|
|
|
|
getListByLabelId: state => labelId => {
|
|
return find(state.boardLists, l => l.label?.id === labelId);
|
|
},
|
|
|
|
getListByTitle: state => title => {
|
|
return find(state.boardLists, l => l.title === title);
|
|
},
|
|
|
|
shouldUseGraphQL: () => {
|
|
return gon?.features?.graphqlBoardLists;
|
|
},
|
|
};
|