Skip to content

Commit

Permalink
pkp/pkp-lib#6528 Disable the delete action instead of hiding it when …
Browse files Browse the repository at this point in the history
…no incomplete submission is listed
  • Loading branch information
jardakotesovec committed Dec 12, 2024
1 parent b1f905c commit 2a00e26
Show file tree
Hide file tree
Showing 4 changed files with 32 additions and 23 deletions.
13 changes: 12 additions & 1 deletion src/components/DropdownActions/DropdownActions.vue
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@
v-for="(action, i) in actions"
:key="i"
v-slot="{active, close}"
:disabled="action.disabled || false"
>
<div class="min-w-[96px]">
<PkpButton
Expand All @@ -57,6 +58,7 @@
:is-warnable="action.isWarnable"
:class="i !== actions.length - 1 ? 'border-b' : ''"
size-variant="fullWidth"
:is-disabled="action.disabled || false"
class="border-light"
@click="
() => {
Expand All @@ -82,7 +84,16 @@ import ButtonIcon from '@/components/ButtonIcon/ButtonIcon.vue';
import Icon from '@/components/Icon/Icon.vue';
defineProps({
/** An array of action objects. Each object should contain `label` (string), `url` (string) to navigate to if the action involves a link, or `name` (string) to perform the action when clicked, an optional `icon` (string) and `isWarnable` (boolean) if the button needs the "warning" button styling from `<Button>` component. */
/**
* An array of action objects.
* Each object should contain
* `label` (string),
* `url` (string) to navigate to if the action involves a link, or
* `name` (string) to perform the action when clicked, an optional
* `icon` (string) and
* `isWarnable` (boolean) if the button needs the "warning" button styling from `<Button>` component.
* `disabled` (boolean) when the item is not available
* */
actions: {
type: Array,
required: true,
Expand Down
3 changes: 2 additions & 1 deletion src/pages/dashboard/components/DashboardBulkActions.vue
Original file line number Diff line number Diff line change
Expand Up @@ -18,12 +18,13 @@ const {t} = useLocalize();
const actions = computed(() => {
const _actions = [];
if (dashboardStore.bulkDeleteDisplayDeleteButton) {
if (dashboardStore.bulkDeleteIsAvailableForUser) {
_actions.push({
label: t('admin.submissions.incomplete.bulkDelete.button'),
name: 'bulkDeleteSelectionEnable',
isWarnable: true,
icon: 'Cancel',
disabled: dashboardStore.bulkDeleteSubmissionIdsCanBeDeleted.length === 0,
});
}
Expand Down
35 changes: 16 additions & 19 deletions src/pages/dashboard/composables/useDashboardBulkDelete.js
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,10 @@ export function useDashboardBulkDelete({
// incomplete submission can be deleted by author of the submission or admin
if (submission.submissionProgress)
if (
hasCurrentUserAtLeastOneRole([pkp.const.ROLE_ID_SITE_ADMIN]) ||
hasCurrentUserAtLeastOneRole([
pkp.const.ROLE_ID_SITE_ADMIN,
pkp.const.ROLE_ID_MANAGER,
]) ||
hasCurrentUserAtLeastOneAssignedRoleInAnyStage(submission, [
pkp.const.ROLE_ID_AUTHOR,
])
Expand All @@ -65,23 +68,18 @@ export function useDashboardBulkDelete({
return false;
}

// Display only for admins and journal managers on editorial dashboard and for author dashboard, where user can delete own submissions
// Display only if some incomplete submissions are in the listing
const bulkDeleteDisplayDeleteButton = computed(() => {
if (bulkDeleteSubmissionIdsCanBeDeleted.value.length > 0) {
if (
dashboardPage === DashboardPageTypes.EDITORIAL_DASHBOARD &&
hasCurrentUserAtLeastOneRole([
pkp.const.ROLE_ID_SITE_ADMIN,
pkp.const.ROLE_ID_MANAGER,
])
) {
return true;
} else if (dashboardPage === DashboardPageTypes.MY_SUBMISSIONS) {
return true;
}
const bulkDeleteIsAvailableForUser = computed(() => {
if (
dashboardPage === DashboardPageTypes.EDITORIAL_DASHBOARD &&
hasCurrentUserAtLeastOneRole([
pkp.const.ROLE_ID_SITE_ADMIN,
pkp.const.ROLE_ID_MANAGER,
])
) {
return true;
} else if (dashboardPage === DashboardPageTypes.MY_SUBMISSIONS) {
return true;
}

return false;
});

Expand All @@ -94,7 +92,6 @@ export function useDashboardBulkDelete({
}
});
}

return submissionIds;
});

Expand Down Expand Up @@ -145,7 +142,7 @@ export function useDashboardBulkDelete({
}

return {
bulkDeleteDisplayDeleteButton,
bulkDeleteIsAvailableForUser,
bulkDeleteSelectionEnabled,
bulkDeleteSelectionEnable,
bulkDeleteSelectionDisable,
Expand Down
4 changes: 2 additions & 2 deletions src/pages/dashboard/dashboardPageStore.js
Original file line number Diff line number Diff line change
Expand Up @@ -238,7 +238,7 @@ export const useDashboardPageStore = defineComponentStore(
* Bulk delete
*/
const {
bulkDeleteDisplayDeleteButton,
bulkDeleteIsAvailableForUser,

bulkDeleteSelectionEnabled,
bulkDeleteSelectionEnable,
Expand Down Expand Up @@ -437,7 +437,7 @@ export const useDashboardPageStore = defineComponentStore(
setCurrentPage,

// Bulk delete
bulkDeleteDisplayDeleteButton,
bulkDeleteIsAvailableForUser,

bulkDeleteSelectionEnabled,
bulkDeleteSelectionEnable,
Expand Down

0 comments on commit 2a00e26

Please sign in to comment.