Add new section functionality

This commit is contained in:
Alicia Sykes 2021-10-29 19:16:10 +01:00
parent 229e67aca8
commit beb532b967
3 changed files with 110 additions and 8 deletions

View File

@ -0,0 +1,66 @@
<!-- Main homepage for default view -->
<template>
<div class="add-section">
<!-- When in edit mode, show Add New Section button -->
<div v-if="isEditMode" @click="openAddNewSectionMenu()" class="add-new-section">
<p> {{ $t('interactive-editor.edit-section.add-section-title') }}</p>
</div>
<!-- Add new section form -->
<EditSectionMenu
v-if="isEditMode && addNewSectionOpen"
:isAddNew="true"
@closeEditSection="closeEditSection"
/>
</div>
</template>
<script>
import EditSectionMenu from '@/components/InteractiveEditor/EditSection.vue';
import StoreKeys from '@/utils/StoreMutations';
import { modalNames } from '@/utils/defaults';
export default {
name: 'add-section-container',
components: {
EditSectionMenu,
},
data: () => ({
addNewSectionOpen: false,
}),
computed: {
isEditMode() {
return this.$store.state.editMode;
},
},
methods: {
openAddNewSectionMenu() {
this.addNewSectionOpen = true;
this.$modal.show(modalNames.EDIT_SECTION);
this.$store.commit(StoreKeys.SET_MODAL_OPEN, true);
},
closeEditSection() {
this.addNewSectionOpen = false;
this.$modal.hide(modalNames.EDIT_SECTION);
this.$store.commit(StoreKeys.SET_MODAL_OPEN, false);
},
},
};
</script>
<style lang="scss" scoped>
.add-new-section {
border: 2px dashed var(--primary);
border-radius: var(--curve-factor);
padding: var(--item-group-padding);
background: var(--item-group-background);
color: var(--primary);
font-size: 1.2rem;
cursor: pointer;
text-align: center;
height: fit-content;
margin: 10px;
}
</style>

View File

