feat: select label preferences with dropdown
This commit is contained in:
		
							parent
							
								
									18fc764d64
								
							
						
					
					
						commit
						e3f3ac1d8d
					
				
					 8 changed files with 327 additions and 171 deletions
				
			
		|  | @ -2,6 +2,7 @@ | |||
|   import { WordStatus, type Field } from "$lib/api/entities"; | ||||
|   import IconButton from "$lib/components/IconButton.svelte"; | ||||
|   import { Button, Input, InputGroup, InputGroupText } from "sveltestrap"; | ||||
|   import FieldEntry from "./FieldEntry.svelte"; | ||||
| 
 | ||||
|   export let field: Field; | ||||
|   export let deleteField: () => void; | ||||
|  | @ -25,12 +26,8 @@ | |||
|   }; | ||||
| 
 | ||||
|   const removeEntry = (index: number) => { | ||||
|     if (field.entries.length === 1) field.entries = []; | ||||
|     else if (index === 0) field.entries = field.entries.slice(1); | ||||
|     else if (index === field.entries.length - 1) | ||||
|       field.entries = field.entries.slice(0, field.entries.length - 1); | ||||
|     else | ||||
|       field.entries = [...field.entries.slice(0, index - 1), ...field.entries.slice(0, index + 1)]; | ||||
|     field.entries.splice(index, 1); | ||||
|     field.entries = [...field.entries]; | ||||
|   }; | ||||
| </script> | ||||
| 
 | ||||
|  | @ -41,62 +38,13 @@ | |||
|     <Button color="danger" on:click={() => deleteField()}>Delete field</Button> | ||||
|   </InputGroup> | ||||
|   {#each field.entries as _, index} | ||||
|     <div class="input-group m-1"> | ||||
|       <IconButton | ||||
|         color="secondary" | ||||
|         icon="chevron-up" | ||||
|         tooltip="Move entry up" | ||||
|         click={() => moveEntry(index, true)} | ||||
|       /> | ||||
|       <IconButton | ||||
|         color="secondary" | ||||
|         icon="chevron-down" | ||||
|         tooltip="Move entry down" | ||||
|         click={() => moveEntry(index, false)} | ||||
|       /> | ||||
|       <input type="text" class="form-control" bind:value={field.entries[index].value} /> | ||||
|       <IconButton | ||||
|         color="secondary" | ||||
|         icon="heart-fill" | ||||
|         tooltip="Favourite" | ||||
|         click={() => (field.entries[index].status = WordStatus.Favourite)} | ||||
|         active={field.entries[index].status === WordStatus.Favourite} | ||||
|       /> | ||||
|       <IconButton | ||||
|         color="secondary" | ||||
|         icon="hand-thumbs-up" | ||||
|         tooltip="Okay" | ||||
|         click={() => (field.entries[index].status = WordStatus.Okay)} | ||||
|         active={field.entries[index].status === WordStatus.Okay} | ||||
|       /> | ||||
|       <IconButton | ||||
|         color="secondary" | ||||
|         icon="emoji-laughing" | ||||
|         tooltip="Jokingly" | ||||
|         click={() => (field.entries[index].status = WordStatus.Jokingly)} | ||||
|         active={field.entries[index].status === WordStatus.Jokingly} | ||||
|       /> | ||||
|       <IconButton | ||||
|         color="secondary" | ||||
|         icon="people" | ||||
|         tooltip="Friends only" | ||||
|         click={() => (field.entries[index].status = WordStatus.FriendsOnly)} | ||||
|         active={field.entries[index].status === WordStatus.FriendsOnly} | ||||
|       /> | ||||
|       <IconButton | ||||
|         color="secondary" | ||||
|         icon="hand-thumbs-down" | ||||
|         tooltip="Avoid" | ||||
|         click={() => (field.entries[index].status = WordStatus.Avoid)} | ||||
|         active={field.entries[index].status === WordStatus.Avoid} | ||||
|       /> | ||||
|       <IconButton | ||||
|         color="danger" | ||||
|         icon="trash3" | ||||
|         tooltip="Remove entry" | ||||
|         click={() => removeEntry(index)} | ||||
|       /> | ||||
|     </div> | ||||
|     <FieldEntry | ||||
|       bind:value={field.entries[index].value} | ||||
|       bind:status={field.entries[index].status} | ||||
|       moveUp={() => moveEntry(index, true)} | ||||
|       moveDown={() => moveEntry(index, false)} | ||||
|       remove={() => removeEntry(index)} | ||||
|     /> | ||||
|   {/each} | ||||
| 
 | ||||
|   <div class="input-group m-1"> | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue