mirror of
https://github.com/lingble/chatwoot.git
synced 2025-11-01 19:48:08 +00:00
# Pull Request Template ## Description Fixes https://linear.app/chatwoot/issue/CW-4091/accessibility-improvement-support-bigger-font-size-for-the-dashboard ## Type of change - [x] New feature (non-breaking change which adds functionality) ## How Has This Been Tested? ### **Loom video** https://www.loom.com/share/1ab781859fa748a5ad54aacbacd127b4?sid=a7dd9164-a6de-462f-bff7-1b25e9c55b4f ## Checklist: - [x] My code follows the style guidelines of this project - [x] I have performed a self-review of my code - [x] I have commented on my code, particularly in hard-to-understand areas - [ ] I have made corresponding changes to the documentation - [x] My changes generate no new warnings - [x] I have added tests that prove my fix is effective or that my feature works - [x] New and existing unit tests pass locally with my changes - [ ] Any dependent changes have been merged and published in downstream modules
190 lines
6.8 KiB
Vue
190 lines
6.8 KiB
Vue
<script setup>
|
|
import { useAlert } from 'dashboard/composables';
|
|
import Thumbnail from 'dashboard/components/widgets/Thumbnail.vue';
|
|
import { useAdmin } from 'dashboard/composables/useAdmin';
|
|
import SettingsLayout from '../SettingsLayout.vue';
|
|
import BaseSettingsHeader from '../components/BaseSettingsHeader.vue';
|
|
import { computed, ref } from 'vue';
|
|
import { useI18n } from 'vue-i18n';
|
|
import { useStoreGetters, useStore } from 'dashboard/composables/store';
|
|
import ChannelName from './components/ChannelName.vue';
|
|
|
|
const getters = useStoreGetters();
|
|
const store = useStore();
|
|
const { t } = useI18n();
|
|
const { isAdmin } = useAdmin();
|
|
|
|
const showDeletePopup = ref(false);
|
|
const selectedInbox = ref({});
|
|
|
|
const inboxesList = computed(() => getters['inboxes/getInboxes'].value);
|
|
const uiFlags = computed(() => getters['inboxes/getUIFlags'].value);
|
|
|
|
const deleteConfirmText = computed(
|
|
() => `${t('INBOX_MGMT.DELETE.CONFIRM.YES')} ${selectedInbox.value.name}`
|
|
);
|
|
|
|
const deleteRejectText = computed(
|
|
() => `${t('INBOX_MGMT.DELETE.CONFIRM.NO')} ${selectedInbox.value.name}`
|
|
);
|
|
|
|
const confirmDeleteMessage = computed(
|
|
() => `${t('INBOX_MGMT.DELETE.CONFIRM.MESSAGE')} ${selectedInbox.value.name}?`
|
|
);
|
|
const confirmPlaceHolderText = computed(
|
|
() =>
|
|
`${t('INBOX_MGMT.DELETE.CONFIRM.PLACE_HOLDER', {
|
|
inboxName: selectedInbox.value.name,
|
|
})}`
|
|
);
|
|
|
|
const deleteInbox = async ({ id }) => {
|
|
try {
|
|
await store.dispatch('inboxes/delete', id);
|
|
useAlert(t('INBOX_MGMT.DELETE.API.SUCCESS_MESSAGE'));
|
|
} catch (error) {
|
|
useAlert(t('INBOX_MGMT.DELETE.API.ERROR_MESSAGE'));
|
|
}
|
|
};
|
|
const closeDelete = () => {
|
|
showDeletePopup.value = false;
|
|
selectedInbox.value = {};
|
|
};
|
|
|
|
const confirmDeletion = () => {
|
|
deleteInbox(selectedInbox.value);
|
|
closeDelete();
|
|
};
|
|
const openDelete = inbox => {
|
|
showDeletePopup.value = true;
|
|
selectedInbox.value = inbox;
|
|
};
|
|
</script>
|
|
|
|
<template>
|
|
<SettingsLayout
|
|
:no-records-found="!inboxesList.length"
|
|
:no-records-message="$t('INBOX_MGMT.LIST.404')"
|
|
:is-loading="uiFlags.isFetching"
|
|
>
|
|
<template #header>
|
|
<BaseSettingsHeader
|
|
:title="$t('INBOX_MGMT.HEADER')"
|
|
:description="$t('INBOX_MGMT.DESCRIPTION')"
|
|
:link-text="$t('INBOX_MGMT.LEARN_MORE')"
|
|
feature-name="inboxes"
|
|
>
|
|
<template #actions>
|
|
<router-link
|
|
v-if="isAdmin"
|
|
class="button nice rounded-md"
|
|
:to="{ name: 'settings_inbox_new' }"
|
|
>
|
|
<fluent-icon icon="add-circle" />
|
|
{{ $t('SETTINGS.INBOXES.NEW_INBOX') }}
|
|
</router-link>
|
|
</template>
|
|
</BaseSettingsHeader>
|
|
</template>
|
|
<template #body>
|
|
<table
|
|
class="min-w-full overflow-x-auto divide-y divide-slate-75 dark:divide-slate-700"
|
|
>
|
|
<tbody
|
|
class="divide-y divide-slate-25 dark:divide-slate-800 flex-1 text-slate-700 dark:text-slate-100"
|
|
>
|
|
<tr v-for="inbox in inboxesList" :key="inbox.id">
|
|
<td class="py-4 ltr:pr-4 rtl:pl-4">
|
|
<div class="flex items-center flex-row gap-4">
|
|
<Thumbnail
|
|
v-if="inbox.avatar_url"
|
|
class="bg-black-50 dark:bg-black-800 rounded-full p-2 ring ring-opacity-20 dark:ring-opacity-80 ring-black-100 dark:ring-black-900 border border-slate-100 dark:border-slate-700/50 shadow-sm"
|
|
:src="inbox.avatar_url"
|
|
:username="inbox.name"
|
|
size="48px"
|
|
/>
|
|
<div
|
|
v-else
|
|
class="w-[48px] h-[48px] flex justify-center items-center bg-black-50 dark:bg-black-800 rounded-full p-2 ring ring-opacity-20 dark:ring-opacity-80 ring-black-100 dark:ring-black-900 border border-slate-100 dark:border-slate-700/50 shadow-sm"
|
|
>
|
|
<svg
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
width="32"
|
|
height="32"
|
|
viewBox="0 0 24 24"
|
|
class="opacity-80 p-1 flex-shrink-0"
|
|
>
|
|
<path
|
|
fill="currentColor"
|
|
d="M1 12c0-5.185 0-7.778 1.61-9.39C4.223 1 6.816 1 12 1s7.778 0 9.39 1.61C23 4.223 23 6.816 23 12s0 7.778-1.61 9.39C19.777 23 17.184 23 12 23s-7.778 0-9.39-1.61C1 19.777 1 17.184 1 12"
|
|
opacity=".35"
|
|
/>
|
|
<path
|
|
fill="currentColor"
|
|
d="M2.61 21.389c1.612 1.61 4.205 1.61 9.39 1.61s7.778 0 9.39-1.61c1.492-1.493 1.601-3.829 1.61-8.29h-3.476c-.996 0-1.494 0-1.931.202c-.438.201-.762.58-1.41 1.335l-.666.777c-.648.756-.972 1.134-1.41 1.335s-.935.202-1.93.202h-.353c-.996 0-1.494 0-1.931-.202c-.438-.2-.762-.579-1.41-1.335l-.666-.777c-.648-.756-.972-1.134-1.41-1.335s-.935-.201-1.93-.201H1c.008 4.46.118 6.796 1.61 8.289"
|
|
/>
|
|
</svg>
|
|
</div>
|
|
<div>
|
|
<span class="block font-medium capitalize">
|
|
{{ inbox.name }}
|
|
</span>
|
|
<ChannelName
|
|
:channel-type="inbox.channel_type"
|
|
:medium="inbox.medium"
|
|
/>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
|
|
<td class="py-4">
|
|
<div class="flex gap-1 justify-end">
|
|
<router-link
|
|
:to="{
|
|
name: 'settings_inbox_show',
|
|
params: { inboxId: inbox.id },
|
|
}"
|
|
>
|
|
<woot-button
|
|
v-if="isAdmin"
|
|
v-tooltip.top="$t('INBOX_MGMT.SETTINGS')"
|
|
variant="smooth"
|
|
size="tiny"
|
|
icon="settings"
|
|
color-scheme="secondary"
|
|
class-names="grey-btn"
|
|
/>
|
|
</router-link>
|
|
|
|
<woot-button
|
|
v-if="isAdmin"
|
|
v-tooltip.top="$t('INBOX_MGMT.DELETE.BUTTON_TEXT')"
|
|
variant="smooth"
|
|
color-scheme="alert"
|
|
size="tiny"
|
|
class-names="grey-btn"
|
|
icon="dismiss-circle"
|
|
@click="openDelete(inbox)"
|
|
/>
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</template>
|
|
|
|
<woot-confirm-delete-modal
|
|
v-if="showDeletePopup"
|
|
v-model:show="showDeletePopup"
|
|
:title="$t('INBOX_MGMT.DELETE.CONFIRM.TITLE')"
|
|
:message="confirmDeleteMessage"
|
|
:confirm-text="deleteConfirmText"
|
|
:reject-text="deleteRejectText"
|
|
:confirm-value="selectedInbox.name"
|
|
:confirm-place-holder-text="confirmPlaceHolderText"
|
|
@on-confirm="confirmDeletion"
|
|
@on-close="closeDelete"
|
|
/>
|
|
</SettingsLayout>
|
|
</template>
|