aboutsummaryrefslogtreecommitdiffstats
path: root/components/editor/quest/EditorQuestTasksOptionsPanel.vue
diff options
context:
space:
mode:
authorLeonardo Bishop <me@leonardobishop.com>2024-03-12 17:48:23 +0000
committerLeonardo Bishop <me@leonardobishop.com>2024-03-12 17:48:23 +0000
commitaddf95bc7e1e694cd9ba7797c8b0847bfecaf54c (patch)
tree422e96cb24eb3b3ec9d4c96de555b8fa14239c59 /components/editor/quest/EditorQuestTasksOptionsPanel.vue
parent8664ad155c89d47affd94f8b0385ebf39841f1f8 (diff)
Add nuxt prefixes back to component file names
Diffstat (limited to 'components/editor/quest/EditorQuestTasksOptionsPanel.vue')
-rw-r--r--components/editor/quest/EditorQuestTasksOptionsPanel.vue83
1 files changed, 83 insertions, 0 deletions
diff --git a/components/editor/quest/EditorQuestTasksOptionsPanel.vue b/components/editor/quest/EditorQuestTasksOptionsPanel.vue
new file mode 100644
index 0000000..cb4b109
--- /dev/null
+++ b/components/editor/quest/EditorQuestTasksOptionsPanel.vue
@@ -0,0 +1,83 @@
+<script setup lang="ts">
+import { useSessionStore, type EditorQuest } from '@/stores/session';
+import { computed, ref } from 'vue';
+
+const props = defineProps<{
+ questId: string;
+}>();
+
+const sessionStore = useSessionStore();
+
+const quest = computed(() => {
+ return sessionStore.getQuestById(props.questId) as EditorQuest;
+});
+
+const showAddTaskModal = ref(false);
+
+const addTask = (newId: string, newType: string) => {
+ sessionStore.getQuestById(props.questId)!.tasks[newId] = {
+ id: newId,
+ config: {
+ type: newType,
+ },
+ };
+
+ showAddTaskModal.value = false;
+};
+</script>
+
+<template>
+ <EditorOptionsPanel v-if="quest">
+ <div id="options">
+ <h2>Tasks <code>({{ Object.keys(quest.tasks).length }})</code></h2>
+
+ <p v-if="Object.keys(quest.tasks).length === 0" class="error-text">This quest does not have any tasks.</p>
+ <EditorTaskConfiguration v-for="(task, taskId) in quest.tasks" :key="taskId" :taskId="String(taskId)"
+ :quest="quest" />
+
+ <div id="controls">
+ <Button id="add-task" :icon="['fas', 'plus']" type="solid" label="Add task" @click="showAddTaskModal = true" />
+ </div>
+ </div>
+ </EditorOptionsPanel>
+
+ <EditorTaskModalCreate v-if="quest" v-model="showAddTaskModal" :questId="questId" @add="addTask" />
+</template>
+
+
+<style scoped>
+#options {
+ display: flex;
+ flex-direction: column;
+ gap: 1rem;
+
+ #controls {
+ display: flex;
+ justify-content: flex-end;
+ gap: 1rem;
+ }
+}
+
+.option-group {
+ display: flex;
+ flex-direction: column;
+ gap: 0.5rem;
+}
+
+.description {
+ font-size: 0.8em;
+}
+
+label {
+ font-weight: 700;
+}
+
+h2 {
+ border-bottom: 1px solid var(--color-border);
+
+ code {
+ font-size: 0.8em;
+ color: var(--color-text-mute);
+ }
+}
+</style>