* feat: sort by position * chore: whitespace change * feat: add border bottom color to list item * feat: allow dragging articles * feat: add migration to reorder all articles * feat: add onsort method * feat: finish UI sorting * feat: show 50 per page in articles list * feat: add article sorting methods * feat: patch up reorder action with the API * refactor: better naming * chore: add comments * feat: attach position to article before create * feat: move article to end if moved between categories * chore: add comments * chore: update version * fix: don't change position if previous category was nil * fix: condition to trigger update on category change * refactor: store new_position * refactor: use grid instead of table * feat: add snug spacing * feat: add grab-icon * feat: add grab icon to list * refactor: show draggable only for category page * feat: add update_positions as a class method --------- Co-authored-by: Nithin David Thomas <1277421+nithindavid@users.noreply.github.com>
158 lines
3.9 KiB
JavaScript
158 lines
3.9 KiB
JavaScript
import articlesAPI from 'dashboard/api/helpCenter/articles';
|
|
import { throwErrorMessage } from 'dashboard/store/utils/api';
|
|
|
|
import types from '../../mutation-types';
|
|
export const actions = {
|
|
index: async (
|
|
{ commit },
|
|
{ pageNumber, portalSlug, locale, status, author_id, category_slug }
|
|
) => {
|
|
try {
|
|
commit(types.SET_UI_FLAG, { isFetching: true });
|
|
const {
|
|
data: { payload, meta },
|
|
} = await articlesAPI.getArticles({
|
|
pageNumber,
|
|
portalSlug,
|
|
locale,
|
|
status,
|
|
author_id,
|
|
category_slug,
|
|
});
|
|
const articleIds = payload.map(article => article.id);
|
|
commit(types.CLEAR_ARTICLES);
|
|
commit(types.ADD_MANY_ARTICLES, payload);
|
|
commit(types.SET_ARTICLES_META, meta);
|
|
commit(types.ADD_MANY_ARTICLES_ID, articleIds);
|
|
return articleIds;
|
|
} catch (error) {
|
|
return throwErrorMessage(error);
|
|
} finally {
|
|
commit(types.SET_UI_FLAG, { isFetching: false });
|
|
}
|
|
},
|
|
|
|
create: async ({ commit, dispatch }, { portalSlug, ...articleObj }) => {
|
|
commit(types.SET_UI_FLAG, { isCreating: true });
|
|
try {
|
|
const {
|
|
data: { payload },
|
|
} = await articlesAPI.createArticle({
|
|
portalSlug,
|
|
articleObj,
|
|
});
|
|
const { id: articleId } = payload;
|
|
commit(types.ADD_ARTICLE, payload);
|
|
commit(types.ADD_ARTICLE_ID, articleId);
|
|
commit(types.ADD_ARTICLE_FLAG, articleId);
|
|
dispatch('portals/updatePortal', portalSlug, { root: true });
|
|
return articleId;
|
|
} catch (error) {
|
|
return throwErrorMessage(error);
|
|
} finally {
|
|
commit(types.SET_UI_FLAG, { isCreating: false });
|
|
}
|
|
},
|
|
|
|
show: async ({ commit }, { id, portalSlug }) => {
|
|
commit(types.SET_UI_FLAG, { isFetching: true });
|
|
try {
|
|
const response = await articlesAPI.getArticle({ id, portalSlug });
|
|
const {
|
|
data: { payload },
|
|
} = response;
|
|
const { id: articleId } = payload;
|
|
commit(types.ADD_ARTICLE, payload);
|
|
commit(types.ADD_ARTICLE_ID, articleId);
|
|
commit(types.SET_UI_FLAG, { isFetching: false });
|
|
} catch (error) {
|
|
commit(types.SET_UI_FLAG, { isFetching: false });
|
|
}
|
|
},
|
|
|
|
update: async ({ commit }, { portalSlug, articleId, ...articleObj }) => {
|
|
commit(types.UPDATE_ARTICLE_FLAG, {
|
|
uiFlags: {
|
|
isUpdating: true,
|
|
},
|
|
articleId,
|
|
});
|
|
|
|
try {
|
|
const {
|
|
data: { payload },
|
|
} = await articlesAPI.updateArticle({
|
|
portalSlug,
|
|
articleId,
|
|
articleObj,
|
|
});
|
|
|
|
commit(types.UPDATE_ARTICLE, payload);
|
|
|
|
return articleId;
|
|
} catch (error) {
|
|
return throwErrorMessage(error);
|
|
} finally {
|
|
commit(types.UPDATE_ARTICLE_FLAG, {
|
|
uiFlags: {
|
|
isUpdating: false,
|
|
},
|
|
articleId,
|
|
});
|
|
}
|
|
},
|
|
|
|
delete: async ({ commit }, { portalSlug, articleId }) => {
|
|
commit(types.UPDATE_ARTICLE_FLAG, {
|
|
uiFlags: {
|
|
isDeleting: true,
|
|
},
|
|
articleId,
|
|
});
|
|
try {
|
|
await articlesAPI.deleteArticle({ portalSlug, articleId });
|
|
commit(types.REMOVE_ARTICLE, articleId);
|
|
commit(types.REMOVE_ARTICLE_ID, articleId);
|
|
return articleId;
|
|
} catch (error) {
|
|
return throwErrorMessage(error);
|
|
} finally {
|
|
commit(types.UPDATE_ARTICLE_FLAG, {
|
|
uiFlags: {
|
|
isDeleting: false,
|
|
},
|
|
articleId,
|
|
});
|
|
}
|
|
},
|
|
|
|
attachImage: async (_, { portalSlug, file }) => {
|
|
try {
|
|
const {
|
|
data: { file_url: fileUrl },
|
|
} = await articlesAPI.uploadImage({
|
|
portalSlug,
|
|
file,
|
|
});
|
|
return fileUrl;
|
|
} catch (error) {
|
|
throwErrorMessage(error);
|
|
}
|
|
return '';
|
|
},
|
|
|
|
reorder: async (_, { portalSlug, categorySlug, reorderedGroup }) => {
|
|
try {
|
|
await articlesAPI.reorderArticles({
|
|
portalSlug,
|
|
reorderedGroup,
|
|
categorySlug,
|
|
});
|
|
} catch (error) {
|
|
throwErrorMessage(error);
|
|
}
|
|
|
|
return '';
|
|
},
|
|
};
|