debian-mirror-gitlab/app/assets/javascripts/boards/mount_multiple_boards_switcher.js

64 lines
1.9 KiB
JavaScript
Raw Normal View History

2021-12-11 22:18:48 +05:30
import { IntrospectionFragmentMatcher } from 'apollo-cache-inmemory';
2019-09-30 21:07:59 +05:30
import Vue from 'vue';
2020-04-08 14:13:33 +05:30
import VueApollo from 'vue-apollo';
2021-04-17 20:07:23 +05:30
import BoardsSelector from 'ee_else_ce/boards/components/boards_selector.vue';
2021-03-11 19:13:27 +05:30
import store from '~/boards/stores';
2020-04-08 14:13:33 +05:30
import createDefaultClient from '~/lib/graphql';
2019-09-30 21:07:59 +05:30
import { parseBoolean } from '~/lib/utils/common_utils';
2021-12-11 22:18:48 +05:30
import introspectionQueryResultData from '~/sidebar/fragmentTypes.json';
2019-09-30 21:07:59 +05:30
2020-04-08 14:13:33 +05:30
Vue.use(VueApollo);
2021-12-11 22:18:48 +05:30
const fragmentMatcher = new IntrospectionFragmentMatcher({
introspectionQueryResultData,
});
2020-04-08 14:13:33 +05:30
const apolloProvider = new VueApollo({
2021-10-27 15:23:28 +05:30
defaultClient: createDefaultClient(
{},
{
2021-12-11 22:18:48 +05:30
cacheConfig: {
fragmentMatcher,
},
2021-10-27 15:23:28 +05:30
},
),
2020-04-08 14:13:33 +05:30
});
2021-03-08 18:12:59 +05:30
export default (params = {}) => {
2019-09-30 21:07:59 +05:30
const boardsSwitcherElement = document.getElementById('js-multiple-boards-switcher');
2021-12-11 22:18:48 +05:30
const { dataset } = boardsSwitcherElement;
2019-09-30 21:07:59 +05:30
return new Vue({
el: boardsSwitcherElement,
components: {
BoardsSelector,
},
2020-04-08 14:13:33 +05:30
apolloProvider,
2021-03-11 19:13:27 +05:30
store,
2021-03-08 18:12:59 +05:30
provide: {
fullPath: params.fullPath,
rootPath: params.rootPath,
2021-03-11 19:13:27 +05:30
recentBoardsEndpoint: params.recentBoardsEndpoint,
2021-12-11 22:18:48 +05:30
allowScopedLabels: params.allowScopedLabels,
labelsManagePath: params.labelsManagePath,
allowLabelCreate: parseBoolean(dataset.canAdminBoard),
2021-03-08 18:12:59 +05:30
},
2019-09-30 21:07:59 +05:30
data() {
const boardsSelectorProps = {
...dataset,
hasMissingBoards: parseBoolean(dataset.hasMissingBoards),
canAdminBoard: parseBoolean(dataset.canAdminBoard),
multipleIssueBoardsAvailable: parseBoolean(dataset.multipleIssueBoardsAvailable),
scopedIssueBoardFeatureEnabled: parseBoolean(dataset.scopedIssueBoardFeatureEnabled),
weights: JSON.parse(dataset.weights),
};
return { boardsSelectorProps };
},
render(createElement) {
2021-11-11 11:23:49 +05:30
return createElement(BoardsSelector, {
2019-09-30 21:07:59 +05:30
props: this.boardsSelectorProps,
});
},
});
};