more refactoring of screen wizard

This commit is contained in:
Peter Clement 2021-11-17 10:24:14 +00:00
parent 63fc3dcc13
commit ac9f30612c
4 changed files with 36 additions and 34 deletions

View File

@ -5,11 +5,10 @@
import sanitizeUrl from "builderStore/store/screenTemplates/utils/sanitizeUrl" import sanitizeUrl from "builderStore/store/screenTemplates/utils/sanitizeUrl"
import { onDestroy } from "svelte" import { onDestroy } from "svelte"
export let screenNameModal
export let selectedScreens export let selectedScreens
export let modal
export let screenName export let screenName
export let url export let url
export let chooseModal
let roleId = $selectedAccessRole || "BASIC" let roleId = $selectedAccessRole || "BASIC"
@ -99,7 +98,7 @@
<ModalContent <ModalContent
title="Select navigation" title="Select navigation"
cancelText="Back" cancelText="Back"
onCancel={() => (blankSelected ? screenNameModal.show() : modal.show())} onCancel={() => (blankSelected ? chooseModal(1) : chooseModal(0))}
size="M" size="M"
onConfirm={() => { onConfirm={() => {
save(createdScreens) save(createdScreens)

View File

@ -4,13 +4,13 @@
import { ModalContent, Body, Detail, Layout, Icon } from "@budibase/bbui" import { ModalContent, Body, Detail, Layout, Icon } from "@budibase/bbui"
import getTemplates from "builderStore/store/screenTemplates" import getTemplates from "builderStore/store/screenTemplates"
export let screenNameModal
export let navigationSelectionModal
export let selectedScreens = [] export let selectedScreens = []
export let chooseModal
const blankScreen = "createFromScratch" const blankScreen = "createFromScratch"
$: blankSelected = selectedScreens.length === 1
$: autoSelected = selectedScreens.length > 0 && !blankSelected $: blankSelected = selectedScreens?.length === 1
$: autoSelected = selectedScreens?.length > 0 && !blankSelected
$: templates = getTemplates($store, $tables.list) $: templates = getTemplates($store, $tables.list)
const toggleScreenSelection = table => { const toggleScreenSelection = table => {
@ -19,7 +19,7 @@
screen => !screen.name.includes(table.name) screen => !screen.name.includes(table.name)
) )
} else { } else {
const templates = templates.filter(template => templates = templates.filter(template =>
template.name.includes(table.name) template.name.includes(table.name)
) )
selectedScreens = [...templates, ...selectedScreens] selectedScreens = [...templates, ...selectedScreens]
@ -31,8 +31,7 @@
title="Add screens" title="Add screens"
confirmText="Add Screens" confirmText="Add Screens"
cancelText="Cancel" cancelText="Cancel"
onConfirm={() => onConfirm={() => (autoSelected ? chooseModal(2) : chooseModal(1))}
autoSelected ? navigationSelectionModal.show() : screenNameModal.show()}
disabled={!selectedScreens.length} disabled={!selectedScreens.length}
size="L" size="L"
> >

View File

@ -3,10 +3,9 @@
import sanitizeUrl from "builderStore/store/screenTemplates/utils/sanitizeUrl" import sanitizeUrl from "builderStore/store/screenTemplates/utils/sanitizeUrl"
import { selectedAccessRole, allScreens } from "builderStore" import { selectedAccessRole, allScreens } from "builderStore"
export let modal
export let navigationSelectionModal
export let screenName export let screenName
export let url export let url
export let chooseModal
let routeError let routeError
let roleId = $selectedAccessRole || "BASIC" let roleId = $selectedAccessRole || "BASIC"
@ -37,8 +36,8 @@
size="M" size="M"
title={"Enter details"} title={"Enter details"}
confirmText={"Continue"} confirmText={"Continue"}
onCancel={() => modal.show()} onCancel={() => chooseModal(0)}
onConfirm={() => navigationSelectionModal.show()} onConfirm={() => chooseModal(2)}
cancelText={"Back"} cancelText={"Back"}
disabled={!screenName || !url || routeError} disabled={!screenName || !url || routeError}
> >

View File

@ -1,43 +1,48 @@
<script> <script>
import NavigationSelectionModal from "components/design/NavigationPanel/NavigationSelectionModal.svelte" import NavigationSelectionModal from "components/design/NavigationPanel/NavigationSelectionModal.svelte"
import ScreenNameModal from "components/design/NavigationPanel/ScreenNameModal.svelte" import ScreenDetailsModal from "components/design/NavigationPanel/ScreenDetailsModal.svelte"
import NewScreenModal from "components/design/NavigationPanel/NewScreenModal.svelte" import NewScreenModal from "components/design/NavigationPanel/NewScreenModal.svelte"
import { Modal } from "@budibase/bbui" import { Modal } from "@budibase/bbui"
let modal let newScreenModal
let navigationSelectionModal let navigationSelectionModal
let screenNameModal let screenDetailsModal
let screenName = "" let screenName = ""
let url = "" let url = ""
let selectedScreens = [] let selectedScreens = []
export function showModal() { export const showModal = () => {
modal.show() newScreenModal.show()
}
const chooseModal = index => {
/*
0 = newScreenModal
1 = screenDetailsModal
2 = navigationSelectionModal
*/
if (index === 0) {
newScreenModal.show()
} else if (index === 1) {
screenDetailsModal.show()
} else if (index === 2) {
navigationSelectionModal.show()
}
} }
</script> </script>
<Modal bind:this={modal}> <Modal bind:this={newScreenModal}>
<NewScreenModal <NewScreenModal bind:selectedScreens {chooseModal} />
{screenNameModal}
{navigationSelectionModal}
bind:selectedScreens
/>
</Modal> </Modal>
<Modal bind:this={screenNameModal}> <Modal bind:this={screenDetailsModal}>
<ScreenNameModal <ScreenDetailsModal bind:screenName bind:url {chooseModal} />
bind:screenName
bind:url
{modal}
{navigationSelectionModal}
/>
</Modal> </Modal>
<Modal bind:this={navigationSelectionModal}> <Modal bind:this={navigationSelectionModal}>
<NavigationSelectionModal <NavigationSelectionModal
bind:url bind:url
bind:screenName bind:screenName
{modal}
bind:selectedScreens bind:selectedScreens
{screenNameModal} {chooseModal}
/> />
</Modal> </Modal>