127 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Svelte
		
	
	
	
	
	
			
		
		
	
	
			127 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Svelte
		
	
	
	
	
	
| <script>
 | |
|   import { _ } from "svelte-i18n";
 | |
|   import { UserGroupService } from "@odit/lfk-client-js";
 | |
|   import store from "../../store";
 | |
|   import UserGroupsEmptyState from "./UserGroupsEmptyState.svelte";
 | |
|   $: searchvalue = "";
 | |
|   $: active_deletes = [];
 | |
|   export let current_groups = [];
 | |
|   const groups_promise = UserGroupService.userGroupControllerGetAll().then(
 | |
|     (val) => {
 | |
|       current_groups = val;
 | |
|     }
 | |
|   );
 | |
| </script>
 | |
| 
 | |
| {#if store.state.jwtinfo.userdetails.permissions.includes('USERGROUP:GET')}
 | |
|   {#await groups_promise}
 | |
|     <div
 | |
|       class="bg-teal-lightest border-t-4 border-teal rounded-b text-teal-darkest px-4 py-3 shadow-md my-2"
 | |
|       role="alert">
 | |
|       <p class="font-bold">{$_('groups-are-being-loaded')}</p>
 | |
|       <p class="text-sm">{$_('this-might-take-a-moment')}</p>
 | |
|     </div>
 | |
|   {:then}
 | |
|     {#if current_groups.length === 0}
 | |
|       <UserGroupsEmptyState />
 | |
|     {:else}
 | |
|       <input
 | |
|         type="search"
 | |
|         bind:value={searchvalue}
 | |
|         placeholder={$_('datatable.search')}
 | |
|         aria-label={$_('datatable.search')}
 | |
|         class="gridjs-input gridjs-search-input mb-4" />
 | |
|       <div
 | |
|         class="shadow border-b border-gray-200 sm:rounded-lg overflow-x-scroll">
 | |
|         <table class="divide-y divide-gray-200 w-full">
 | |
|           <thead class="bg-gray-50">
 | |
|             <tr>
 | |
|               <th
 | |
|                 scope="col"
 | |
|                 class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
 | |
|                 {$_('name')}
 | |
|               </th>
 | |
|               <th
 | |
|                 scope="col"
 | |
|                 class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
 | |
|                 {$_('description')}
 | |
|               </th>
 | |
|               <th scope="col" class="relative px-6 py-3">
 | |
|                 <span class="sr-only">{$_('action')}</span>
 | |
|               </th>
 | |
|             </tr>
 | |
|           </thead>
 | |
|           <tbody class="divide-y divide-gray-200">
 | |
|             {#each current_groups as group}
 | |
|               {#if Object.values(group)
 | |
|                 .toString()
 | |
|                 .toLowerCase()
 | |
|                 .includes(searchvalue)}
 | |
|                 <tr data-rowid="user_{group.id}">
 | |
|                   <td class="px-6 py-4 whitespace-nowrap">
 | |
|                     <div class="flex items-center">
 | |
|                       <div class="ml-4">
 | |
|                         <div class="text-sm font-medium text-gray-900">
 | |
|                           {group.name}
 | |
|                         </div>
 | |
|                       </div>
 | |
|                     </div>
 | |
|                   </td>
 | |
|                   <td class="px-6 py-4 whitespace-nowrap">
 | |
|                     {group.description}
 | |
|                   </td>
 | |
|                   {#if active_deletes[group.id] === true}
 | |
|                     <td
 | |
|                       class="px-6 py-4 whitespace-nowrap text-right text-sm font-medium">
 | |
|                       <button
 | |
|                         on:click={() => {
 | |
|                           active_deletes[group.id] = false;
 | |
|                         }}
 | |
|                         tabindex="0"
 | |
|                         class="ml-4 text-indigo-600 hover:text-indigo-900 cursor-pointer">{$_('cancel-delete')}</button>
 | |
|                       <button
 | |
|                         on:click={() => {
 | |
|                           UserGroupService.userGroupControllerRemove(group.id, true)
 | |
|                             .then((resp) => {
 | |
|                               current_groups = current_groups.filter((obj) => obj.id !== group.id);
 | |
|                             })
 | |
|                             .catch((err) => {
 | |
|                               // error deleting user
 | |
|                             });
 | |
|                         }}
 | |
|                         tabindex="0"
 | |
|                         class="ml-4 text-red-600 hover:text-red-900 cursor-pointer">{$_('confirm-delete')}</button>
 | |
|                     </td>
 | |
|                   {:else}
 | |
|                     <td
 | |
|                       class="px-6 py-4 whitespace-nowrap text-right text-sm font-medium">
 | |
|                       <a
 | |
|                         href="./{group.id}"
 | |
|                         class="text-indigo-600 hover:text-indigo-900">Details</a>
 | |
|                       {#if store.state.jwtinfo.userdetails.permissions.includes('USERGROUP:DELETE')}
 | |
|                         <button
 | |
|                           on:click={() => {
 | |
|                             active_deletes[group.id] = true;
 | |
|                           }}
 | |
|                           tabindex="0"
 | |
|                           class="ml-4 text-red-600 hover:text-red-900 cursor-pointer">{$_('delete')}</button>
 | |
|                       {/if}
 | |
|                     </td>
 | |
|                   {/if}
 | |
|                 </tr>
 | |
|               {/if}
 | |
|             {/each}
 | |
|           </tbody>
 | |
|         </table>
 | |
|       </div>
 | |
|     {/if}
 | |
|   {:catch error}
 | |
|     <div class="text-white px-6 py-4 border-0 rounded relative mb-4 bg-red-500">
 | |
|       <span class="inline-block align-middle mr-8">
 | |
|         <b class="capitalize">{$_('general_promise_error')}</b>
 | |
|         {error}
 | |
|       </span>
 | |
|     </div>
 | |
|   {/await}
 | |
| {/if}
 |