150 lines
5.2 KiB
JavaScript
150 lines
5.2 KiB
JavaScript
import Api from '~/api';
|
|
import { createAlert } from '~/alert';
|
|
import axios from '~/lib/utils/axios_utils';
|
|
import { visitUrl, setUrlParams } from '~/lib/utils/url_utility';
|
|
import { logError } from '~/lib/logger';
|
|
import { __ } from '~/locale';
|
|
import { languageFilterData } from '~/search/sidebar/components/language_filter/data';
|
|
import { GROUPS_LOCAL_STORAGE_KEY, PROJECTS_LOCAL_STORAGE_KEY, SIDEBAR_PARAMS } from './constants';
|
|
import * as types from './mutation_types';
|
|
import {
|
|
loadDataFromLS,
|
|
setFrequentItemToLS,
|
|
mergeById,
|
|
isSidebarDirty,
|
|
getAggregationsUrl,
|
|
prepareSearchAggregations,
|
|
} from './utils';
|
|
|
|
export const fetchGroups = ({ commit }, search) => {
|
|
commit(types.REQUEST_GROUPS);
|
|
Api.groups(search, { order_by: 'similarity' })
|
|
.then((data) => {
|
|
commit(types.RECEIVE_GROUPS_SUCCESS, data);
|
|
})
|
|
.catch(() => {
|
|
createAlert({ message: __('There was a problem fetching groups.') });
|
|
commit(types.RECEIVE_GROUPS_ERROR);
|
|
});
|
|
};
|
|
|
|
export const fetchProjects = ({ commit, state }, search) => {
|
|
commit(types.REQUEST_PROJECTS);
|
|
const groupId = state.query?.group_id;
|
|
|
|
const handleCatch = () => {
|
|
createAlert({ message: __('There was an error fetching projects') });
|
|
commit(types.RECEIVE_PROJECTS_ERROR);
|
|
};
|
|
const handleSuccess = ({ data }) => {
|
|
commit(types.RECEIVE_PROJECTS_SUCCESS, data);
|
|
};
|
|
|
|
if (groupId) {
|
|
Api.groupProjects(groupId, search, {
|
|
order_by: 'similarity',
|
|
with_shared: false,
|
|
include_subgroups: true,
|
|
})
|
|
.then(handleSuccess)
|
|
.catch(handleCatch);
|
|
} else {
|
|
// The .catch() is due to the API method not handling a rejection properly
|
|
Api.projects(search, { order_by: 'similarity' }).then(handleSuccess).catch(handleCatch);
|
|
}
|
|
};
|
|
|
|
export const preloadStoredFrequentItems = ({ commit }) => {
|
|
const storedGroups = loadDataFromLS(GROUPS_LOCAL_STORAGE_KEY);
|
|
commit(types.LOAD_FREQUENT_ITEMS, { key: GROUPS_LOCAL_STORAGE_KEY, data: storedGroups });
|
|
|
|
const storedProjects = loadDataFromLS(PROJECTS_LOCAL_STORAGE_KEY);
|
|
commit(types.LOAD_FREQUENT_ITEMS, { key: PROJECTS_LOCAL_STORAGE_KEY, data: storedProjects });
|
|
};
|
|
|
|
export const loadFrequentGroups = async ({ commit, state }) => {
|
|
const storedData = state.frequentItems[GROUPS_LOCAL_STORAGE_KEY];
|
|
const promises = storedData.map((d) => Api.group(d.id));
|
|
try {
|
|
const inflatedData = mergeById(await Promise.all(promises), storedData);
|
|
commit(types.LOAD_FREQUENT_ITEMS, { key: GROUPS_LOCAL_STORAGE_KEY, data: inflatedData });
|
|
} catch {
|
|
createAlert({ message: __('There was a problem fetching recent groups.') });
|
|
}
|
|
};
|
|
|
|
export const loadFrequentProjects = async ({ commit, state }) => {
|
|
const storedData = state.frequentItems[PROJECTS_LOCAL_STORAGE_KEY];
|
|
const promises = storedData.map((d) => Api.project(d.id).then((res) => res.data));
|
|
try {
|
|
const inflatedData = mergeById(await Promise.all(promises), storedData);
|
|
commit(types.LOAD_FREQUENT_ITEMS, { key: PROJECTS_LOCAL_STORAGE_KEY, data: inflatedData });
|
|
} catch {
|
|
createAlert({ message: __('There was a problem fetching recent projects.') });
|
|
}
|
|
};
|
|
|
|
export const setFrequentGroup = ({ state, commit }, item) => {
|
|
const frequentItems = setFrequentItemToLS(GROUPS_LOCAL_STORAGE_KEY, state.frequentItems, item);
|
|
commit(types.LOAD_FREQUENT_ITEMS, { key: GROUPS_LOCAL_STORAGE_KEY, data: frequentItems });
|
|
};
|
|
|
|
export const setFrequentProject = ({ state, commit }, item) => {
|
|
const frequentItems = setFrequentItemToLS(PROJECTS_LOCAL_STORAGE_KEY, state.frequentItems, item);
|
|
commit(types.LOAD_FREQUENT_ITEMS, { key: PROJECTS_LOCAL_STORAGE_KEY, data: frequentItems });
|
|
};
|
|
|
|
export const setQuery = ({ state, commit }, { key, value }) => {
|
|
commit(types.SET_QUERY, { key, value });
|
|
|
|
if (SIDEBAR_PARAMS.includes(key)) {
|
|
commit(types.SET_SIDEBAR_DIRTY, isSidebarDirty(state.query, state.urlQuery));
|
|
}
|
|
};
|
|
|
|
export const applyQuery = ({ state }) => {
|
|
visitUrl(setUrlParams({ ...state.query, page: null }, window.location.href, false, true));
|
|
};
|
|
|
|
export const resetQuery = ({ state }) => {
|
|
visitUrl(
|
|
setUrlParams({ ...state.query, page: null, state: null, confidential: null }, undefined, true),
|
|
);
|
|
};
|
|
|
|
export const resetLanguageQueryWithRedirect = ({ state }) => {
|
|
visitUrl(setUrlParams({ ...state.query, language: null }, undefined, true));
|
|
};
|
|
|
|
export const resetLanguageQuery = ({ commit }) => {
|
|
commit(types.SET_QUERY, { key: languageFilterData?.filterParam, value: [] });
|
|
};
|
|
|
|
export const fetchSidebarCount = ({ commit, state }) => {
|
|
const promises = Object.values(state.navigation).map((navItem) => {
|
|
// active nav item has count already so we skip it
|
|
if (!navItem.active) {
|
|
return axios
|
|
.get(navItem.count_link)
|
|
.then(({ data: { count } }) => {
|
|
commit(types.RECEIVE_NAVIGATION_COUNT, { key: navItem.scope, count });
|
|
})
|
|
.catch((e) => logError(e));
|
|
}
|
|
return Promise.resolve();
|
|
});
|
|
return Promise.all(promises);
|
|
};
|
|
|
|
export const fetchLanguageAggregation = ({ commit, state }) => {
|
|
commit(types.REQUEST_AGGREGATIONS);
|
|
return axios
|
|
.get(getAggregationsUrl())
|
|
.then(({ data }) => {
|
|
commit(types.RECEIVE_AGGREGATIONS_SUCCESS, prepareSearchAggregations(state, data));
|
|
})
|
|
.catch((e) => {
|
|
logError(e);
|
|
commit(types.RECEIVE_AGGREGATIONS_ERROR);
|
|
});
|
|
};
|