Skip to content

Commit

Permalink
enh(api): generate pagesUrl from parts
Browse files Browse the repository at this point in the history
Accept multiple arguments to `pagesUrl`
and join them with `/` to build the url:

Example:
```js
api.pagesUrl({collectiveId: 10}, 'trash', 12)
```
results in `/apps/collectives/_api/10/_pages/trash/12`

Signed-off-by: Max <[email protected]>
  • Loading branch information
max-nextcloud committed Nov 28, 2023
1 parent c7cc37a commit 18d10d4
Show file tree
Hide file tree
Showing 3 changed files with 117 additions and 54 deletions.
5 changes: 5 additions & 0 deletions cypress/support/commands.js
Original file line number Diff line number Diff line change
Expand Up @@ -264,6 +264,11 @@ Cypress.Commands.add('seedCollectivePageMode', (name, mode) => {
.then((found) => api.updateCollectivePageMode(found.id, mode))
})

/**
* Context for the given collective for a logged in user.
*
* @param {object} collective - Collective to provide the context for.
*/
function collectiveContext(collective) {
return {
isPublic: false,
Expand Down
126 changes: 97 additions & 29 deletions src/api.js
Original file line number Diff line number Diff line change
@@ -1,63 +1,131 @@
import axios from '@nextcloud/axios'
import { generateUrl } from '@nextcloud/router'

// not used yet.
function url(suffix = '') {
return generateUrl('/apps/collectives/_api' + suffix)
/**
* Url for the collectives api
*
* @param {...any} parts - url parts to append - will be joined with `/`
*/
function collectivesUrl(...parts) {
const path = ['apps/collectives/_api', ...parts]
.join('/')
return generateUrl(path)
}

export function getCollectives(shareTokenParam = false) {
return shareTokenParam
? axios.get(url(`/p/${shareTokenParam}`))
: axios.get(url())
/**
* Get all active (i.e. not trashed) collectives for the current user
*
* Will return the shared collective if a share token is given.
*
* @param {string} shareToken authentication token from the share
*/
export function getCollectives(shareToken = false) {
return shareToken
? axios.get(collectivesUrl('p', shareToken))
: axios.get(collectivesUrl())
}

/**
* Get all trashed collectives for the current user
*/
export function getTrashCollectives() {
return axios.get(url('/trash'))
return axios.get(collectivesUrl('trash'))
}

/**
* Create a new collective with the given properties.
*
* @param {object} collective - properties for the new collective
*/
export function newCollective(collective) {
return axios.post(
url(),
collectivesUrl(),
collective,
)
}

export function trashCollective(id) {
return axios.delete(url(`/${id}`))
/**
* Trash the collective with the given id
*
* @param {number} collectiveId - Id of the collective to trash.
*/
export function trashCollective(collectiveId) {
return axios.delete(collectivesUrl(collectiveId))
}

export function deleteCollective(id, circle) {
let doCircle = ''
if (circle) {
doCircle = '?circle=1'
}
return axios.delete(url('/trash/' + id + doCircle))
/**
* Delete the collective with the given id.
*
* @param {number} collectiveId - id of the collective to delete
* @param {boolean} removeCircle - also remove the circle if true
*/
export function deleteCollective(collectiveId, removeCircle) {
const query = removeCircle ? '?circle=1' : ''
return axios.delete(collectivesUrl('trash', collectiveId + query))
}

export function updateCollectiveEditPermissions(id, level) {
return axios.put(url(`/${id}/editLevel`), { level })
/**
* Set the permission level required for editing.
*
* @param {number} collectiveId - id of the collective to update
* @param {number} level - required level for editing
*/
export function updateCollectiveEditPermissions(collectiveId, level) {
return axios.put(collectivesUrl(collectiveId, 'editLevel'), { level })
}

export function updateCollectiveSharePermissions(id, level) {
return axios.put(url(`/${id}/shareLevel`), { level })
/**
* Set the permission level required for sharing.
*
* @param {number} collectiveId - id of the collective to update
* @param {number} level - required level for sharing
*/
export function updateCollectiveSharePermissions(collectiveId, level) {
return axios.put(collectivesUrl(collectiveId, 'shareLevel'), { level })
}

export function updateCollectivePageMode(id, mode) {
return axios.put(url(`/${id}/pageMode`), { mode })
/**
* Set the edit mode for the given collective
*
* @param {number} collectiveId - id of the collective to update
* @param {number} mode - pageMode to use.
*
* Possible modes: pageModes.MODE_VIEW or pageModes.MODE_EDIT
*/
export function updateCollectivePageMode(collectiveId, mode) {
return axios.put(collectivesUrl(collectiveId, 'pageMode'), { mode })
}

/**
* Get all pages in the given context (collective or public share)
*
* @param {object} context - either the current collective or a share context
*/
export function getPages(context) {
return axios.get(pagesUrl(context))
}

/**
* Create a new page in the given context (collective or public share)
*
* @param {object} context - either the current collective or a share context
* @param {object} page - properties of the new page
*/
export function createPage(context, page) {
const url = pagesUrl(context) + '/' + page.parentId
return axios.post(url, page)
return axios.post(
pagesUrl(context, page.parentId),
page,
)
}

export function pagesUrl({ isPublic = false, shareTokenParam, collectiveId }) {
return isPublic
? url(`/p/${shareTokenParam}/_pages`)
: url(`/${collectiveId}/_pages`)
/**
* Url for pages paths inside the given context.
*
* @param {object} context - either the current collective or a share context
* @param {...any} parts - url parts to append.
*/
export function pagesUrl(context, ...parts) {
return context.isPublic
? collectivesUrl('p', context.shareTokenParam, '_pages', ...parts)
: collectivesUrl(context.collectiveId, '_pages', ...parts)
}
40 changes: 15 additions & 25 deletions src/store/pages.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { set } from 'vue'
import { getCurrentUser } from '@nextcloud/auth'
import { getBuilder } from '@nextcloud/browser-storage'
import axios from '@nextcloud/axios'
import { generateRemoteUrl, generateUrl } from '@nextcloud/router'
import { generateRemoteUrl } from '@nextcloud/router'
/* eslint import/namespace: ['error', { allowComputed: true }] */
import * as sortOrders from '../util/sortOrders.js'
import { sortedSubpages, pageParents } from './pageExtracts.js'
Expand Down Expand Up @@ -251,42 +251,32 @@ export default {
}
},

pagesUrl(_state, getters) {
return getters.isPublic
? generateUrl(`/apps/collectives/_api/p/${getters.shareTokenParam}/_pages`)
: generateUrl(`/apps/collectives/_api/${getters.currentCollective.id}/_pages`)
},

pageUrl(_state, getters) {
return (pageId) => `${getters.pagesUrl}/${pageId}`
},

emojiUrl(_state, getters) {
return (pageId) => `${getters.pageUrl(pageId)}/emoji`
return (pageId) => api.pagesUrl(getters.context, pageId, 'emoji')
},

subpageOrderUrl(_state, getters) {
return (pageId) => `${getters.pageUrl(pageId)}/subpageOrder`
return (pageId) => api.pagesUrl(getters.context, pageId, 'subpageOrder')
},

touchUrl(_state, getters) {
return `${getters.pageUrl(getters.currentPage.id)}/touch`
return api.pagesUrl(getters.context, getters.currentPage.id, 'touch')
},

attachmentsUrl(_state, getters) {
return (pageId) => `${getters.pageUrl(pageId)}/attachments`
return (pageId) => api.pagesUrl(getters.context, pageId, 'attachments')
},

backlinksUrl(_state, getters) {
return (pageId) => `${getters.pageUrl(pageId)}/backlinks`
return (pageId) => api.pagesUrl(getters.context, pageId, 'backlinks')
},

trashIndexUrl(_state, getters) {
return `${getters.pagesUrl}/trash`
return api.pagesUrl(getters.context, 'trash')
},

trashActionUrl(_state, getters) {
return (pageId) => `${getters.pagesUrl}/trash/${pageId}`
return (pageId) => api.pagesUrl(getters.context, 'trash', pageId)
},

pageTitle(state, getters) {
Expand Down Expand Up @@ -544,7 +534,7 @@ export default {
* @param {number} pageId Page ID
*/
async [GET_PAGE]({ commit, getters, state }, pageId) {
const response = await axios.get(getters.pageUrl(pageId))
const response = await axios.get(api.pagesUrl(getters.context, pageId))
commit(UPDATE_PAGE, response.data.data)
},

Expand Down Expand Up @@ -610,7 +600,7 @@ export default {
* @param {string} newTitle new title for the page
*/
async [RENAME_PAGE]({ commit, getters }, newTitle) {
const url = getters.pageUrl(getters.currentPage.id)
const url = api.pagesUrl(getters.context, getters.currentPage.id)
const response = await axios.put(url, { title: newTitle })
await commit(UPDATE_PAGE, response.data.data)
},
Expand Down Expand Up @@ -640,7 +630,7 @@ export default {
index += 1
}

const url = getters.pageUrl(pageId)
const url = api.pagesUrl(getters.context, pageId)
try {
await axios.put(url, { index, parentId: newParentId, copy: true })
// Reload the page list to make new page appear
Expand Down Expand Up @@ -679,7 +669,7 @@ export default {
page.parentId = newParentId
commit(UPDATE_PAGE, page)

const url = getters.pageUrl(pageId)
const url = api.pagesUrl(getters.context, pageId)
try {
const response = await axios.put(url, { index, parentId: newParentId })
commit(UPDATE_PAGE, response.data.data)
Expand Down Expand Up @@ -714,7 +704,7 @@ export default {
async [COPY_PAGE_TO_COLLECTIVE]({ commit, getters, state, dispatch }, { collectiveId, newParentId, pageId, index }) {
commit('load', 'pagelist')

const url = `${getters.pageUrl(pageId)}/to/${collectiveId}`
const url = api.pagesUrl(getters.context, pageId, 'to', collectiveId)
await axios.put(url, { index, parentId: newParentId, copy: true })
commit('done', 'pagelist')
},
Expand All @@ -738,7 +728,7 @@ export default {
const page = { ...state.pages.find(p => p.id === pageId) }
const hasSubpages = getters.visibleSubpages(pageId).length > 0

const url = `${getters.pageUrl(pageId)}/to/${collectiveId}`
const url = api.pagesUrl(getters.context, pageId, 'to', collectiveId)
await axios.put(url, { index, parentId: newParentId })
commit(REMOVE_PAGE, page)
commit('done', 'pagelist')
Expand Down Expand Up @@ -814,7 +804,7 @@ export default {
* @param {number} page.pageId ID of the page
*/
async [TRASH_PAGE]({ commit, getters }, { pageId }) {
const response = await axios.delete(getters.pageUrl(pageId))
const response = await axios.delete(api.pagesUrl(getters.context, pageId))
commit(MOVE_PAGE_INTO_TRASH, response.data.data)
},

Expand Down

0 comments on commit 18d10d4

Please sign in to comment.