|
@@ -13,6 +13,9 @@
|
|
import EditUserModal from '$lib/components/admin/EditUserModal.svelte';
|
|
import EditUserModal from '$lib/components/admin/EditUserModal.svelte';
|
|
import SettingsModal from '$lib/components/admin/SettingsModal.svelte';
|
|
import SettingsModal from '$lib/components/admin/SettingsModal.svelte';
|
|
import Pagination from '$lib/components/common/Pagination.svelte';
|
|
import Pagination from '$lib/components/common/Pagination.svelte';
|
|
|
|
+ import ChatBubbles from '$lib/components/icons/ChatBubbles.svelte';
|
|
|
|
+ import Tooltip from '$lib/components/common/Tooltip.svelte';
|
|
|
|
+ import UserChatsModal from '$lib/components/admin/UserChatsModal.svelte';
|
|
|
|
|
|
const i18n = getContext('i18n');
|
|
const i18n = getContext('i18n');
|
|
|
|
|
|
@@ -25,6 +28,8 @@
|
|
let page = 1;
|
|
let page = 1;
|
|
|
|
|
|
let showSettingsModal = false;
|
|
let showSettingsModal = false;
|
|
|
|
+
|
|
|
|
+ let showUserChatsModal = false;
|
|
let showEditUserModal = false;
|
|
let showEditUserModal = false;
|
|
|
|
|
|
const updateRoleHandler = async (id, role) => {
|
|
const updateRoleHandler = async (id, role) => {
|
|
@@ -84,6 +89,7 @@
|
|
/>
|
|
/>
|
|
{/key}
|
|
{/key}
|
|
|
|
|
|
|
|
+<UserChatsModal bind:show={showUserChatsModal} user={selectedUser} />
|
|
<SettingsModal bind:show={showSettingsModal} />
|
|
<SettingsModal bind:show={showSettingsModal} />
|
|
|
|
|
|
<div class="min-h-screen max-h-[100dvh] w-full flex justify-center dark:text-white">
|
|
<div class="min-h-screen max-h-[100dvh] w-full flex justify-center dark:text-white">
|
|
@@ -220,50 +226,66 @@
|
|
|
|
|
|
<td class="px-3 py-2 text-right">
|
|
<td class="px-3 py-2 text-right">
|
|
<div class="flex justify-end w-full">
|
|
<div class="flex justify-end w-full">
|
|
- <button
|
|
|
|
- class="self-center w-fit text-sm px-2 py-2 hover:bg-black/5 dark:hover:bg-white/5 rounded-xl"
|
|
|
|
- on:click={async () => {
|
|
|
|
- showEditUserModal = !showEditUserModal;
|
|
|
|
- selectedUser = user;
|
|
|
|
- }}
|
|
|
|
- >
|
|
|
|
- <svg
|
|
|
|
- xmlns="http://www.w3.org/2000/svg"
|
|
|
|
- fill="none"
|
|
|
|
- viewBox="0 0 24 24"
|
|
|
|
- stroke-width="1.5"
|
|
|
|
- stroke="currentColor"
|
|
|
|
- class="w-4 h-4"
|
|
|
|
|
|
+ <Tooltip content="Chats">
|
|
|
|
+ <button
|
|
|
|
+ class="self-center w-fit text-sm px-2 py-2 hover:bg-black/5 dark:hover:bg-white/5 rounded-xl"
|
|
|
|
+ on:click={async () => {
|
|
|
|
+ showUserChatsModal = !showUserChatsModal;
|
|
|
|
+ selectedUser = user;
|
|
|
|
+ }}
|
|
|
|
+ >
|
|
|
|
+ <ChatBubbles />
|
|
|
|
+ </button>
|
|
|
|
+ </Tooltip>
|
|
|
|
+
|
|
|
|
+ <Tooltip content="Edit User">
|
|
|
|
+ <button
|
|
|
|
+ class="self-center w-fit text-sm px-2 py-2 hover:bg-black/5 dark:hover:bg-white/5 rounded-xl"
|
|
|
|
+ on:click={async () => {
|
|
|
|
+ showEditUserModal = !showEditUserModal;
|
|
|
|
+ selectedUser = user;
|
|
|
|
+ }}
|
|
>
|
|
>
|
|
- <path
|
|
|
|
- stroke-linecap="round"
|
|
|
|
- stroke-linejoin="round"
|
|
|
|
- d="m16.862 4.487 1.687-1.688a1.875 1.875 0 1 1 2.652 2.652L6.832 19.82a4.5 4.5 0 0 1-1.897 1.13l-2.685.8.8-2.685a4.5 4.5 0 0 1 1.13-1.897L16.863 4.487Zm0 0L19.5 7.125"
|
|
|
|
- />
|
|
|
|
- </svg>
|
|
|
|
- </button>
|
|
|
|
-
|
|
|
|
- <button
|
|
|
|
- class="self-center w-fit text-sm px-2 py-2 hover:bg-black/5 dark:hover:bg-white/5 rounded-xl"
|
|
|
|
- on:click={async () => {
|
|
|
|
- deleteUserHandler(user.id);
|
|
|
|
- }}
|
|
|
|
- >
|
|
|
|
- <svg
|
|
|
|
- xmlns="http://www.w3.org/2000/svg"
|
|
|
|
- fill="none"
|
|
|
|
- viewBox="0 0 24 24"
|
|
|
|
- stroke-width="1.5"
|
|
|
|
- stroke="currentColor"
|
|
|
|
- class="w-4 h-4"
|
|
|
|
|
|
+ <svg
|
|
|
|
+ xmlns="http://www.w3.org/2000/svg"
|
|
|
|
+ fill="none"
|
|
|
|
+ viewBox="0 0 24 24"
|
|
|
|
+ stroke-width="1.5"
|
|
|
|
+ stroke="currentColor"
|
|
|
|
+ class="w-4 h-4"
|
|
|
|
+ >
|
|
|
|
+ <path
|
|
|
|
+ stroke-linecap="round"
|
|
|
|
+ stroke-linejoin="round"
|
|
|
|
+ d="m16.862 4.487 1.687-1.688a1.875 1.875 0 1 1 2.652 2.652L6.832 19.82a4.5 4.5 0 0 1-1.897 1.13l-2.685.8.8-2.685a4.5 4.5 0 0 1 1.13-1.897L16.863 4.487Zm0 0L19.5 7.125"
|
|
|
|
+ />
|
|
|
|
+ </svg>
|
|
|
|
+ </button>
|
|
|
|
+ </Tooltip>
|
|
|
|
+
|
|
|
|
+ <Tooltip content="Delete User">
|
|
|
|
+ <button
|
|
|
|
+ class="self-center w-fit text-sm px-2 py-2 hover:bg-black/5 dark:hover:bg-white/5 rounded-xl"
|
|
|
|
+ on:click={async () => {
|
|
|
|
+ deleteUserHandler(user.id);
|
|
|
|
+ }}
|
|
>
|
|
>
|
|
- <path
|
|
|
|
- stroke-linecap="round"
|
|
|
|
- stroke-linejoin="round"
|
|
|
|
- d="m14.74 9-.346 9m-4.788 0L9.26 9m9.968-3.21c.342.052.682.107 1.022.166m-1.022-.165L18.16 19.673a2.25 2.25 0 0 1-2.244 2.077H8.084a2.25 2.25 0 0 1-2.244-2.077L4.772 5.79m14.456 0a48.108 48.108 0 0 0-3.478-.397m-12 .562c.34-.059.68-.114 1.022-.165m0 0a48.11 48.11 0 0 1 3.478-.397m7.5 0v-.916c0-1.18-.91-2.164-2.09-2.201a51.964 51.964 0 0 0-3.32 0c-1.18.037-2.09 1.022-2.09 2.201v.916m7.5 0a48.667 48.667 0 0 0-7.5 0"
|
|
|
|
- />
|
|
|
|
- </svg>
|
|
|
|
- </button>
|
|
|
|
|
|
+ <svg
|
|
|
|
+ xmlns="http://www.w3.org/2000/svg"
|
|
|
|
+ fill="none"
|
|
|
|
+ viewBox="0 0 24 24"
|
|
|
|
+ stroke-width="1.5"
|
|
|
|
+ stroke="currentColor"
|
|
|
|
+ class="w-4 h-4"
|
|
|
|
+ >
|
|
|
|
+ <path
|
|
|
|
+ stroke-linecap="round"
|
|
|
|
+ stroke-linejoin="round"
|
|
|
|
+ d="m14.74 9-.346 9m-4.788 0L9.26 9m9.968-3.21c.342.052.682.107 1.022.166m-1.022-.165L18.16 19.673a2.25 2.25 0 0 1-2.244 2.077H8.084a2.25 2.25 0 0 1-2.244-2.077L4.772 5.79m14.456 0a48.108 48.108 0 0 0-3.478-.397m-12 .562c.34-.059.68-.114 1.022-.165m0 0a48.11 48.11 0 0 1 3.478-.397m7.5 0v-.916c0-1.18-.91-2.164-2.09-2.201a51.964 51.964 0 0 0-3.32 0c-1.18.037-2.09 1.022-2.09 2.201v.916m7.5 0a48.667 48.667 0 0 0-7.5 0"
|
|
|
|
+ />
|
|
|
|
+ </svg>
|
|
|
|
+ </button>
|
|
|
|
+ </Tooltip>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
</td>
|
|
</tr>
|
|
</tr>
|