|
| 1 | +<template> |
| 2 | + <div v-if="isEntering" class="flex items-center"> |
| 3 | + <label class="input w-auto"> |
| 4 | + <input |
| 5 | + ref="newFileInputElement" |
| 6 | + v-model="newFileStem" |
| 7 | + type="text" |
| 8 | + placeholder="new file" |
| 9 | + class="w-16" |
| 10 | + @keyup.enter="addNewFile" |
| 11 | + /> |
| 12 | + <span class="label">.{{ previewStore.syntax }}</span> |
| 13 | + </label> |
| 14 | + </div> |
| 15 | + |
| 16 | + <div v-else class="flex items-center"> |
| 17 | + <div class="tooltip tooltip-right" data-tip="Add new file"> |
| 18 | + <Icon name="prime:plus" @click="isEntering = true" /> |
| 19 | + </div> |
| 20 | + </div> |
| 21 | +</template> |
| 22 | + |
| 23 | +<script setup lang="ts"> |
| 24 | +const previewStore = usePreviewStore(); |
| 25 | +
|
| 26 | +const isEntering = ref(false); |
| 27 | +const newFileStem = ref(""); |
| 28 | +const newFileInputElement = useTemplateRef("newFileInputElement"); |
| 29 | +
|
| 30 | +// Set focus on first render |
| 31 | +useFocus(newFileInputElement, { initialValue: true }); |
| 32 | +
|
| 33 | +// Add file when clicked outside |
| 34 | +onClickOutside(newFileInputElement, addNewFile); |
| 35 | +
|
| 36 | +function addNewFile() { |
| 37 | + const stem = newFileStem.value; |
| 38 | + const filename = stem + "." + previewStore.syntax; |
| 39 | +
|
| 40 | + // Nothing has been entered, back to NOT entering state |
| 41 | + if (!stem.trim()) { |
| 42 | + isEntering.value = false; |
| 43 | + return; |
| 44 | + } |
| 45 | +
|
| 46 | + // Exist? |
| 47 | + if (filename in previewStore.files) { |
| 48 | + alert("Filename already exists"); |
| 49 | + // Return back to NOT entering state |
| 50 | + isEntering.value = false; |
| 51 | + return; |
| 52 | + } |
| 53 | +
|
| 54 | + // Add new blank file with that filename |
| 55 | + previewStore.files[filename] = ""; |
| 56 | +
|
| 57 | + // Return back to NOT entering state |
| 58 | + newFileStem.value = ""; |
| 59 | + isEntering.value = false; |
| 60 | +} |
| 61 | +</script> |
0 commit comments