import Vue from 'vue'; import VueApollo from 'vue-apollo'; import { mapGetters } from 'vuex'; import BoardsSelector from '~/boards/components/boards_selector.vue'; import BoardsSelectorDeprecated from '~/boards/components/boards_selector_deprecated.vue'; import store from '~/boards/stores'; import createDefaultClient from '~/lib/graphql'; import { parseBoolean } from '~/lib/utils/common_utils'; import glFeatureFlagMixin from '~/vue_shared/mixins/gl_feature_flags_mixin'; Vue.use(VueApollo); const apolloProvider = new VueApollo({ defaultClient: createDefaultClient(), }); export default (params = {}) => { const boardsSwitcherElement = document.getElementById('js-multiple-boards-switcher'); return new Vue({ el: boardsSwitcherElement, components: { BoardsSelector, BoardsSelectorDeprecated, }, mixins: [glFeatureFlagMixin()], apolloProvider, store, provide: { fullPath: params.fullPath, rootPath: params.rootPath, recentBoardsEndpoint: params.recentBoardsEndpoint, }, data() { const { dataset } = boardsSwitcherElement; const boardsSelectorProps = { ...dataset, currentBoard: JSON.parse(dataset.currentBoard), hasMissingBoards: parseBoolean(dataset.hasMissingBoards), canAdminBoard: parseBoolean(dataset.canAdminBoard), multipleIssueBoardsAvailable: parseBoolean(dataset.multipleIssueBoardsAvailable), projectId: dataset.projectId ? Number(dataset.projectId) : 0, groupId: Number(dataset.groupId), scopedIssueBoardFeatureEnabled: parseBoolean(dataset.scopedIssueBoardFeatureEnabled), weights: JSON.parse(dataset.weights), }; return { boardsSelectorProps }; }, computed: { ...mapGetters(['shouldUseGraphQL']), }, render(createElement) { if (this.shouldUseGraphQL) { return createElement(BoardsSelector, { props: this.boardsSelectorProps, }); } return createElement(BoardsSelectorDeprecated, { props: this.boardsSelectorProps, }); }, }); };