@webitel/ui-sdk 24.6.17 → 24.6.18
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/img/plyr.svg +77 -68
- package/dist/img/sprite/account.svg +4 -2
- package/dist/img/sprite/adfs.svg +7 -3
- package/dist/img/sprite/agent.svg +4 -3
- package/dist/img/sprite/app-navigator.svg +9 -9
- package/dist/img/sprite/arrow-down.svg +2 -1
- package/dist/img/sprite/arrow-left.svg +2 -1
- package/dist/img/sprite/arrow-mix.svg +3 -3
- package/dist/img/sprite/arrow-right.svg +2 -1
- package/dist/img/sprite/arrow-up.svg +2 -1
- package/dist/img/sprite/attach.svg +2 -1
- package/dist/img/sprite/attention.svg +2 -1
- package/dist/img/sprite/azure.svg +25 -17
- package/dist/img/sprite/back.svg +2 -2
- package/dist/img/sprite/bot.svg +4 -3
- package/dist/img/sprite/bucket.svg +2 -1
- package/dist/img/sprite/calendar.svg +2 -1
- package/dist/img/sprite/call--filled.svg +1 -1
- package/dist/img/sprite/call-add-to--filled.svg +2 -2
- package/dist/img/sprite/call-add-to.svg +3 -2
- package/dist/img/sprite/call-disconnect--filled.svg +2 -1
- package/dist/img/sprite/call-disconnect.svg +2 -1
- package/dist/img/sprite/call-end--filled.svg +2 -1
- package/dist/img/sprite/call-end.svg +2 -1
- package/dist/img/sprite/call-inbound--filled.svg +3 -2
- package/dist/img/sprite/call-inbound.svg +2 -1
- package/dist/img/sprite/call-missed--filled.svg +2 -2
- package/dist/img/sprite/call-missed.svg +2 -1
- package/dist/img/sprite/call-outbound--filled.svg +2 -1
- package/dist/img/sprite/call-outbound.svg +2 -1
- package/dist/img/sprite/call-ringing--filled.svg +4 -3
- package/dist/img/sprite/call-ringing.svg +2 -1
- package/dist/img/sprite/call-transfer--filled.svg +2 -2
- package/dist/img/sprite/call-transfer.svg +2 -1
- package/dist/img/sprite/call.svg +2 -1
- package/dist/img/sprite/chat--filled.svg +1 -1
- package/dist/img/sprite/chat-emoji.svg +2 -1
- package/dist/img/sprite/chat-end--filled.svg +2 -1
- package/dist/img/sprite/chat-end.svg +3 -2
- package/dist/img/sprite/chat-group.svg +5 -3
- package/dist/img/sprite/chat-join.svg +3 -2
- package/dist/img/sprite/chat-message-status-read.svg +2 -1
- package/dist/img/sprite/chat-message-status-sent.svg +2 -1
- package/dist/img/sprite/chat-quick-response--filled.svg +2 -1
- package/dist/img/sprite/chat-quick-response.svg +2 -1
- package/dist/img/sprite/chat-reply.svg +2 -1
- package/dist/img/sprite/chat-send.svg +5 -4
- package/dist/img/sprite/chat-transfer--filled.svg +2 -1
- package/dist/img/sprite/chat-transfer.svg +3 -2
- package/dist/img/sprite/chat.svg +2 -1
- package/dist/img/sprite/checkbox--checked--filled.svg +2 -1
- package/dist/img/sprite/checkbox--checked.svg +2 -1
- package/dist/img/sprite/checkbox.svg +2 -1
- package/dist/img/sprite/clear.svg +2 -1
- package/dist/img/sprite/close--filled.svg +2 -1
- package/dist/img/sprite/close.svg +1 -1
- package/dist/img/sprite/collapse.svg +4 -3
- package/dist/img/sprite/column-select.svg +3 -2
- package/dist/img/sprite/conference.svg +9 -6
- package/dist/img/sprite/contacts.svg +2 -1
- package/dist/img/sprite/copy.svg +2 -1
- package/dist/img/sprite/custom-chat-gateway.svg +8 -3
- package/dist/img/sprite/dark-mode.svg +5 -3
- package/dist/img/sprite/docs.svg +5 -4
- package/dist/img/sprite/done.svg +3 -2
- package/dist/img/sprite/download.svg +4 -3
- package/dist/img/sprite/edit.svg +2 -1
- package/dist/img/sprite/elevenlabs.svg +3 -3
- package/dist/img/sprite/email.svg +2 -1
- package/dist/img/sprite/expand.svg +4 -3
- package/dist/img/sprite/eye--closed.svg +2 -1
- package/dist/img/sprite/eye--opened.svg +4 -2
- package/dist/img/sprite/filter.svg +3 -3
- package/dist/img/sprite/flows.svg +2 -1
- package/dist/img/sprite/generate.svg +3 -2
- package/dist/img/sprite/google.svg +8 -4
- package/dist/img/sprite/history.svg +2 -2
- package/dist/img/sprite/hold.svg +2 -1
- package/dist/img/sprite/idle.svg +3 -2
- package/dist/img/sprite/instagram.svg +31 -26
- package/dist/img/sprite/job--accept.svg +3 -2
- package/dist/img/sprite/job--end.svg +3 -2
- package/dist/img/sprite/job.svg +5 -3
- package/dist/img/sprite/lock.svg +2 -1
- package/dist/img/sprite/logout.svg +2 -1
- package/dist/img/sprite/mail--color.svg +3 -1
- package/dist/img/sprite/mail.svg +3 -1
- package/dist/img/sprite/menu.svg +2 -1
- package/dist/img/sprite/messenger-facebook--filled.svg +2 -1
- package/dist/img/sprite/messenger-facebook.svg +8 -7
- package/dist/img/sprite/messenger-infobip.svg +8 -3
- package/dist/img/sprite/messenger-messenger.svg +12 -9
- package/dist/img/sprite/messenger-telegram--filled.svg +3 -1
- package/dist/img/sprite/messenger-telegram.svg +10 -7
- package/dist/img/sprite/messenger-viber--filled.svg +3 -1
- package/dist/img/sprite/messenger-viber.svg +3 -1
- package/dist/img/sprite/messenger-web-chat.svg +6 -2
- package/dist/img/sprite/messenger-whatsapp--filled.svg +6 -2
- package/dist/img/sprite/messenger-whatsapp.svg +9 -7
- package/dist/img/sprite/meta.svg +20 -15
- package/dist/img/sprite/mic-muted.svg +5 -4
- package/dist/img/sprite/mic.svg +3 -2
- package/dist/img/sprite/microsoft.svg +5 -5
- package/dist/img/sprite/move.svg +4 -4
- package/dist/img/sprite/note.svg +2 -1
- package/dist/img/sprite/numpad.svg +24 -22
- package/dist/img/sprite/options.svg +3 -3
- package/dist/img/sprite/pause.svg +2 -1
- package/dist/img/sprite/pin.svg +2 -1
- package/dist/img/sprite/play.svg +3 -2
- package/dist/img/sprite/plus.svg +2 -1
- package/dist/img/sprite/preview-tag-application.svg +5 -4
- package/dist/img/sprite/preview-tag-audio.svg +4 -2
- package/dist/img/sprite/preview-tag-image.svg +4 -2
- package/dist/img/sprite/preview-tag-video.svg +4 -2
- package/dist/img/sprite/prompter.svg +2 -1
- package/dist/img/sprite/queue-member.svg +2 -1
- package/dist/img/sprite/radio--checked.svg +3 -2
- package/dist/img/sprite/radio.svg +2 -1
- package/dist/img/sprite/rec-off.svg +1 -1
- package/dist/img/sprite/rec.svg +3 -2
- package/dist/img/sprite/refresh.svg +2 -2
- package/dist/img/sprite/role.svg +2 -1
- package/dist/img/sprite/rounded-info.svg +2 -1
- package/dist/img/sprite/scorecard.svg +3 -2
- package/dist/img/sprite/search.svg +2 -1
- package/dist/img/sprite/select-custom-value-enter.svg +1 -1
- package/dist/img/sprite/send-arrow.svg +2 -2
- package/dist/img/sprite/settings.svg +2 -1
- package/dist/img/sprite/sort-arrow-down.svg +2 -2
- package/dist/img/sprite/sort-arrow-up.svg +2 -2
- package/dist/img/sprite/sound-off.svg +3 -2
- package/dist/img/sprite/sound-on.svg +2 -1
- package/dist/img/sprite/star--filled.svg +2 -1
- package/dist/img/sprite/star.svg +2 -1
- package/dist/img/sprite/stop.svg +4 -2
- package/dist/img/sprite/stt-download.svg +3 -2
- package/dist/img/sprite/stt-search.svg +2 -1
- package/dist/img/sprite/stt.svg +4 -2
- package/dist/img/sprite/telegram-bot.svg +6 -2
- package/dist/img/sprite/tick.svg +2 -1
- package/dist/img/sprite/tts-download.svg +4 -3
- package/dist/img/sprite/unpin.svg +3 -3
- package/dist/img/sprite/upload.svg +4 -3
- package/dist/img/sprite/user.svg +2 -1
- package/dist/img/sprite/video-cam-off.svg +4 -2
- package/dist/img/sprite/video-cam.svg +2 -1
- package/dist/img/sprite/zoom-in.svg +2 -1
- package/dist/img/sprite/zoom-out.svg +3 -2
- package/dist/ui-sdk.css +1 -1
- package/dist/ui-sdk.js +13200 -13195
- package/dist/ui-sdk.umd.cjs +11 -11
- package/package.json +1 -1
- package/src/api/clients/agents/agents.js +4 -4
- package/src/api/clients/buckets/buckets.js +3 -3
- package/src/api/clients/calendars/calendars.js +5 -5
- package/src/api/clients/chatGateways/chatGateways.js +9 -8
- package/src/api/clients/chatGateways/defaults/defaultChatGateway.js +1 -1
- package/src/api/clients/chatGateways/defaults/webChatGateway.js +4 -3
- package/src/api/clients/communications/communications.js +6 -5
- package/src/api/clients/flows/flow.js +2 -2
- package/src/api/clients/gateways/defaults/registerGateway.js +1 -1
- package/src/api/clients/gateways/defaults/trunkingGateway.js +1 -1
- package/src/api/clients/gateways/gateways.js +4 -4
- package/src/api/clients/index.js +12 -12
- package/src/api/clients/lists/blacklists.js +6 -4
- package/src/api/clients/media/media.js +2 -2
- package/src/api/clients/queues/queues.js +10 -10
- package/src/api/clients/roles/roles.js +4 -4
- package/src/api/clients/users/__tests__/users.spec.js +1 -1
- package/src/api/clients/users/users.js +7 -6
- package/src/api/defaults/getDefaultGetParams/getDefaultGetParams.js +2 -2
- package/src/api/defaults/getDefaultInstance/getDefaultInstance.js +3 -3
- package/src/api/defaults/index.js +6 -4
- package/src/api/transformers/camelToSnake/camelToSnake.transformer.js +1 -1
- package/src/api/transformers/index.js +10 -10
- package/src/api/transformers/notify/notify.transformer.js +7 -3
- package/src/api/transformers/snakeToCamel/snakeToCamel.transformer.js +1 -1
- package/src/api/transformers/starToSearch/starToSearch.transformer.js +1 -1
- package/src/components/index.js +40 -38
- package/src/components/on-demand/wt-cc-agent-status-timers/__tests__/wt-cc-agent-status-timers.spec.js +2 -2
- package/src/components/on-demand/wt-cc-agent-status-timers/wt-cc-agent-status-timers.vue +6 -6
- package/src/components/on-demand/wt-save-failed-popup/wt-save-failed-popup.vue +1 -1
- package/src/components/transitions/wt-expand-transition.vue +6 -7
- package/src/components/wt-app-header/__tests__/WtAppNavigator.spec.js +2 -1
- package/src/components/wt-app-header/__tests__/WtHeaderActions.spec.js +2 -1
- package/src/components/wt-app-header/assets/admin-dark.svg +42 -34
- package/src/components/wt-app-header/assets/admin-light.svg +42 -34
- package/src/components/wt-app-header/assets/agent-dark.svg +124 -124
- package/src/components/wt-app-header/assets/agent-light.svg +124 -124
- package/src/components/wt-app-header/assets/analytics-dark.svg +96 -58
- package/src/components/wt-app-header/assets/analytics-light.svg +96 -58
- package/src/components/wt-app-header/assets/audit-dark.svg +39 -33
- package/src/components/wt-app-header/assets/audit-light.svg +39 -33
- package/src/components/wt-app-header/assets/crm-dark.svg +22 -22
- package/src/components/wt-app-header/assets/crm-light.svg +22 -22
- package/src/components/wt-app-header/assets/history-dark.svg +246 -134
- package/src/components/wt-app-header/assets/history-light.svg +246 -134
- package/src/components/wt-app-header/assets/supervisor-dark.svg +72 -72
- package/src/components/wt-app-header/assets/supervisor-light.svg +72 -72
- package/src/components/wt-app-header/wt-app-header.vue +2 -2
- package/src/components/wt-app-header/wt-app-navigator.vue +1 -1
- package/src/components/wt-app-header/wt-header-actions.vue +1 -1
- package/src/components/wt-avatar/wt-avatar.vue +6 -6
- package/src/components/wt-badge/wt-badge.vue +4 -4
- package/src/components/wt-button/__tests__/WtButton.spec.js +1 -1
- package/src/components/wt-button/wt-button.vue +9 -9
- package/src/components/wt-button-select/__tests__/WtButtonSelect.spec.js +5 -3
- package/src/components/wt-button-select/wt-button-select.vue +2 -2
- package/src/components/wt-checkbox/__tests__/WtCheckbox.spec.js +3 -3
- package/src/components/wt-checkbox/wt-checkbox.vue +9 -9
- package/src/components/wt-chip/wt-chip.scss +7 -7
- package/src/components/wt-chip/wt-chip.vue +1 -1
- package/src/components/wt-context-menu/wt-context-menu.vue +8 -8
- package/src/components/wt-copy-action/wt-copy-action.vue +1 -1
- package/src/components/wt-datepicker/__tests__/WtDatepicker.spec.js +3 -3
- package/src/components/wt-datepicker/wt-datepicker.vue +8 -8
- package/src/components/wt-divider/wt-divider.vue +1 -1
- package/src/components/wt-error-page/wt-error-page.vue +5 -5
- package/src/components/wt-expansion-panel/wt-expansion-panel.vue +1 -1
- package/src/components/wt-filters-panel-wrapper/__tests__/WtFiltersPanelWrapper.spec.js +4 -2
- package/src/components/wt-filters-panel-wrapper/wt-filters-panel-wrapper.vue +3 -3
- package/src/components/wt-headline/_variables.scss +1 -1
- package/src/components/wt-headline/wt-headline.vue +4 -4
- package/src/components/wt-hint/wt-hint.vue +1 -1
- package/src/components/wt-icon/wt-icon.vue +16 -3
- package/src/components/wt-icon-action/_internals/wt-add-icon-action.vue +1 -1
- package/src/components/wt-icon-action/_internals/wt-delete-icon-action.vue +1 -1
- package/src/components/wt-icon-action/_internals/wt-download-icon-action.vue +1 -1
- package/src/components/wt-icon-action/_internals/wt-edit-icon-action.vue +1 -1
- package/src/components/wt-icon-action/_internals/wt-history-icon-action.vue +1 -1
- package/src/components/wt-icon-action/_internals/wt-refresh-icon-action.vue +1 -1
- package/src/components/wt-icon-action/wt-icon-action.vue +2 -2
- package/src/components/wt-icon-btn/__tests__/WtIconBtn.spec.js +1 -1
- package/src/components/wt-icon-btn/wt-icon-btn.vue +3 -3
- package/src/components/wt-indicator/__tests__/WtIndicator.spec.js +1 -1
- package/src/components/wt-indicator/wt-indicator.vue +6 -3
- package/src/components/wt-input/__tests__/WtInput.spec.js +2 -2
- package/src/components/wt-input/wt-input.vue +3 -5
- package/src/components/wt-input-info/wt-input-info.vue +2 -2
- package/src/components/wt-label/wt-label.vue +3 -3
- package/src/components/wt-loader/_internals/wt-loader--md.vue +62 -63
- package/src/components/wt-loader/_internals/wt-loader--sm.vue +8 -4
- package/src/components/wt-loader/wt-loader.vue +2 -2
- package/src/components/wt-logo/assets/logo-dark.svg +51 -25
- package/src/components/wt-logo/assets/logo-light.svg +51 -25
- package/src/components/wt-logo/wt-logo.vue +2 -2
- package/src/components/wt-navigation-bar/__tests__/WtNavigationBar.spec.js +10 -8
- package/src/components/wt-navigation-bar/assets/dark/app-logo-dark-admin.svg +12 -6
- package/src/components/wt-navigation-bar/assets/dark/app-logo-dark-analytics.svg +19 -11
- package/src/components/wt-navigation-bar/assets/dark/app-logo-dark-audit.svg +10 -6
- package/src/components/wt-navigation-bar/assets/dark/app-logo-dark-crm.svg +7 -4
- package/src/components/wt-navigation-bar/assets/dark/app-logo-dark-history.svg +14 -7
- package/src/components/wt-navigation-bar/assets/dark/app-logo-dark-supervisor.svg +20 -11
- package/src/components/wt-navigation-bar/assets/dark/app-logo-dark-workspace.svg +20 -10
- package/src/components/wt-navigation-bar/assets/light/app-logo-light-admin.svg +12 -6
- package/src/components/wt-navigation-bar/assets/light/app-logo-light-analytics.svg +19 -11
- package/src/components/wt-navigation-bar/assets/light/app-logo-light-audit.svg +10 -6
- package/src/components/wt-navigation-bar/assets/light/app-logo-light-crm.svg +7 -4
- package/src/components/wt-navigation-bar/assets/light/app-logo-light-history.svg +14 -7
- package/src/components/wt-navigation-bar/assets/light/app-logo-light-supervisor.svg +20 -11
- package/src/components/wt-navigation-bar/assets/light/app-logo-light-workspace.svg +20 -10
- package/src/components/wt-navigation-bar/wt-navigation-bar.vue +13 -12
- package/src/components/wt-notification/__tests__/WtNotification.spec.js +1 -1
- package/src/components/wt-notification/wt-notification.vue +5 -5
- package/src/components/wt-notifications-bar/__tests__/WtNotificationsBar.spec.js +2 -2
- package/src/components/wt-notifications-bar/wt-notifications-bar.vue +4 -4
- package/src/components/wt-page-header/wt-page-header.vue +1 -1
- package/src/components/wt-page-wrapper/__tests__/WtPageWrapper.spec.js +2 -1
- package/src/components/wt-page-wrapper/wt-page-wrapper.vue +2 -2
- package/src/components/wt-pagination/__tests__/WtPagination.spec.js +1 -1
- package/src/components/wt-pagination/wt-pagination.vue +1 -1
- package/src/components/wt-player/scripts/__tests__/createPlyrURL.spec.js +1 -1
- package/src/components/wt-player/scripts/createPlyrURL.js +5 -2
- package/src/components/wt-player/wt-player.vue +8 -8
- package/src/components/wt-popup/__tests__/WtPopup.spec.js +1 -1
- package/src/components/wt-popup/wt-popup.vue +3 -0
- package/src/components/wt-progress-bar/__tests__/WtProgressBar.spec.js +12 -2
- package/src/components/wt-progress-bar/wt-progress-bar.vue +7 -7
- package/src/components/wt-radio/__tests__/WtRadio.spec.js +2 -2
- package/src/components/wt-radio/wt-radio.vue +8 -8
- package/src/components/wt-rounded-action/wt-rounded-action.vue +10 -8
- package/src/components/wt-search-bar/__tests__/WtSearchBar.spec.js +2 -2
- package/src/components/wt-search-bar/_variables.scss +2 -6
- package/src/components/wt-search-bar/wt-search-bar.vue +3 -3
- package/src/components/wt-select/__tests__/WtSelect.spec.js +1 -1
- package/src/components/wt-select/_variables.scss +1 -1
- package/src/components/wt-select/mixins/__tests__/multiselectMixin.spec.js +1 -1
- package/src/components/wt-select/mixins/multiselectMixin.js +8 -7
- package/src/components/wt-select/wt-select.vue +7 -8
- package/src/components/wt-slider/wt-slider.vue +3 -3
- package/src/components/wt-status-select/__tests__/WtStatusSelect.spec.js +1 -1
- package/src/components/wt-status-select/_internals/StatusOptions.lookup.js +1 -1
- package/src/components/wt-status-select/wt-status-select.vue +15 -15
- package/src/components/wt-stepper/wt-stepper.vue +6 -6
- package/src/components/wt-switcher/__tests__/WtSwitcher.spec.js +2 -2
- package/src/components/wt-table/__tests__/WtTable.spec.js +7 -5
- package/src/components/wt-table/wt-table.vue +104 -104
- package/src/components/wt-table-column-select/wt-table-column-select.vue +9 -8
- package/src/components/wt-tabs/wt-tabs.vue +2 -2
- package/src/components/wt-tags-input/__tests__/WtTagsInput.spec.js +2 -2
- package/src/components/wt-tags-input/mixin/__tests__/taggableMixin.spec.js +3 -3
- package/src/components/wt-tags-input/wt-tags-input.vue +2 -2
- package/src/components/wt-textarea/__tests__/WtTextarea.spec.js +5 -3
- package/src/components/wt-textarea/wt-textarea.vue +3 -3
- package/src/components/wt-time-input/__tests__/WtTimeInput.spec.js +2 -2
- package/src/components/wt-time-input/wt-time-input.vue +12 -11
- package/src/components/wt-timepicker/__tests__/WtTimepicker.spec.js +2 -2
- package/src/components/wt-timepicker/wt-timepicker.vue +12 -12
- package/src/components/wt-tooltip/_internals/wt-tooltip-floating.vue +1 -1
- package/src/components/wt-tooltip/wt-tooltip.vue +7 -11
- package/src/composables/useCachedInterval/__tests__/useCachedInterval.spec.js +1 -1
- package/src/composables/useCachedInterval/useCachedInterval.js +6 -5
- package/src/composables/useDestroyableSortable/useDestroyableSortable.js +1 -6
- package/src/composables/useRepresentableAgentPauseCause/__tests__/useRepresentableAgentPauseCause.spec.js +4 -5
- package/src/composables/useRepresentableAgentPauseCause/useRepresentableAgentPauseCause.js +1 -1
- package/src/css/main.scss +6 -6
- package/src/css/styleguide/colors/_deprecated.scss +1 -1
- package/src/css/styleguide/fonts/_fonts.scss +0 -1
- package/src/css/styleguide/placeholder/_placeholder.scss +1 -1
- package/src/css/styleguide/scroll.scss +6 -5
- package/src/css/styleguide/typography/_typography.scss +1 -1
- package/src/directives/index.js +1 -1
- package/src/enums/WebitelApplications/AdminSections.enum.js +0 -2
- package/src/locale/en/en.js +6 -6
- package/src/locale/es/es.js +5 -5
- package/src/locale/i18n.js +5 -6
- package/src/locale/kz/kz.js +5 -5
- package/src/locale/ru/ru.js +6 -6
- package/src/locale/ua/ua.js +6 -6
- package/src/mixins/dataFilterMixins/__tests__/apiFilterMixin.spec.js +1 -1
- package/src/mixins/dataFilterMixins/__tests__/enumFilterMixin.spec.js +5 -3
- package/src/mixins/dataFilterMixins/__tests__/paginationFilterMixin.spec.js +1 -1
- package/src/mixins/dataFilterMixins/__tests__/sortFilterMixin.spec.js +27 -24
- package/src/mixins/dataFilterMixins/__tests__/urlControllerMixin.spec.js +1 -1
- package/src/mixins/dataFilterMixins/apiFilterMixin.js +1 -1
- package/src/mixins/dataFilterMixins/baseFilterMixin/baseFilterMixin.js +3 -2
- package/src/mixins/dataFilterMixins/enumFilterMixin.js +5 -3
- package/src/mixins/dataFilterMixins/paginationFilterMixin.js +1 -1
- package/src/mixins/dataFilterMixins/sortFilterMixin.js +26 -13
- package/src/mixins/validationMixin/__tests__/validationMixin.spec.js +1 -1
- package/src/mixins/validationMixin/useValidation.js +8 -4
- package/src/mixins/validationMixin/validationMixin.js +1 -1
- package/src/modules/AgentStatusSelect/api/pause-cause.js +5 -3
- package/src/modules/AgentStatusSelect/components/__tests__/wt-cc-agent-status-select.spec.js +10 -7
- package/src/modules/AgentStatusSelect/components/__tests__/wt-cc-pause-cause-popup.spec.js +2 -2
- package/src/modules/AgentStatusSelect/components/_internals/wt-cc-pause-cause-popup.vue +6 -4
- package/src/modules/AgentStatusSelect/components/_internals/wt-cc-status-select-error-popup.vue +2 -2
- package/src/modules/AgentStatusSelect/components/wt-cc-agent-status-select.vue +3 -3
- package/src/modules/Appearance/components/__tests__/wt-dark-mode-switcher.spec.js +1 -1
- package/src/modules/Appearance/store/AppearanceStoreModule.js +5 -5
- package/src/modules/Appearance/store/__tests__/AppearanceStoreModule.spec.js +1 -1
- package/src/modules/AuditForm/components/__tests__/audit-form-question-read-wrapper.spec.js +2 -1
- package/src/modules/AuditForm/components/__tests__/audit-form-question-write-wrapper.spec.js +16 -7
- package/src/modules/AuditForm/components/__tests__/audit-form.spec.js +16 -8
- package/src/modules/AuditForm/components/audit-form-question-read-wrapper.vue +8 -7
- package/src/modules/AuditForm/components/audit-form-question-write-wrapper.vue +18 -18
- package/src/modules/AuditForm/components/audit-form-question.vue +3 -2
- package/src/modules/AuditForm/components/audit-form.vue +10 -13
- package/src/modules/AuditForm/components/questions/options/__tests__/audit-form-question-options-write-row.spec.js +3 -2
- package/src/modules/AuditForm/components/questions/options/__tests__/audit-form-question-options.spec.js +4 -2
- package/src/modules/AuditForm/components/questions/options/audit-form-question-options-write-row.vue +5 -5
- package/src/modules/AuditForm/components/questions/options/audit-form-question-options.vue +5 -5
- package/src/modules/AuditForm/components/questions/score/audit-form-question-score.vue +16 -16
- package/src/modules/AuditForm/schemas/AuditFormQuestionSchema.js +1 -1
- package/src/modules/CSVExport/CSVExport.js +8 -6
- package/src/modules/CSVExport/__tests__/CSVExport.spec.js +3 -3
- package/src/modules/CSVExport/mixins/exportCSVMixin.js +5 -4
- package/src/modules/CardStoreModule/composables/useCardStore.js +1 -1
- package/src/modules/CardStoreModule/store/CardStoreModule.js +2 -2
- package/src/modules/DeleteConfirmationPopup/__tests__/delete-confirmation-popup.spec.js +11 -7
- package/src/modules/DeleteConfirmationPopup/components/delete-confirmation-popup.vue +4 -4
- package/src/modules/FilesExport/FilesExport.js +2 -3
- package/src/modules/FilesExport/__tests__/FilesExport.spec.js +18 -6
- package/src/modules/FilesExport/mixins/exportFilesMixin.js +7 -3
- package/src/modules/FilesExport/scripts/generateMediaURL.js +2 -1
- package/src/modules/Filters/classes/BaseFilterSchema.js +3 -3
- package/src/modules/Filters/components/__tests__/filter-pagination.spec.js +1 -1
- package/src/modules/Filters/components/__tests__/filter-table-fields.spec.js +2 -2
- package/src/modules/Filters/components/filter-pagination.vue +1 -1
- package/src/modules/Filters/components/filter-table-fields.vue +0 -2
- package/src/modules/Filters/scripts/getters/index.js +3 -3
- package/src/modules/Filters/scripts/getters/localStorageGetter.js +1 -1
- package/src/modules/Filters/scripts/getters/queryGetter.js +0 -1
- package/src/modules/Filters/scripts/getters/valueGetter.js +1 -1
- package/src/modules/Filters/scripts/restores/index.js +2 -2
- package/src/modules/Filters/scripts/restores/localStorageRestore.js +1 -1
- package/src/modules/Filters/scripts/restores/queryRestore.js +1 -1
- package/src/modules/Filters/scripts/setters/index.js +3 -3
- package/src/modules/Filters/scripts/setters/localStorageSetter.js +1 -1
- package/src/modules/Filters/scripts/setters/querySetter.js +1 -1
- package/src/modules/Filters/scripts/setters/valueSetter.js +1 -1
- package/src/modules/Filters/store/FiltersStoreModule.js +4 -4
- package/src/modules/Filters/store/__tests__/FiltersStoreModule.spec.js +4 -4
- package/src/modules/Notifications/store/NotificationsStoreModule.js +17 -15
- package/src/modules/Notifications/store/__tests__/NotificationsStoreModule.actions.spec.js +6 -3
- package/src/modules/Notifications/store/__tests__/NotificationsStoreModule.mutations.spec.js +2 -2
- package/src/modules/QueryFilters/api/__tests__/defaults.spec.js +1 -1
- package/src/modules/QueryFilters/classes/ApiFilterSchema.js +1 -1
- package/src/modules/QueryFilters/classes/EnumFilterSchema.js +1 -1
- package/src/modules/QueryFilters/classes/__tests__/ApiFilterSchema.spec.js +1 -1
- package/src/modules/QueryFilters/components/__tests__/abstract-api-filter.spec.js +3 -3
- package/src/modules/QueryFilters/components/__tests__/abstract-enum-filter.spec.js +3 -3
- package/src/modules/QueryFilters/components/__tests__/filter-datetime.spec.js +5 -4
- package/src/modules/QueryFilters/components/__tests__/filter-from-to.spec.js +3 -3
- package/src/modules/QueryFilters/components/__tests__/filter-search.spec.js +7 -5
- package/src/modules/QueryFilters/components/abstract-api-filter.vue +6 -6
- package/src/modules/QueryFilters/components/abstract-enum-filter.vue +7 -7
- package/src/modules/QueryFilters/components/filter-datetime.vue +2 -2
- package/src/modules/QueryFilters/components/filter-from-to.vue +8 -8
- package/src/modules/QueryFilters/components/filter-search.vue +2 -2
- package/src/modules/QueryFilters/components/filter-table-fields.vue +1 -1
- package/src/modules/QueryFilters/mixins/__tests__/apiFilterMixin.spec.js +7 -3
- package/src/modules/QueryFilters/mixins/__tests__/enumFilterMixin.spec.js +18 -11
- package/src/modules/QueryFilters/mixins/__tests__/sortFilterMixin.spec.js +27 -23
- package/src/modules/QueryFilters/mixins/__tests__/urlControllerMixin.spec.js +1 -1
- package/src/modules/QueryFilters/mixins/apiFilterMixin.js +5 -2
- package/src/modules/QueryFilters/mixins/baseFilterMixin/baseFilterMixin.js +2 -2
- package/src/modules/QueryFilters/mixins/enumFilterMixin.js +13 -11
- package/src/modules/QueryFilters/mixins/paginationFilterMixin.js +5 -3
- package/src/modules/QueryFilters/mixins/sortFilterMixin.js +18 -7
- package/src/modules/QueryFilters/store/QueryFiltersStoreModule.js +2 -2
- package/src/modules/QueryFilters/store/__tests__/QueryFiltersStoreModule.spec.js +17 -9
- package/src/modules/QueryFilters/store/queryFilters.js +1 -1
- package/src/modules/TableStoreModule/composables/useTableStore.js +1 -1
- package/src/modules/TableStoreModule/store/TableStoreModule.js +3 -3
- package/src/modules/TableStoreModule/store/__tests__/TableStoreModule.spec.js +6 -5
- package/src/modules/Userinfo/api/userinfo.js +2 -2
- package/src/modules/Userinfo/classes/ApplicationsAccess.js +18 -13
- package/src/modules/Userinfo/store/UserinfoStoreModule.js +28 -15
- package/src/plugins/breakpoint/breakpoint.plugin.js +1 -2
- package/src/scripts/__tests__/caseConverters.spec.js +6 -3
- package/src/scripts/__tests__/convertDuration.spec.js +1 -1
- package/src/scripts/__tests__/debounce.spec.js +1 -1
- package/src/scripts/__tests__/editProxy.spec.js +1 -1
- package/src/scripts/__tests__/isEmpty.spec.js +1 -1
- package/src/scripts/__tests__/prettifyFileSize.spec.js +1 -1
- package/src/scripts/__tests__/prettifyTime.spec.js +1 -1
- package/src/scripts/__tests__/preventHiddenPageCallsDecorator.spec.js +2 -1
- package/src/scripts/__tests__/sortQueryAdapters.spec.js +1 -1
- package/src/scripts/__tests__/updateObject.spec.js +5 -3
- package/src/scripts/caseConverters.js +34 -28
- package/src/scripts/debounce.js +5 -1
- package/src/scripts/preventHiddenPageCallsDecorator.js +4 -2
- package/src/scripts/sortQueryAdapters.js +12 -6
- package/src/scripts/updateObject.js +1 -1
- package/src/store/BaseStoreModules/ApiStoreModule.js +1 -1
- package/src/store/BaseStoreModules/BaseStoreModule.js +16 -4
- package/src/store/BaseStoreModules/__tests__/BaseStoreModule.spec.js +27 -23
- package/src/store/ReactiveNowStoreModule/ReactiveNowStoreModule.js +1 -1
- package/src/store/helpers/__tests__/getNamespacedState.spec.js +1 -1
- package/src/store/helpers/getNamespacedState.js +2 -1
- package/src/tests/mocks/axiosMock.js +16 -16
- package/src/validators/decimalValidator.js +3 -2
- package/src/validators/variableSearchValidator/__tests__/variableSearchValidator.spec.js +2 -2
- package/src/validators/websocketValidator/__tests__/websocketValidator.spec.js +3 -2
|
@@ -1,35 +1,39 @@
|
|
|
1
1
|
import { shallowMount } from '@vue/test-utils';
|
|
2
2
|
import { createRouter, createWebHistory } from 'vue-router';
|
|
3
|
-
import sortFilterMixin from '../sortFilterMixin';
|
|
3
|
+
import sortFilterMixin from '../sortFilterMixin.js';
|
|
4
4
|
|
|
5
5
|
const router = createRouter({
|
|
6
6
|
history: createWebHistory(),
|
|
7
7
|
routes: [{ path: '/', name: 'jest' }],
|
|
8
8
|
});
|
|
9
9
|
|
|
10
|
-
const headers = [
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
10
|
+
const headers = [
|
|
11
|
+
{
|
|
12
|
+
value: 'queue',
|
|
13
|
+
show: true,
|
|
14
|
+
sort: null,
|
|
15
|
+
field: 'queue',
|
|
16
|
+
}, {
|
|
17
|
+
value: 'agents',
|
|
18
|
+
show: true,
|
|
19
|
+
sort: null,
|
|
20
|
+
field: 'online',
|
|
21
|
+
},
|
|
22
|
+
];
|
|
21
23
|
|
|
22
|
-
const sortedHeaders = [
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
24
|
+
const sortedHeaders = [
|
|
25
|
+
{
|
|
26
|
+
value: 'queue',
|
|
27
|
+
show: true,
|
|
28
|
+
sort: 'asc',
|
|
29
|
+
field: 'queue',
|
|
30
|
+
}, {
|
|
31
|
+
value: 'agents',
|
|
32
|
+
show: true,
|
|
33
|
+
sort: null,
|
|
34
|
+
field: 'online',
|
|
35
|
+
},
|
|
36
|
+
];
|
|
33
37
|
|
|
34
38
|
describe('Sort filter mixin', () => {
|
|
35
39
|
const setHeaders = vi.fn();
|
|
@@ -44,7 +48,6 @@ describe('Sort filter mixin', () => {
|
|
|
44
48
|
await router.replace('/');
|
|
45
49
|
});
|
|
46
50
|
|
|
47
|
-
|
|
48
51
|
it('Correctly sets value from $route query', async () => {
|
|
49
52
|
await router.replace({ path: '/', query: { sort: '+queue' } });
|
|
50
53
|
const wrapper = shallowMount(Component, {
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { shallowMount } from '@vue/test-utils';
|
|
2
2
|
import { createRouter, createWebHistory } from 'vue-router';
|
|
3
|
-
import _urlControllerMixin from '../_urlControllerMixin/_urlControllerMixin';
|
|
3
|
+
import _urlControllerMixin from '../_urlControllerMixin/_urlControllerMixin.js';
|
|
4
4
|
|
|
5
5
|
const router = createRouter({
|
|
6
6
|
history: createWebHistory(),
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import _urlControllerMixin from '../_urlControllerMixin/_urlControllerMixin';
|
|
1
|
+
import _urlControllerMixin from '../_urlControllerMixin/_urlControllerMixin.js';
|
|
2
2
|
|
|
3
3
|
export default {
|
|
4
4
|
mixins: [_urlControllerMixin],
|
|
@@ -22,7 +22,8 @@ export default {
|
|
|
22
22
|
|
|
23
23
|
methods: {
|
|
24
24
|
restore({ filterQuery }) {
|
|
25
|
-
const value = this.getValueFromQuery({ filterQuery }) ||
|
|
25
|
+
const value = this.getValueFromQuery({ filterQuery }) ||
|
|
26
|
+
this.defaultValue;
|
|
26
27
|
this.restoreValue(value);
|
|
27
28
|
},
|
|
28
29
|
},
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import baseFilterMixin from './baseFilterMixin/baseFilterMixin';
|
|
1
|
+
import baseFilterMixin from './baseFilterMixin/baseFilterMixin.js';
|
|
2
2
|
|
|
3
3
|
export default {
|
|
4
4
|
mixins: [baseFilterMixin],
|
|
@@ -20,10 +20,12 @@ export default {
|
|
|
20
20
|
restoreValue(value) {
|
|
21
21
|
if (Array.isArray(value)) {
|
|
22
22
|
this.value = this.options
|
|
23
|
-
.filter((option) => value.some((value) => `${value}` ===
|
|
23
|
+
.filter((option) => value.some((value) => `${value}` ===
|
|
24
|
+
option[this.storedProp]));
|
|
24
25
|
} else {
|
|
25
26
|
this.value = this.options
|
|
26
|
-
|
|
27
|
+
.find((option) => option[this.storedProp] === value) ||
|
|
28
|
+
this.defaultValue;
|
|
27
29
|
}
|
|
28
30
|
},
|
|
29
31
|
},
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import baseFilterMixin from './baseFilterMixin/baseFilterMixin';
|
|
1
|
+
import baseFilterMixin from './baseFilterMixin/baseFilterMixin.js';
|
|
2
2
|
|
|
3
3
|
const SortSymbols = Object.freeze({
|
|
4
4
|
ASC: 'asc',
|
|
@@ -8,30 +8,43 @@ const SortSymbols = Object.freeze({
|
|
|
8
8
|
|
|
9
9
|
const getNextSortOrder = (sort) => {
|
|
10
10
|
switch (sort) {
|
|
11
|
-
case SortSymbols.NONE:
|
|
12
|
-
|
|
13
|
-
case SortSymbols.
|
|
14
|
-
|
|
11
|
+
case SortSymbols.NONE:
|
|
12
|
+
return SortSymbols.ASC;
|
|
13
|
+
case SortSymbols.ASC:
|
|
14
|
+
return SortSymbols.DESC;
|
|
15
|
+
case SortSymbols.DESC:
|
|
16
|
+
return SortSymbols.NONE;
|
|
17
|
+
default:
|
|
18
|
+
return SortSymbols.ASC;
|
|
15
19
|
}
|
|
16
20
|
};
|
|
17
21
|
|
|
18
22
|
const sortToQueryAdapter = (order) => {
|
|
19
23
|
switch (order) {
|
|
20
|
-
case SortSymbols.ASC:
|
|
21
|
-
|
|
22
|
-
|
|
24
|
+
case SortSymbols.ASC:
|
|
25
|
+
return '+';
|
|
26
|
+
case SortSymbols.DESC:
|
|
27
|
+
return '-';
|
|
28
|
+
default:
|
|
29
|
+
return '';
|
|
23
30
|
}
|
|
24
31
|
};
|
|
25
32
|
|
|
26
33
|
const queryToSortAdapter = (order) => {
|
|
27
34
|
switch (order) {
|
|
28
|
-
case '+':
|
|
29
|
-
|
|
30
|
-
|
|
35
|
+
case '+':
|
|
36
|
+
return SortSymbols.ASC;
|
|
37
|
+
case '-':
|
|
38
|
+
return SortSymbols.DESC;
|
|
39
|
+
default:
|
|
40
|
+
return SortSymbols.NONE;
|
|
31
41
|
}
|
|
32
42
|
};
|
|
33
43
|
|
|
34
|
-
const encodeSortQuery = ({
|
|
44
|
+
const encodeSortQuery = ({
|
|
45
|
+
column,
|
|
46
|
+
order,
|
|
47
|
+
}) => (`${sortToQueryAdapter(order)}${column.field}`);
|
|
35
48
|
|
|
36
49
|
const decodeSortQuery = ({ value }) => {
|
|
37
50
|
const sort = queryToSortAdapter(value.slice(0, 1));
|
|
@@ -58,7 +71,7 @@ export default {
|
|
|
58
71
|
return {
|
|
59
72
|
...col,
|
|
60
73
|
sort: col === column ? order : sortFieldValue,
|
|
61
|
-
}
|
|
74
|
+
};
|
|
62
75
|
});
|
|
63
76
|
const value = encodeSortQuery({ column, order });
|
|
64
77
|
this.setHeaders(headers);
|
|
@@ -1,7 +1,10 @@
|
|
|
1
|
-
import { computed, isReactive
|
|
1
|
+
import { computed, isReactive } from 'vue';
|
|
2
2
|
import { useI18n } from 'vue-i18n';
|
|
3
3
|
|
|
4
|
-
export function useValidation({
|
|
4
|
+
export function useValidation({
|
|
5
|
+
v: inputV,
|
|
6
|
+
customValidators: inputCustomValidators,
|
|
7
|
+
}) {
|
|
5
8
|
const { t } = useI18n();
|
|
6
9
|
|
|
7
10
|
// support vue options api, where v is a reactive, not ref
|
|
@@ -14,7 +17,8 @@ export function useValidation({ v: inputV, customValidators: inputCustomValidato
|
|
|
14
17
|
}
|
|
15
18
|
// end
|
|
16
19
|
|
|
17
|
-
const isValidation = computed(() => !!v && !!v.value &&
|
|
20
|
+
const isValidation = computed(() => !!v && !!v.value &&
|
|
21
|
+
!!Object.keys(v.value).length);
|
|
18
22
|
const invalid = computed(() => isValidation.value && v.value.$error);
|
|
19
23
|
|
|
20
24
|
const validationText = computed(() => {
|
|
@@ -40,7 +44,7 @@ export function useValidation({ v: inputV, customValidators: inputCustomValidato
|
|
|
40
44
|
}
|
|
41
45
|
|
|
42
46
|
if (customValidators && customValidators.value) {
|
|
43
|
-
|
|
47
|
+
|
|
44
48
|
for (const { name, text } of customValidators.value) {
|
|
45
49
|
if (v.value[name]?.$invalid) validationText = text;
|
|
46
50
|
}
|
|
@@ -37,7 +37,7 @@ export default {
|
|
|
37
37
|
else if (this.v.websocketValidator?.$invalid) validationText = `${this.$t('validation.websocketValidator')}`;
|
|
38
38
|
else if (this.v.integer?.$invalid) validationText = `${this.$t('validation.integer')}`;
|
|
39
39
|
}
|
|
40
|
-
|
|
40
|
+
|
|
41
41
|
for (const { name, text } of this.customValidators) {
|
|
42
42
|
if (this.v[name]?.$invalid) validationText = text;
|
|
43
43
|
}
|
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
import { AgentServiceApiFactory } from 'webitel-sdk';
|
|
2
|
+
import { getDefaultGetListResponse } from '../../../api/defaults/index.js';
|
|
2
3
|
import applyTransform, {
|
|
3
|
-
merge,
|
|
4
|
+
merge,
|
|
5
|
+
mergeEach,
|
|
6
|
+
notify,
|
|
4
7
|
snakeToCamel,
|
|
5
|
-
} from '../../../api/transformers';
|
|
6
|
-
import { getDefaultGetListResponse } from '../../../api/defaults';
|
|
8
|
+
} from '../../../api/transformers/index.js';
|
|
7
9
|
|
|
8
10
|
const PauseCauseAPIFactory = ({ instance, OpenAPIConfig }) => {
|
|
9
11
|
|
package/src/modules/AgentStatusSelect/components/__tests__/wt-cc-agent-status-select.spec.js
CHANGED
|
@@ -1,18 +1,20 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { mount, shallowMount } from '@vue/test-utils';
|
|
2
2
|
import { createStore } from 'vuex';
|
|
3
|
-
import AgentStatus from '../../../../enums/AgentStatus/AgentStatus.enum';
|
|
4
|
-
import * as AgentStatusAPIFactory from '../../api/agent-status';
|
|
5
|
-
import * as PauseCauseAPIFactory from '../../api/pause-cause';
|
|
3
|
+
import AgentStatus from '../../../../enums/AgentStatus/AgentStatus.enum.js';
|
|
4
|
+
import * as AgentStatusAPIFactory from '../../api/agent-status.js';
|
|
5
|
+
import * as PauseCauseAPIFactory from '../../api/pause-cause.js';
|
|
6
6
|
import WtCcAgentStatusSelect from '../wt-cc-agent-status-select.vue';
|
|
7
7
|
|
|
8
8
|
const pauseCauses = [{ name: 'jest1' }, { name: 'jest2' }];
|
|
9
9
|
const getAgentPauseCausesMock = vi.fn(() => ({ items: pauseCauses }));
|
|
10
10
|
// https://stackoverflow.com/a/63727813
|
|
11
|
-
vi.spyOn(PauseCauseAPIFactory, 'default')
|
|
11
|
+
vi.spyOn(PauseCauseAPIFactory, 'default')
|
|
12
|
+
.mockImplementation(() => ({ getList: getAgentPauseCausesMock }));
|
|
12
13
|
|
|
13
14
|
const agentStatusMock = vi.fn(() => {});
|
|
14
15
|
// https://stackoverflow.com/a/63727813
|
|
15
|
-
vi.spyOn(AgentStatusAPIFactory, 'default')
|
|
16
|
+
vi.spyOn(AgentStatusAPIFactory, 'default')
|
|
17
|
+
.mockImplementation(() => ({ patch: agentStatusMock }));
|
|
16
18
|
|
|
17
19
|
const agent = {
|
|
18
20
|
status: '',
|
|
@@ -64,7 +66,8 @@ describe('Wt Cc Agent Status Select', () => {
|
|
|
64
66
|
await wrapper.vm.$nextTick(); // load pause causes
|
|
65
67
|
await wrapper.vm.$nextTick();
|
|
66
68
|
await wrapper.vm.$nextTick(); // render popup
|
|
67
|
-
expect(wrapper.findComponent({ name: 'pause-cause-popup' }).isVisible())
|
|
69
|
+
expect(wrapper.findComponent({ name: 'pause-cause-popup' }).isVisible())
|
|
70
|
+
.toBe(true);
|
|
68
71
|
});
|
|
69
72
|
it(`at pause-cause-popup "change" event, triggers patch agent status
|
|
70
73
|
with "pause" status and passed pauseCause`, async () => {
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { mount, shallowMount } from '@vue/test-utils';
|
|
2
2
|
import WtCcPauseCausePopup from '../_internals/wt-cc-pause-cause-popup.vue';
|
|
3
3
|
|
|
4
4
|
describe('Pause cause popup', () => {
|
|
5
5
|
it('renders a component', () => {
|
|
6
6
|
const wrapper = shallowMount(WtCcPauseCausePopup);
|
|
7
7
|
expect(wrapper.exists())
|
|
8
|
-
|
|
8
|
+
.toBe(true);
|
|
9
9
|
});
|
|
10
10
|
it('at option input event, sets "selected" its value', () => {
|
|
11
11
|
const value = 'jest';
|
|
@@ -16,10 +16,10 @@
|
|
|
16
16
|
class="wt-cc-pause-cause-popup-option"
|
|
17
17
|
>
|
|
18
18
|
<wt-radio
|
|
19
|
-
|
|
19
|
+
:label="option.name"
|
|
20
20
|
:selected="selected.id"
|
|
21
21
|
:value="option.id"
|
|
22
|
-
|
|
22
|
+
class="wt-cc-pause-cause-popup-option__radio"
|
|
23
23
|
@input="select(option)"
|
|
24
24
|
/>
|
|
25
25
|
<div class="wt-cc-pause-cause-popup-option__limits-wrapper">
|
|
@@ -57,7 +57,9 @@
|
|
|
57
57
|
<script setup>
|
|
58
58
|
import { computed, ref, toRef } from 'vue';
|
|
59
59
|
import { useI18n } from 'vue-i18n';
|
|
60
|
-
import {
|
|
60
|
+
import {
|
|
61
|
+
useRepresentableAgentPauseCause,
|
|
62
|
+
} from '../../../../composables/useRepresentableAgentPauseCause/useRepresentableAgentPauseCause.js';
|
|
61
63
|
|
|
62
64
|
const props = defineProps({
|
|
63
65
|
options: {
|
|
@@ -103,8 +105,8 @@ function setPause() {
|
|
|
103
105
|
<style lang="scss" scoped>
|
|
104
106
|
.wt-cc-pause-cause-popup-option {
|
|
105
107
|
display: flex;
|
|
106
|
-
justify-content: space-between;
|
|
107
108
|
align-items: center;
|
|
109
|
+
justify-content: space-between;
|
|
108
110
|
|
|
109
111
|
&:not(:last-child) {
|
|
110
112
|
margin-bottom: var(--spacing-sm);
|
package/src/modules/AgentStatusSelect/components/_internals/wt-cc-status-select-error-popup.vue
CHANGED
|
@@ -10,8 +10,8 @@
|
|
|
10
10
|
<template #main>
|
|
11
11
|
<article class="wt-cc-status-select-error-popup__main-wrapper">
|
|
12
12
|
<wt-icon
|
|
13
|
-
icon="attention"
|
|
14
13
|
color="error"
|
|
14
|
+
icon="attention"
|
|
15
15
|
/>
|
|
16
16
|
<p class="wt-cc-status-select-error-popup__message">
|
|
17
17
|
{{ $t('webitelUI.agentStatusSelect.statusSelectErrorPopup.message') }}
|
|
@@ -48,9 +48,9 @@ function close() {
|
|
|
48
48
|
<style lang="scss" scoped>
|
|
49
49
|
.wt-cc-status-select-error-popup__main-wrapper {
|
|
50
50
|
display: flex;
|
|
51
|
+
align-items: center;
|
|
51
52
|
flex-direction: column;
|
|
52
53
|
justify-content: center;
|
|
53
|
-
align-items: center;
|
|
54
54
|
gap: var(--spacing-sm);
|
|
55
55
|
}
|
|
56
56
|
</style>
|
|
@@ -23,9 +23,9 @@
|
|
|
23
23
|
import { ref } from 'vue';
|
|
24
24
|
import { useStore } from 'vuex';
|
|
25
25
|
import { PauseNotAllowedError } from 'webitel-sdk';
|
|
26
|
-
import AgentStatus from '../../../enums/AgentStatus/AgentStatus.enum';
|
|
27
|
-
import AgentStatusAPIFactory from '../api/agent-status';
|
|
28
|
-
import PauseCauseAPIFactory from '../api/pause-cause';
|
|
26
|
+
import AgentStatus from '../../../enums/AgentStatus/AgentStatus.enum.js';
|
|
27
|
+
import AgentStatusAPIFactory from '../api/agent-status.js';
|
|
28
|
+
import PauseCauseAPIFactory from '../api/pause-cause.js';
|
|
29
29
|
import PauseCausePopup from './_internals/wt-cc-pause-cause-popup.vue';
|
|
30
30
|
import StatusSelectErrorPopup from './_internals/wt-cc-status-select-error-popup.vue';
|
|
31
31
|
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { shallowMount } from '@vue/test-utils';
|
|
2
2
|
import { createStore } from 'vuex';
|
|
3
|
-
import AppearanceStoreModule from '../../store/AppearanceStoreModule';
|
|
3
|
+
import AppearanceStoreModule from '../../store/AppearanceStoreModule.js';
|
|
4
4
|
import WtDarkModeSwitcher from '../wt-dark-mode-switcher.vue';
|
|
5
5
|
|
|
6
6
|
describe('WtDarkModeSwitcher', () => {
|
|
@@ -1,23 +1,23 @@
|
|
|
1
|
-
import BaseStoreModule from '../../../store/BaseStoreModules/BaseStoreModule';
|
|
1
|
+
import BaseStoreModule from '../../../store/BaseStoreModules/BaseStoreModule.js';
|
|
2
2
|
|
|
3
3
|
export default class AppearanceStoreModule extends BaseStoreModule {
|
|
4
4
|
state = {
|
|
5
5
|
theme: null,
|
|
6
|
-
}
|
|
6
|
+
};
|
|
7
7
|
|
|
8
8
|
getters = {
|
|
9
9
|
DARK_MODE: (state) => state.theme === 'dark',
|
|
10
|
-
}
|
|
10
|
+
};
|
|
11
11
|
|
|
12
12
|
actions = {
|
|
13
13
|
SET_THEME: (context, theme) => {
|
|
14
14
|
context.commit('SET_THEME', theme);
|
|
15
15
|
},
|
|
16
|
-
}
|
|
16
|
+
};
|
|
17
17
|
|
|
18
18
|
mutations = {
|
|
19
19
|
SET_THEME: (state, theme) => {
|
|
20
20
|
state.theme = theme;
|
|
21
21
|
},
|
|
22
|
-
}
|
|
22
|
+
};
|
|
23
23
|
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { shallowMount } from '@vue/test-utils';
|
|
2
|
-
import AuditFormQuestionReadWrapper
|
|
2
|
+
import AuditFormQuestionReadWrapper
|
|
3
|
+
from '../audit-form-question-read-wrapper.vue';
|
|
3
4
|
|
|
4
5
|
describe('AuditFormQuestionReadWrapper', () => {
|
|
5
6
|
it('renders a component', () => {
|
package/src/modules/AuditForm/components/__tests__/audit-form-question-write-wrapper.spec.js
CHANGED
|
@@ -2,10 +2,13 @@ import { shallowMount } from '@vue/test-utils';
|
|
|
2
2
|
import { EngineAuditQuestionType } from 'webitel-sdk';
|
|
3
3
|
import {
|
|
4
4
|
generateQuestionOptionsSchema,
|
|
5
|
-
} from '../../schemas/AuditFormQuestionOptionsSchema';
|
|
6
|
-
import
|
|
7
|
-
import {
|
|
8
|
-
|
|
5
|
+
} from '../../schemas/AuditFormQuestionOptionsSchema.js';
|
|
6
|
+
import { generateQuestionSchema } from '../../schemas/AuditFormQuestionSchema.js';
|
|
7
|
+
import {
|
|
8
|
+
generateQuestionScoreSchema,
|
|
9
|
+
} from '../../schemas/AuditFormQuestionScoreSchema.js';
|
|
10
|
+
import AuditFormQuestionWriteWrapper
|
|
11
|
+
from '../audit-form-question-write-wrapper.vue';
|
|
9
12
|
|
|
10
13
|
const v = { question: {} };
|
|
11
14
|
|
|
@@ -27,7 +30,9 @@ describe('AuditFormQuestionWriteWrapper', () => {
|
|
|
27
30
|
v,
|
|
28
31
|
},
|
|
29
32
|
});
|
|
30
|
-
wrapper.findComponent({ name: 'wt-switcher' })
|
|
33
|
+
wrapper.findComponent({ name: 'wt-switcher' })
|
|
34
|
+
.vm
|
|
35
|
+
.$emit('change', !question.required);
|
|
31
36
|
expect(wrapper.emitted()['change:question'][0][0].required)
|
|
32
37
|
.toBe(!question.required);
|
|
33
38
|
});
|
|
@@ -40,7 +45,9 @@ describe('AuditFormQuestionWriteWrapper', () => {
|
|
|
40
45
|
},
|
|
41
46
|
});
|
|
42
47
|
wrapper.find('.audit-form-question-write-content-question')
|
|
43
|
-
.findComponent({ name: 'wt-select' })
|
|
48
|
+
.findComponent({ name: 'wt-select' })
|
|
49
|
+
.vm
|
|
50
|
+
.$emit('input', { value: EngineAuditQuestionType.Score });
|
|
44
51
|
expect(wrapper.emitted()['change:question'][0][0])
|
|
45
52
|
.toEqual(generateQuestionScoreSchema());
|
|
46
53
|
});
|
|
@@ -53,7 +60,9 @@ describe('AuditFormQuestionWriteWrapper', () => {
|
|
|
53
60
|
},
|
|
54
61
|
});
|
|
55
62
|
wrapper.find('.audit-form-question-write-content-question')
|
|
56
|
-
.findComponent({ name: 'wt-select' })
|
|
63
|
+
.findComponent({ name: 'wt-select' })
|
|
64
|
+
.vm
|
|
65
|
+
.$emit('input', { value: EngineAuditQuestionType.Option });
|
|
57
66
|
expect(wrapper.emitted()['change:question'][0][0])
|
|
58
67
|
.toEqual(generateQuestionOptionsSchema());
|
|
59
68
|
});
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { mount } from '@vue/test-utils';
|
|
2
2
|
import { ref } from 'vue';
|
|
3
|
-
import AuditForm from '../audit-form.vue';
|
|
4
|
-
import { generateQuestionSchema } from '../../schemas/AuditFormQuestionSchema';
|
|
5
3
|
import {
|
|
6
4
|
useDestroyableSortable,
|
|
7
|
-
} from '../../../../composables/useDestroyableSortable/useDestroyableSortable';
|
|
5
|
+
} from '../../../../composables/useDestroyableSortable/useDestroyableSortable.js';
|
|
6
|
+
import { generateQuestionSchema } from '../../schemas/AuditFormQuestionSchema.js';
|
|
7
|
+
import AuditForm from '../audit-form.vue';
|
|
8
8
|
|
|
9
|
-
vi.mock('../../../../composables/useDestroyableSortable/useDestroyableSortable');
|
|
9
|
+
vi.mock('../../../../composables/useDestroyableSortable/useDestroyableSortable.js');
|
|
10
10
|
|
|
11
11
|
useDestroyableSortable.mockImplementation(() => ({ reloadSortable: ref(false) }));
|
|
12
12
|
|
|
@@ -42,7 +42,9 @@ describe('AuditForm', () => {
|
|
|
42
42
|
questions: [generateQuestionSchema()],
|
|
43
43
|
},
|
|
44
44
|
});
|
|
45
|
-
await wrapper.findComponent({ name: 'audit-form-question' })
|
|
45
|
+
await wrapper.findComponent({ name: 'audit-form-question' })
|
|
46
|
+
.vm
|
|
47
|
+
.$emit('delete', { key: 0 });
|
|
46
48
|
expect(wrapper.emitted()['update:questions'][0][0])
|
|
47
49
|
.toEqual([]);
|
|
48
50
|
});
|
|
@@ -54,15 +56,21 @@ describe('AuditForm', () => {
|
|
|
54
56
|
questions: [question],
|
|
55
57
|
},
|
|
56
58
|
});
|
|
57
|
-
await wrapper.findComponent({ name: 'audit-form-question' })
|
|
59
|
+
await wrapper.findComponent({ name: 'audit-form-question' })
|
|
60
|
+
.vm
|
|
61
|
+
.$emit('copy', { question, key: 0 });
|
|
58
62
|
expect(wrapper.emitted()['update:questions'][0][0])
|
|
59
63
|
.toEqual([question, question]);
|
|
60
64
|
});
|
|
61
|
-
it('initializes result depending on passed questions',() => {
|
|
65
|
+
it('initializes result depending on passed questions', () => {
|
|
62
66
|
const wrapper = mount(AuditForm, {
|
|
63
67
|
props: {
|
|
64
68
|
mode: 'fill',
|
|
65
|
-
questions: [
|
|
69
|
+
questions: [
|
|
70
|
+
generateQuestionSchema(),
|
|
71
|
+
generateQuestionSchema(),
|
|
72
|
+
generateQuestionSchema(),
|
|
73
|
+
],
|
|
66
74
|
},
|
|
67
75
|
});
|
|
68
76
|
expect(wrapper.emitted()['update:result'][0][0]).toEqual([{}, {}, {}]);
|
|
@@ -1,19 +1,19 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<article
|
|
3
|
-
class="audit-form-question-read"
|
|
4
3
|
:class="{
|
|
5
4
|
'audit-form-question-read--filled': isResult && result.score != null,
|
|
6
5
|
'audit-form-question-read--readonly': readonly,
|
|
7
6
|
}"
|
|
8
|
-
|
|
7
|
+
class="audit-form-question-read"
|
|
9
8
|
@click="emit('activate')"
|
|
9
|
+
@keyup.enter="emit('activate')"
|
|
10
10
|
>
|
|
11
11
|
<header class="audit-form-question-read-header">
|
|
12
12
|
<p
|
|
13
|
-
class="audit-form-question-read-text"
|
|
14
13
|
:class="{
|
|
15
14
|
'audit-form-question-read-text--required': question.required,
|
|
16
15
|
}"
|
|
16
|
+
class="audit-form-question-read-text"
|
|
17
17
|
>
|
|
18
18
|
{{ question.question }}
|
|
19
19
|
</p>
|
|
@@ -45,10 +45,10 @@
|
|
|
45
45
|
<script setup>
|
|
46
46
|
import { computed } from 'vue';
|
|
47
47
|
import { EngineAuditQuestionType } from 'webitel-sdk';
|
|
48
|
-
import
|
|
48
|
+
import WtIcon from '../../../components/wt-icon/wt-icon.vue';
|
|
49
|
+
import isEmpty from '../../../scripts/isEmpty.js';
|
|
49
50
|
import AuditFormQuestionOptions from './questions/options/audit-form-question-options.vue';
|
|
50
51
|
import AuditFormQuestionScore from './questions/score/audit-form-question-score.vue';
|
|
51
|
-
import WtIcon from '../../../components/wt-icon/wt-icon.vue';
|
|
52
52
|
|
|
53
53
|
const props = defineProps({
|
|
54
54
|
question: {
|
|
@@ -92,9 +92,9 @@ const isResult = computed(() => !isEmpty(props.result));
|
|
|
92
92
|
position: relative;
|
|
93
93
|
display: flex;
|
|
94
94
|
flex-direction: column;
|
|
95
|
-
gap: var(--spacing-sm);
|
|
96
|
-
border: 1px solid transparent;
|
|
97
95
|
transition: var(--transition);
|
|
96
|
+
border: 1px solid transparent;
|
|
97
|
+
gap: var(--spacing-sm);
|
|
98
98
|
|
|
99
99
|
&:not(.audit-form-question-read--readonly) {
|
|
100
100
|
&:hover,
|
|
@@ -127,6 +127,7 @@ const isResult = computed(() => !isEmpty(props.result));
|
|
|
127
127
|
}
|
|
128
128
|
}
|
|
129
129
|
}
|
|
130
|
+
|
|
130
131
|
.audit-form-question--clear {
|
|
131
132
|
margin-top: var(--spacing-sm);
|
|
132
133
|
cursor: pointer;
|