2021-02-14 13:09:20 -05:00
|
|
|
import { GlToast } from '@gitlab/ui';
|
2020-09-11 20:08:44 -04:00
|
|
|
import Vue from 'vue';
|
2020-09-17 14:10:12 -04:00
|
|
|
import Vuex from 'vuex';
|
2021-01-21 07:09:05 -05:00
|
|
|
import { parseDataAttributes } from 'ee_else_ce/members/utils';
|
2020-09-11 20:08:44 -04:00
|
|
|
import App from './components/app.vue';
|
2021-01-21 07:09:05 -05:00
|
|
|
import membersStore from './store';
|
2020-09-11 20:08:44 -04:00
|
|
|
|
2021-01-21 07:09:05 -05:00
|
|
|
export const initMembersApp = (
|
2020-11-29 04:09:27 -05:00
|
|
|
el,
|
|
|
|
{
|
|
|
|
tableFields = [],
|
|
|
|
tableAttrs = {},
|
|
|
|
tableSortableFields = [],
|
|
|
|
requestFormatter = () => {},
|
|
|
|
filteredSearchBar = { show: false },
|
|
|
|
},
|
|
|
|
) => {
|
2020-09-11 20:08:44 -04:00
|
|
|
if (!el) {
|
|
|
|
return () => {};
|
|
|
|
}
|
|
|
|
|
2020-09-17 14:10:12 -04:00
|
|
|
Vue.use(Vuex);
|
2020-10-15 17:09:12 -04:00
|
|
|
Vue.use(GlToast);
|
2020-09-17 14:10:12 -04:00
|
|
|
|
2020-11-19 07:09:26 -05:00
|
|
|
const store = new Vuex.Store(
|
|
|
|
membersStore({
|
2020-10-12 05:08:38 -04:00
|
|
|
...parseDataAttributes(el),
|
2020-09-17 14:10:12 -04:00
|
|
|
currentUserId: gon.current_user_id || null,
|
2020-09-22 11:09:37 -04:00
|
|
|
tableFields,
|
2020-11-10 16:08:51 -05:00
|
|
|
tableAttrs,
|
2020-11-29 04:09:27 -05:00
|
|
|
tableSortableFields,
|
2020-10-14 14:08:47 -04:00
|
|
|
requestFormatter,
|
2020-11-29 04:09:27 -05:00
|
|
|
filteredSearchBar,
|
2020-09-17 14:10:12 -04:00
|
|
|
}),
|
2020-11-19 07:09:26 -05:00
|
|
|
);
|
2020-09-17 14:10:12 -04:00
|
|
|
|
2020-09-11 20:08:44 -04:00
|
|
|
return new Vue({
|
|
|
|
el,
|
|
|
|
components: { App },
|
2020-09-17 14:10:12 -04:00
|
|
|
store,
|
2020-12-23 19:10:25 -05:00
|
|
|
render: (createElement) => createElement('app'),
|
2020-09-11 20:08:44 -04:00
|
|
|
});
|
|
|
|
};
|