149 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Svelte
		
	
	
	
	
	
			
		
		
	
	
			149 lines
		
	
	
		
			5.4 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="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 class="odd:bg-white even:bg-gray-100">
 | |
|               <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
 | |
|                   class="odd:bg-white even:bg-gray-100"
 | |
|                   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}
 |