Quick update to allow deleting layouts if they are not currently in use.

This commit is contained in:
mike12345567 2020-11-30 16:12:06 +00:00
parent 9b5734b1de
commit fdd719aadb
5 changed files with 40 additions and 7 deletions

View File

@ -1,5 +1,5 @@
const CouchDB = require("../../db/client") const CouchDB = require("../../db")
const { generateLayoutID } = require("../../db/utils") const { generateLayoutID, getScreenParams } = require("../../db/utils")
exports.save = async function(ctx) { exports.save = async function(ctx) {
const db = new CouchDB(ctx.user.appId) const db = new CouchDB(ctx.user.appId)
@ -9,3 +9,24 @@ exports.save = async function(ctx) {
ctx.body = await db.put(layout) ctx.body = await db.put(layout)
ctx.status = 200 ctx.status = 200
} }
exports.destroy = async function(ctx) {
const db = new CouchDB(ctx.user.appId)
const layoutId = ctx.params.layoutId,
layoutRev = ctx.params.layoutRev
const layoutsUsedByScreens = (
await db.allDocs(
getScreenParams(null, {
include_docs: true,
})
)
).rows.map(element => element.doc.props.layoutId)
if (layoutsUsedByScreens.indexOf(layoutId) !== -1) {
ctx.throw(400, "Cannot delete a base layout")
}
await db.remove(layoutId, layoutRev)
ctx.message = "Layout deleted successfully"
ctx.status = 200
}

View File

@ -36,7 +36,7 @@ exports.save = async ctx => {
exports.destroy = async ctx => { exports.destroy = async ctx => {
const db = new CouchDB(ctx.user.appId) const db = new CouchDB(ctx.user.appId)
await db.remove(ctx.params.screenId, ctx.params.revId) await db.remove(ctx.params.screenId, ctx.params.screenRev)
ctx.message = "Screen deleted successfully" ctx.message = "Screen deleted successfully"
ctx.status = 200 ctx.status = 200
} }

View File

@ -5,6 +5,12 @@ const controller = require("../controllers/layout")
const router = Router() const router = Router()
router.post("/api/layouts", authorized(BUILDER), controller.save) router
.post("/api/layouts", authorized(BUILDER), controller.save)
.delete(
"/api/layouts/:layoutId/:layoutRev",
authorized(BUILDER),
controller.destroy
)
module.exports = router module.exports = router

View File

@ -38,7 +38,7 @@ router
controller.save controller.save
) )
.delete( .delete(
"/api/screens/:screenId/:revId", "/api/screens/:screenId/:screenRev",
authorized(BUILDER), authorized(BUILDER),
controller.destroy controller.destroy
) )

View File

@ -1,3 +1,8 @@
const BASE_LAYOUT_PROP_IDS = {
PRIVATE: "private-master-layout",
PUBLIC: "public-master-layout",
}
const BASE_LAYOUTS = [ const BASE_LAYOUTS = [
{ {
componentLibraries: ["@budibase/standard-components"], componentLibraries: ["@budibase/standard-components"],
@ -6,7 +11,7 @@ const BASE_LAYOUTS = [
stylesheets: [], stylesheets: [],
name: "Main", name: "Main",
props: { props: {
_id: "private-master-layout", _id: BASE_LAYOUT_PROP_IDS.PRIVATE,
_component: "@budibase/standard-components/container", _component: "@budibase/standard-components/container",
_children: [ _children: [
{ {
@ -151,7 +156,7 @@ const BASE_LAYOUTS = [
stylesheets: [], stylesheets: [],
name: "Unauthenticated", name: "Unauthenticated",
props: { props: {
_id: "public-master-layout", _id: BASE_LAYOUT_PROP_IDS.PUBLIC,
_component: "@budibase/standard-components/container", _component: "@budibase/standard-components/container",
_children: [ _children: [
{ {
@ -217,4 +222,5 @@ const BASE_LAYOUTS = [
module.exports = { module.exports = {
BASE_LAYOUTS, BASE_LAYOUTS,
BASE_LAYOUT_PROP_IDS,
} }