diff --git a/packages/builder/src/builderStore/store/index.js b/packages/builder/src/builderStore/store/index.js
index 36a43b3712..c6ab194379 100644
--- a/packages/builder/src/builderStore/store/index.js
+++ b/packages/builder/src/builderStore/store/index.js
@@ -53,7 +53,6 @@ export const getStore = () => {
store.createDatabaseForApp = backendStoreActions.createDatabaseForApp(store)
store.saveScreen = saveScreen(store)
- store.deleteScreen = deleteScreen(store)
store.setCurrentScreen = setCurrentScreen(store)
store.setCurrentPage = setCurrentPage(store)
store.createScreen = createScreen(store)
@@ -162,6 +161,7 @@ const createScreen = store => (screenName, route, layoutComponentName) => {
props: createProps(rootComponent).props,
}
newScreen.route = route
+ newScreen.name = newScreen.props._id
newScreen.props._instanceName = screenName || ""
state.currentPreviewItem = newScreen
state.currentComponentInfo = newScreen.props
@@ -191,24 +191,6 @@ const setCurrentScreen = store => screenName => {
})
}
-const deleteScreen = store => name => {
- store.update(s => {
- const components = s.components.filter(c => c.name !== name)
- const screens = s.screens.filter(c => c.name !== name)
-
- s.components = components
- s.screens = screens
- if (s.currentPreviewItem.name === name) {
- s.currentPreviewItem = null
- s.currentFrontEndType = ""
- }
-
- api.delete(`/_builder/api/${s.appId}/screen/${name}`)
-
- return s
- })
-}
-
const savePage = store => async page => {
store.update(state => {
if (state.currentFrontEndType !== "page" || !state.currentPageName) {
diff --git a/packages/builder/src/components/userInterface/ComponentsHierarchy.svelte b/packages/builder/src/components/userInterface/ComponentsHierarchy.svelte
index fbe9121623..60311021f8 100644
--- a/packages/builder/src/components/userInterface/ComponentsHierarchy.svelte
+++ b/packages/builder/src/components/userInterface/ComponentsHierarchy.svelte
@@ -6,6 +6,7 @@
import { pipe } from "components/common/core"
import { store } from "builderStore"
import { ArrowDownIcon, ShapeIcon } from "components/common/Icons/"
+ import ScreenDropdownMenu from "./ScreenDropdownMenu.svelte"
export let screens = []
@@ -15,12 +16,15 @@
const joinPath = join("/")
const normalizedName = name =>
- pipe(name, [
- trimCharsStart("./"),
- trimCharsStart("~/"),
- trimCharsStart("../"),
- trimChars(" "),
- ])
+ pipe(
+ name,
+ [
+ trimCharsStart("./"),
+ trimCharsStart("~/"),
+ trimCharsStart("../"),
+ trimChars(" "),
+ ]
+ )
const changeScreen = screen => {
store.setCurrentScreen(screen.props._instanceName)
@@ -31,7 +35,7 @@
{#each screens as screen}
changeScreen(screen)}>
@@ -46,6 +50,10 @@
{screen.props._instanceName}
+
+
{#if $store.currentPreviewItem.props._instanceName && $store.currentPreviewItem.props._instanceName === screen.props._instanceName && screen.props._children}
@@ -63,10 +71,16 @@
color: var(--ink);
}
+ .screen-header-row {
+ display: flex;
+ flex-direction: row;
+ }
+
.title {
margin-left: 14px;
font-size: 14px;
font-weight: 400;
+ flex: 1;
}
.icon {
@@ -89,4 +103,20 @@
.rotate :global(svg) {
transform: rotate(-90deg);
}
+
+ .dropdown-menu {
+ display: none;
+ height: 24px;
+ width: 24px;
+ color: var(--ink);
+ padding: 0px 5px;
+ border-style: none;
+ background: rgba(0, 0, 0, 0);
+ cursor: pointer;
+ position: relative;
+ }
+
+ .budibase__nav-item:hover .dropdown-menu {
+ display: block;
+ }
diff --git a/packages/builder/src/components/userInterface/ComponentsHierarchyChildren.svelte b/packages/builder/src/components/userInterface/ComponentsHierarchyChildren.svelte
index 691d188b07..d827a88f86 100644
--- a/packages/builder/src/components/userInterface/ComponentsHierarchyChildren.svelte
+++ b/packages/builder/src/components/userInterface/ComponentsHierarchyChildren.svelte
@@ -19,7 +19,11 @@
const capitalise = s => s.substring(0, 1).toUpperCase() + s.substring(1)
const get_name = s => (!s ? "" : last(s.split("/")))
- const get_capitalised_name = name => pipe(name, [get_name, capitalise])
+ const get_capitalised_name = name =>
+ pipe(
+ name,
+ [get_name, capitalise]
+ )
const isScreenslot = name => name === "##builtin/screenslot"
const selectComponent = component => {
diff --git a/packages/builder/src/components/userInterface/ScreenDropdownMenu.svelte b/packages/builder/src/components/userInterface/ScreenDropdownMenu.svelte
new file mode 100644
index 0000000000..9db14cefc5
--- /dev/null
+++ b/packages/builder/src/components/userInterface/ScreenDropdownMenu.svelte
@@ -0,0 +1,115 @@
+
+
+
{}}>
+
+
+
+
+
+
+
diff --git a/packages/server/src/api/routes/pages.js b/packages/server/src/api/routes/pages.js
index 98f0f08b92..afdacff86b 100644
--- a/packages/server/src/api/routes/pages.js
+++ b/packages/server/src/api/routes/pages.js
@@ -69,19 +69,14 @@ router.patch(
)
router.delete(
- "/_builder/api/:appname/pages/:pagename/screen/*",
+ "/_builder/api/pages/:pagename/screens/:id",
authorized(BUILDER),
async ctx => {
- const name = ctx.request.path.replace(
- `/_builder/api/${ctx.params.appname}/pages/${ctx.params.pagename}/screen/`,
- ""
- )
-
await deleteScreen(
ctx.config,
- ctx.params.appname,
+ ctx.user.appId,
ctx.params.pagename,
- decodeURI(name)
+ ctx.params.id
)
ctx.response.status = StatusCodes.OK
diff --git a/packages/server/src/utilities/builder/index.js b/packages/server/src/utilities/builder/index.js
index f63e34a8cd..0a68d9725b 100644
--- a/packages/server/src/utilities/builder/index.js
+++ b/packages/server/src/utilities/builder/index.js
@@ -75,8 +75,8 @@ module.exports.renameScreen = async (
await rename(oldComponentPath, newComponentPath)
}
-module.exports.deleteScreen = async (config, appname, pagename, name) => {
- const appPath = appPackageFolder(config, appname)
+module.exports.deleteScreen = async (config, appId, pagename, name) => {
+ const appPath = appPackageFolder(config, appId)
const componentFile = screenPath(appPath, pagename, name)
await unlink(componentFile)