GroupItem.svelte 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. <script>
  2. import { toast } from 'svelte-sonner';
  3. import { onMount, getContext } from 'svelte';
  4. const i18n = getContext('i18n');
  5. import { deleteGroupById, updateGroupById } from '$lib/apis/groups';
  6. import Pencil from '$lib/components/icons/Pencil.svelte';
  7. import User from '$lib/components/icons/User.svelte';
  8. import UserCircleSolid from '$lib/components/icons/UserCircleSolid.svelte';
  9. import GroupModal from './EditGroupModal.svelte';
  10. import { querystringValue } from '$lib/utils';
  11. export let users = [];
  12. export let group = {
  13. name: 'Admins',
  14. user_ids: [1, 2, 3]
  15. };
  16. export let setGroups = () => {};
  17. let showEdit = false;
  18. const updateHandler = async (_group) => {
  19. const res = await updateGroupById(localStorage.token, group.id, _group).catch((error) => {
  20. toast.error(`${error}`);
  21. return null;
  22. });
  23. if (res) {
  24. toast.success($i18n.t('Group updated successfully'));
  25. setGroups();
  26. }
  27. };
  28. const deleteHandler = async () => {
  29. const res = await deleteGroupById(localStorage.token, group.id).catch((error) => {
  30. toast.error(`${error}`);
  31. return null;
  32. });
  33. if (res) {
  34. toast.success($i18n.t('Group deleted successfully'));
  35. setGroups();
  36. }
  37. };
  38. onMount(() => {
  39. const groupId = querystringValue('id');
  40. if (groupId && groupId === group.id) {
  41. showEdit = true;
  42. }
  43. });
  44. </script>
  45. <GroupModal
  46. bind:show={showEdit}
  47. edit
  48. {users}
  49. {group}
  50. onSubmit={updateHandler}
  51. onDelete={deleteHandler}
  52. />
  53. <button
  54. class="flex items-center gap-3 justify-between px-1 text-xs w-full transition"
  55. on:click={() => {
  56. showEdit = true;
  57. }}
  58. >
  59. <div class="flex items-center gap-1.5 w-full font-medium flex-1">
  60. <div>
  61. <UserCircleSolid className="size-4" />
  62. </div>
  63. <div class="line-clamp-1">
  64. {group.name}
  65. </div>
  66. </div>
  67. <div class="flex items-center gap-1.5 w-fit font-medium text-right justify-end">
  68. {group.user_ids.length}
  69. <div>
  70. <User className="size-3.5" />
  71. </div>
  72. <div class=" rounded-lg p-1 hover:bg-gray-100 dark:hover:bg-gray-850 transition">
  73. <Pencil className="size-3.5" />
  74. </div>
  75. </div>
  76. </button>