@ -1,14 +1,13 @@
<template> <template>
<modal <modal
:name="modalName" :name="modalName" @closed="modalClosed"
:resizable="true" :resizable="true" width="50%" height="80%"
width="50%"
height="80%"
classes="dashy-modal edit-section" classes="dashy-modal edit-section"
@closed="modalClosed"
> >
<div class="edit-section-inner"> <div class="edit-section-inner">
<h3>{{ $t('interactive-editor.edit-section.edit-section-title') }}</h3> <h3>
{{ $t(`interactive-editor.edit-section.${isAddNew ? 'add' : 'edit'}-section-title`) }}
</h3>
<FormSchema <FormSchema
:schema="customSchema" :schema="customSchema"
v-model="sectionData" v-model="sectionData"
@ -34,6 +33,7 @@ export default {
name: 'EditSection', name: 'EditSection',
props: { props: {
sectionIndex: Number, sectionIndex: Number,
isAddNew: Boolean,
}, },
components: { components: {
SaveCancelButtons, SaveCancelButtons,
@ -47,6 +47,7 @@ export default {
}; };
}, },
computed: { computed: {
/* Make a custom schema object, using fields from ConfigSchema */
customSchema() { customSchema() {
const sectionSchema = this.schema; const sectionSchema = this.schema;
const displayDataSchema = this.schema.displayData.properties; const displayDataSchema = this.schema.displayData.properties;
@ -76,7 +77,9 @@ export default {
this.$modal.show(modalNames.EDIT_SECTION); this.$modal.show(modalNames.EDIT_SECTION);
}, },
methods: { methods: {
/* From the current index, return section data */
getSectionFromState(index) { getSectionFromState(index) {
if (this.isAddNew) return {};
return this.$store.getters.getSectionByIndex(index); return this.$store.getters.getSectionByIndex(index);
}, },
/* Clean up work, triggered when modal closed */ /* Clean up work, triggered when modal closed */
@ -84,9 +87,14 @@ export default {
this.$store.commit(StoreKeys.SET_MODAL_OPEN, false); this.$store.commit(StoreKeys.SET_MODAL_OPEN, false);
this.$emit('closeEditSection'); this.$emit('closeEditSection');
}, },
/* Either update existing section, or insert new one, then close modal */
saveSection() { saveSection() {
const { sectionIndex, sectionData } = this; const { sectionIndex, sectionData } = this;
this.$store.commit(StoreKeys.UPDATE_SECTION, { sectionIndex, sectionData }); if (this.isAddNew) {
this.$store.commit(StoreKeys.INSERT_SECTION, sectionData);
} else {
this.$store.commit(StoreKeys.UPDATE_SECTION, { sectionIndex, sectionData });
}
this.$store.commit(StoreKeys.SET_EDIT_MODE, true); this.$store.commit(StoreKeys.SET_EDIT_MODE, true);
this.$emit('closeEditSection'); this.$emit('closeEditSection');
}, },

View File

@ -44,6 +44,8 @@
:class=" :class="
(searchValue && filterTiles(section.items, searchValue).length === 0) ? 'no-results' : ''" (searchValue && filterTiles(section.items, searchValue).length === 0) ? 'no-results' : ''"
/> />
<!-- Show add new section button, in edit mode -->
<AddNewSection v-if="isEditMode" />
</div> </div>
<!-- Show message when there's no data to show --> <!-- Show message when there's no data to show -->
<div v-if="checkIfResults()" class="no-data"> <div v-if="checkIfResults()" class="no-data">
@ -62,8 +64,10 @@ import SettingsContainer from '@/components/Settings/SettingsContainer.vue';
import Section from '@/components/LinkItems/Section.vue'; import Section from '@/components/LinkItems/Section.vue';
import EditModeSaveMenu from '@/components/InteractiveEditor/EditModeSaveMenu.vue'; import EditModeSaveMenu from '@/components/InteractiveEditor/EditModeSaveMenu.vue';
import ExportConfigMenu from '@/components/InteractiveEditor/ExportConfigMenu.vue'; import ExportConfigMenu from '@/components/InteractiveEditor/ExportConfigMenu.vue';
import AddNewSection from '@/components/InteractiveEditor/AddNewSectionLauncher.vue';
import { searchTiles } from '@/utils/Search'; import { searchTiles } from '@/utils/Search';
import Defaults, { localStorageKeys, iconCdns } from '@/utils/defaults'; import StoreKeys from '@/utils/StoreMutations';
import Defaults, { localStorageKeys, iconCdns, modalNames } from '@/utils/defaults';
import ErrorHandler from '@/utils/ErrorHandler'; import ErrorHandler from '@/utils/ErrorHandler';
import BackIcon from '@/assets/interface-icons/back-arrow.svg'; import BackIcon from '@/assets/interface-icons/back-arrow.svg';
@ -73,6 +77,7 @@ export default {
SettingsContainer, SettingsContainer,
EditModeSaveMenu, EditModeSaveMenu,
ExportConfigMenu, ExportConfigMenu,
AddNewSection,
Section, Section,
BackIcon, BackIcon,
}, },
@ -80,6 +85,7 @@ export default {
searchValue: '', searchValue: '',
layout: '', layout: '',
itemSizeBound: '', itemSizeBound: '',
addNewSectionOpen: false,
}), }),
computed: { computed: {
sections() { sections() {
@ -164,6 +170,16 @@ export default {
updateModalVisibility(modalState) { updateModalVisibility(modalState) {
this.$store.commit('SET_MODAL_OPEN', modalState); this.$store.commit('SET_MODAL_OPEN', modalState);
}, },
openAddNewSectionMenu() {
this.addNewSectionOpen = true;
this.$modal.show(modalNames.EDIT_SECTION);
this.$store.commit(StoreKeys.SET_MODAL_OPEN, true);
},
closeEditSection() {
this.addNewSectionOpen = false;
this.$modal.hide(modalNames.EDIT_SECTION);
this.$store.commit(StoreKeys.SET_MODAL_OPEN, false);
},
/* If on sub-route, and section exists, then return only that section */ /* If on sub-route, and section exists, then return only that section */
findSingleSection: (allSections, sectionTitle) => { findSingleSection: (allSections, sectionTitle) => {
if (!sectionTitle) return undefined; if (!sectionTitle) return undefined;
@ -346,6 +362,18 @@ export default {
&.single-section-view { &.single-section-view {
display: block; display: block;
} }
.add-new-section {
border: 2px dashed var(--primary);
border-radius: var(--curve-factor);
padding: var(--item-group-padding);
background: var(--item-group-background);
color: var(--primary);
font-size: 1.2rem;
cursor: pointer;
text-align: center;
height: fit-content;
margin: 10px;
}
} }
/* Custom styles only applied when there is no sections in config */ /* Custom styles only applied when there is no sections in config */