diff --git a/src/modules/contact-center/modules/resource-groups/modules/resources/components/opened-resource-group-resources.vue b/src/modules/contact-center/modules/resource-groups/modules/resources/components/opened-resource-group-resources.vue index 692cae4c1..20d716f8a 100644 --- a/src/modules/contact-center/modules/resource-groups/modules/resources/components/opened-resource-group-resources.vue +++ b/src/modules/contact-center/modules/resource-groups/modules/resources/components/opened-resource-group-resources.vue @@ -5,9 +5,9 @@ @close="closePopup" /> @@ -31,7 +31,10 @@ v-if="!disableUserInput" :class="{'hidden': anySelected}" :selected-count="selectedRows.length" - @click="callDelete(selectedRows)" + @click="askDeleteConfirmation({ + deleted: selectedRows, + callback: () => deleteData(selectedRows), + })" /> @@ -110,17 +116,37 @@ import { useDummy } from '../../../../../../../app/composables/useDummy'; import openedObjectTableTabMixin from '../../../../../../../app/mixins/objectPagesMixins/openedObjectTableTabMixin/openedObjectTableTabMixin'; import ResPopup from './opened-resource-group-resource-popup.vue'; +import DeleteConfirmationPopup + from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/components/delete-confirmation-popup.vue'; +import { useDeleteConfirmationPopup } from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/composables/useDeleteConfirmationPopup'; const namespace = 'ccenter/resGroups'; const subNamespace = 'res'; export default { name: 'OpenedResourceGroupResources', - components: { ResPopup }, + components: { ResPopup, DeleteConfirmationPopup }, mixins: [openedObjectTableTabMixin], setup() { const { dummy } = useDummy({ namespace: `${namespace}/${subNamespace}`, hiddenText: true }); - return { dummy }; + const { + isVisible: isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + } = useDeleteConfirmationPopup(); + + return { + dummy, + isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + }; }, data: () => ({ namespace, diff --git a/src/modules/contact-center/modules/resources/components/the-resources.vue b/src/modules/contact-center/modules/resources/components/the-resources.vue index 515b1765f..a56fdf387 100644 --- a/src/modules/contact-center/modules/resources/components/the-resources.vue +++ b/src/modules/contact-center/modules/resources/components/the-resources.vue @@ -11,9 +11,9 @@ @@ -116,16 +122,37 @@ import { useDummy } from '../../../../../app/composables/useDummy'; import tableComponentMixin from '../../../../../app/mixins/objectPagesMixins/objectTableMixin/tableComponentMixin'; import RouteNames from '../../../../../app/router/_internals/RouteNames.enum'; +import DeleteConfirmationPopup + from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/components/delete-confirmation-popup.vue'; +import { useDeleteConfirmationPopup } from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/composables/useDeleteConfirmationPopup'; const namespace = 'ccenter/res'; export default { name: 'TheResources', + components: { DeleteConfirmationPopup }, mixins: [tableComponentMixin], setup() { const { dummy } = useDummy({ namespace, showAction: true }); - return { dummy }; + const { + isVisible: isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + } = useDeleteConfirmationPopup(); + + return { + dummy, + isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + }; }, data: () => ({ namespace, diff --git a/src/modules/contact-center/modules/resources/modules/display/components/opened-resource-numbers.vue b/src/modules/contact-center/modules/resources/modules/display/components/opened-resource-numbers.vue index a058e5d1b..b0e108d90 100644 --- a/src/modules/contact-center/modules/resources/modules/display/components/opened-resource-numbers.vue +++ b/src/modules/contact-center/modules/resources/modules/display/components/opened-resource-numbers.vue @@ -5,9 +5,9 @@ @close="closePopup" /> @@ -31,7 +31,10 @@ v-if="!disableUserInput" :class="{'hidden': anySelected}" :selected-count="selectedRows.length" - @click="callDelete(selectedRows)" + @click="askDeleteConfirmation({ + deleted: selectedRows, + callback: () => deleteData(selectedRows), + })" /> @@ -95,19 +101,40 @@ import { useDummy } from '../../../../../../../app/composables/useDummy'; import openedObjectTableTabMixin from '../../../../../../../app/mixins/objectPagesMixins/openedObjectTableTabMixin/openedObjectTableTabMixin'; import NumberPopup from './opened-resource-numbers-popup.vue'; +import DeleteConfirmationPopup + from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/components/delete-confirmation-popup.vue'; +import { useDeleteConfirmationPopup } from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/composables/useDeleteConfirmationPopup'; const namespace = 'ccenter/res'; const subNamespace = 'numbers'; export default { name: 'OpenedResourceNumber', - components: { NumberPopup }, + components: { NumberPopup, DeleteConfirmationPopup }, mixins: [openedObjectTableTabMixin], setup() { const { dummy } = useDummy({ namespace: `${namespace}/${subNamespace}`, hiddenText: true }); - return { dummy }; + const { + isVisible: isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + } = useDeleteConfirmationPopup(); + + return { + dummy, + isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + }; }, + data: () => ({ namespace, subNamespace, diff --git a/src/modules/contact-center/modules/teams/components/the-teams.vue b/src/modules/contact-center/modules/teams/components/the-teams.vue index be6b58d4a..6b1b0c6b9 100644 --- a/src/modules/contact-center/modules/teams/components/the-teams.vue +++ b/src/modules/contact-center/modules/teams/components/the-teams.vue @@ -11,9 +11,9 @@ @@ -107,16 +113,37 @@ import { kebabToCamel } from '@webitel/ui-sdk/src/scripts/caseConverters'; import { useDummy } from '../../../../../app/composables/useDummy'; import tableComponentMixin from '../../../../../app/mixins/objectPagesMixins/objectTableMixin/tableComponentMixin'; import RouteNames from '../../../../../app/router/_internals/RouteNames.enum'; +import DeleteConfirmationPopup + from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/components/delete-confirmation-popup.vue'; +import { useDeleteConfirmationPopup } from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/composables/useDeleteConfirmationPopup'; const namespace = 'ccenter/teams'; export default { name: 'TheTeams', + components: { DeleteConfirmationPopup }, mixins: [tableComponentMixin], setup() { const { dummy } = useDummy({ namespace, showAction: true }); - return { dummy }; + const { + isVisible: isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + } = useDeleteConfirmationPopup(); + + return { + dummy, + isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + }; }, data: () => ({ namespace, diff --git a/src/modules/contact-center/modules/teams/modules/agents/components/opened-team-agents.vue b/src/modules/contact-center/modules/teams/modules/agents/components/opened-team-agents.vue index 1bee1cc36..c10a73482 100644 --- a/src/modules/contact-center/modules/teams/modules/agents/components/opened-team-agents.vue +++ b/src/modules/contact-center/modules/teams/modules/agents/components/opened-team-agents.vue @@ -5,9 +5,9 @@ @close="closePopup" /> @@ -137,18 +143,38 @@ import RouteNames from '../../../../../../../app/router/_internals/RouteNames.en import agentStatusMixin from '../../../../../mixins/agentStatusMixin'; import agentSupervisorsAndSkillsPopupMixin from '../../../../../mixins/agentSupervisorsAndSkillsPopupMixin'; import AgentPopup from './opened-team-agent-popup.vue'; +import DeleteConfirmationPopup + from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/components/delete-confirmation-popup.vue'; +import { useDeleteConfirmationPopup } from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/composables/useDeleteConfirmationPopup'; const namespace = 'ccenter/teams'; const subNamespace = 'agents'; export default { name: 'OpenedTeamAgents', - components: { AgentPopup, ObjectListPopup }, + components: { AgentPopup, ObjectListPopup, DeleteConfirmationPopup }, mixins: [openedObjectTableTabMixin, agentSupervisorsAndSkillsPopupMixin, agentStatusMixin], setup() { const { dummy } = useDummy({ namespace: `${namespace}/${subNamespace}`, hiddenText: true }); - return { dummy }; + const { + isVisible: isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + } = useDeleteConfirmationPopup(); + + return { + dummy, + isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + }; }, data: () => ({ namespace, diff --git a/src/modules/contact-center/modules/teams/modules/supervisors/components/opened-team-supervisors.vue b/src/modules/contact-center/modules/teams/modules/supervisors/components/opened-team-supervisors.vue index a227e0ea1..00678577d 100644 --- a/src/modules/contact-center/modules/teams/modules/supervisors/components/opened-team-supervisors.vue +++ b/src/modules/contact-center/modules/teams/modules/supervisors/components/opened-team-supervisors.vue @@ -10,9 +10,9 @@ @close="closeSubordinates" /> @@ -36,7 +36,10 @@ v-if="!disableUserInput" :class="{'hidden': anySelected}" :selected-count="selectedRows.length" - @click="callDelete(selectedRows)" + @click="askDeleteConfirmation({ + deleted: selectedRows, + callback: () => deleteData(selectedRows), + })" /> @@ -117,18 +123,42 @@ import openedObjectTableTabMixin import RouteNames from '../../../../../../../app/router/_internals/RouteNames.enum'; import SupervisorSubordinatesPopup from './opened-team-supervisor-subordinates-popup.vue'; import SupervisorPopup from './opened-team-supervisors-popup.vue'; +import DeleteConfirmationPopup + from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/components/delete-confirmation-popup.vue'; +import { useDeleteConfirmationPopup } from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/composables/useDeleteConfirmationPopup'; const namespace = 'ccenter/teams'; const subNamespace = 'supervisors'; export default { name: 'OpenedTeamSupervisors', - components: { SupervisorPopup, SupervisorSubordinatesPopup }, + components: { + SupervisorPopup, + SupervisorSubordinatesPopup, + DeleteConfirmationPopup, + }, mixins: [openedObjectTableTabMixin], setup() { const { dummy } = useDummy({ namespace: `${namespace}/${subNamespace}`, hiddenText: true }); - return { dummy }; + const { + isVisible: isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + } = useDeleteConfirmationPopup(); + + return { + dummy, + isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + }; }, data: () => ({ namespace, diff --git a/src/modules/directory/modules/users/components/the-users.vue b/src/modules/directory/modules/users/components/the-users.vue index 5be6dfb9d..d36045b91 100644 --- a/src/modules/directory/modules/users/components/the-users.vue +++ b/src/modules/directory/modules/users/components/the-users.vue @@ -18,9 +18,9 @@ @close="closeCSVPopup" /> @@ -45,7 +45,10 @@ v-if="hasDeleteAccess" :class="{'hidden': anySelected}" :selected-count="selectedRows.length" - @click="callDelete(selectedRows)" + @click="askDeleteConfirmation({ + deleted: selectedRows, + callback: () => deleteData(selectedRows), + })" /> @@ -134,17 +140,42 @@ import tableComponentMixin from '../../../../../app/mixins/objectPagesMixins/obj import RouteNames from '../../../../../app/router/_internals/RouteNames.enum'; import UserStatus from './_internals/user-status-chips.vue'; import UploadPopup from './upload-users-popup.vue'; +import DeleteConfirmationPopup +from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/components/delete-confirmation-popup.vue'; +import { useDeleteConfirmationPopup } from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/composables/useDeleteConfirmationPopup'; const namespace = 'directory/users'; export default { name: 'TheUsers', - components: { UploadPopup, UserStatus, UploadFileIconBtn }, + components: { + UploadPopup, + UserStatus, + UploadFileIconBtn, + DeleteConfirmationPopup + }, mixins: [tableComponentMixin], setup() { const { dummy } = useDummy({ namespace, hiddenText: true }); - return { dummy }; + const { + isVisible: isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + } = useDeleteConfirmationPopup(); + + return { + dummy, + isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + }; }, data: () => ({ isUploadPopup: false, diff --git a/src/modules/directory/modules/users/modules/tokens/components/opened-user-token.vue b/src/modules/directory/modules/users/modules/tokens/components/opened-user-token.vue index 133185cac..689e042de 100644 --- a/src/modules/directory/modules/users/modules/tokens/components/opened-user-token.vue +++ b/src/modules/directory/modules/users/modules/tokens/components/opened-user-token.vue @@ -10,9 +10,9 @@ @close="closeTokenCreatedPopup" /> @@ -29,7 +29,10 @@ v-if="!disableUserInput" :class="{'hidden': anySelected}" :selected-count="selectedRows.length" - @click="callDelete(selectedRows)" + @click="askDeleteConfirmation({ + deleted: selectedRows, + callback: () => deleteData(selectedRows), + })" /> @@ -88,11 +94,39 @@ import openedObjectTableTabMixin from '../../../../../../../app/mixins/objectPagesMixins/openedObjectTableTabMixin/openedObjectTableTabMixin'; import TokenCreatedPopup from './opened-user-token-created-popup.vue'; import TokenPopup from './opened-user-token-popup.vue'; +import DeleteConfirmationPopup + from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/components/delete-confirmation-popup.vue'; +import { useDeleteConfirmationPopup } from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/composables/useDeleteConfirmationPopup'; export default { name: 'OpenedUserTokens', - components: { TokenPopup, TokenCreatedPopup }, + components: { + TokenPopup, + TokenCreatedPopup, + DeleteConfirmationPopup, + }, mixins: [openedObjectTableTabMixin], + + setup() { + const { + isVisible: isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + } = useDeleteConfirmationPopup(); + + return { + isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + }; + }, + data: () => ({ subNamespace: 'tokens', isPopup: false, diff --git a/src/modules/integrations/modules/cognitive-profiles/components/the-cognitive-profiles.vue b/src/modules/integrations/modules/cognitive-profiles/components/the-cognitive-profiles.vue index b60f9c3b7..d4c5a30f7 100644 --- a/src/modules/integrations/modules/cognitive-profiles/components/the-cognitive-profiles.vue +++ b/src/modules/integrations/modules/cognitive-profiles/components/the-cognitive-profiles.vue @@ -15,9 +15,9 @@ @close="isCognitiveProfilePopup = false" /> @@ -47,7 +47,10 @@ v-if="hasDeleteAccess" :class="{'hidden': anySelected}" :selected-count="selectedRows.length" - @click="callDelete(selectedRows)" + @click="askDeleteConfirmation({ + deleted: selectedRows, + callback: () => deleteData(selectedRows), + })" /> @@ -109,7 +112,10 @@ v-if="hasDeleteAccess" action="delete" class="table-action" - @click="callDelete(item)" + @click="askDeleteConfirmation({ + deleted: [item], + callback: () => deleteData(item), + })" /> @@ -135,6 +141,9 @@ import tableComponentMixin from '../../../../../app/mixins/objectPagesMixins/obj import RouteNames from '../../../../../app/router/_internals/RouteNames.enum'; import dummyPic from '../assets/adm-dummy-cognitive-profiles.svg'; import CreateCognitiveProfilePopup from './create-cognitive-profile-popup.vue'; +import DeleteConfirmationPopup + from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/components/delete-confirmation-popup.vue'; +import { useDeleteConfirmationPopup } from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/composables/useDeleteConfirmationPopup'; const namespace = 'integrations/cognitiveProfiles'; @@ -142,6 +151,7 @@ export default { name: 'TheCognitiveProfiles', components: { CreateCognitiveProfilePopup, + DeleteConfirmationPopup, }, mixins: [tableComponentMixin], @@ -152,7 +162,24 @@ export default { dummyPic, dummyText: 'objects.integrations.emptyWorkspace', }); - return { dummy }; + const { + isVisible: isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + } = useDeleteConfirmationPopup(); + + return { + dummy, + isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + }; }, data: () => ({ namespace, diff --git a/src/modules/integrations/modules/email-profiles/components/the-email-profiles.vue b/src/modules/integrations/modules/email-profiles/components/the-email-profiles.vue index 3647150a3..dd277c691 100644 --- a/src/modules/integrations/modules/email-profiles/components/the-email-profiles.vue +++ b/src/modules/integrations/modules/email-profiles/components/the-email-profiles.vue @@ -11,9 +11,9 @@ @@ -121,11 +127,15 @@ import { useDummy } from '../../../../../app/composables/useDummy'; import tableComponentMixin from '../../../../../app/mixins/objectPagesMixins/objectTableMixin/tableComponentMixin'; import RouteNames from '../../../../../app/router/_internals/RouteNames.enum'; import dummyPic from '../assets/adm-dummy-email-profile.svg'; +import DeleteConfirmationPopup + from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/components/delete-confirmation-popup.vue'; +import { useDeleteConfirmationPopup } from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/composables/useDeleteConfirmationPopup'; const namespace = 'integrations/emailProfiles'; export default { name: 'TheEmailProfiles', + components: { DeleteConfirmationPopup }, mixins: [tableComponentMixin], setup() { @@ -135,7 +145,24 @@ export default { dummyPic, dummyText: 'objects.integrations.emptyWorkspace', }); - return { dummy }; + const { + isVisible: isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + } = useDeleteConfirmationPopup(); + + return { + dummy, + isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + }; }, data: () => ({ namespace, diff --git a/src/modules/integrations/modules/import-csv/components/the-import-csv.vue b/src/modules/integrations/modules/import-csv/components/the-import-csv.vue index 59cb52532..759ceae6e 100644 --- a/src/modules/integrations/modules/import-csv/components/the-import-csv.vue +++ b/src/modules/integrations/modules/import-csv/components/the-import-csv.vue @@ -11,9 +11,9 @@ @@ -117,17 +123,37 @@ import { useDummy } from '../../../../../app/composables/useDummy'; import tableComponentMixin from '../../../../../app/mixins/objectPagesMixins/objectTableMixin/tableComponentMixin'; import RouteNames from '../../../../../app/router/_internals/RouteNames.enum'; import UploadAction from './import-csv-upload-action.vue'; +import DeleteConfirmationPopup + from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/components/delete-confirmation-popup.vue'; +import { useDeleteConfirmationPopup } from '@webitel/ui-sdk/src/modules/DeleteConfirmationPopup/composables/useDeleteConfirmationPopup'; const namespace = 'integrations/importCsv'; export default { name: 'TheImportCsv', - components: { UploadAction }, + components: { UploadAction, DeleteConfirmationPopup }, mixins: [tableComponentMixin], setup() { const { dummy } = useDummy({ namespace, showAction: true }); - return { dummy }; + const { + isVisible: isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + } = useDeleteConfirmationPopup(); + + return { + dummy, + isDeleteConfirmationPopup, + deleteCount, + deleteCallback, + + askDeleteConfirmation, + closeDelete, + }; }, data: () => ({ namespace, diff --git a/src/modules/integrations/modules/single-sign-on/components/the-single-sign-on.vue b/src/modules/integrations/modules/single-sign-on/components/the-single-sign-on.vue index 4e6fec478..6626de41d 100644 --- a/src/modules/integrations/modules/single-sign-on/components/the-single-sign-on.vue +++ b/src/modules/integrations/modules/single-sign-on/components/the-single-sign-on.vue @@ -11,9 +11,9 @@ @@ -100,10 +106,33 @@