Skip to content

Commit

Permalink
fix: update display mode when editing context
Browse files Browse the repository at this point in the history
Signed-off-by: Cleopatra Enjeck M. <[email protected]>
  • Loading branch information
enjeck committed Dec 16, 2024
1 parent 4f9536b commit ab66fcc
Show file tree
Hide file tree
Showing 4 changed files with 19 additions and 7 deletions.
2 changes: 1 addition & 1 deletion src/modules/modals/CreateContext.vue
Original file line number Diff line number Diff line change
Expand Up @@ -171,7 +171,7 @@ export default {
isUser: true,
key: 'user-' + getCurrentUser().uid,
})
const displayMode = this.showInNavigation ? 'NAV_ENTRY_MODE_ALL' : 'NAV_ENTRY_MODE_HIDDEN'
const displayMode = this.showInNavigation ? 'NAV_ENTRY_MODE_RECIPIENTS' : 'NAV_ENTRY_MODE_HIDDEN'
const res = await this.$store.dispatch('insertNewContext', { data, previousReceivers: [], receivers: this.receivers, displayMode: NAV_ENTRY_MODE[displayMode] })
if (res) {
return res.id
Expand Down
4 changes: 2 additions & 2 deletions src/modules/modals/EditContext.vue
Original file line number Diff line number Diff line change
Expand Up @@ -185,7 +185,7 @@ export default {
isUser: true,
key: 'user-' + getCurrentUser().uid,
})
const displayMode = this.showInNavigation ? 'NAV_ENTRY_MODE_ALL' : 'NAV_ENTRY_MODE_HIDDEN'
const displayMode = this.showInNavigationDefault ? 'NAV_ENTRY_MODE_RECIPIENTS' : 'NAV_ENTRY_MODE_HIDDEN'
const res = await this.$store.dispatch('updateContext', { id: this.contextId, data, previousReceivers: Object.values(context.sharing), receivers: this.receivers, displayMode: NAV_ENTRY_MODE[displayMode] })
if (res) {
showSuccess(t('tables', 'Updated application "{contextTitle}".', { contextTitle: this.title }))
Expand Down Expand Up @@ -269,7 +269,7 @@ export default {

},
updateDisplayMode() {
this.showInNavigation = !this.showInNavigation
this.showInNavigationDefault = !this.showInNavigationDefault
},
actionTransfer() {
emit('tables:context:edit', null)
Expand Down
4 changes: 2 additions & 2 deletions src/modules/navigation/partials/NavigationContextItem.vue
Original file line number Diff line number Diff line change
Expand Up @@ -117,9 +117,9 @@ export default {
},
updateDisplayMode() {
const value = !this.showInNavigation
let displayMode = value ? NAV_ENTRY_MODE.NAV_ENTRY_MODE_RECIPIENTS : NAV_ENTRY_MODE.NAV_ENTRY_MODE_HIDDEN
let displayMode = value ? NAV_ENTRY_MODE.NAV_ENTRY_MODE_ALL : NAV_ENTRY_MODE.NAV_ENTRY_MODE_HIDDEN
if (this.ownsContext(this.context)) {
displayMode = value ? NAV_ENTRY_MODE.NAV_ENTRY_MODE_ALL : NAV_ENTRY_MODE.NAV_ENTRY_MODE_HIDDEN
displayMode = value ? NAV_ENTRY_MODE.NAV_ENTRY_MODE_RECIPIENTS : NAV_ENTRY_MODE.NAV_ENTRY_MODE_HIDDEN
}
const share = Object.values(this.context.sharing || {}).find(share => share.receiver === getCurrentUser().uid)
if (share) {
Expand Down
16 changes: 14 additions & 2 deletions src/store/store.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,8 @@ import { showError } from '@nextcloud/dialogs'
import '@nextcloud/dialogs/style.css'
import data from './data.js'
import displayError from '../shared/utils/displayError.js'
import { NODE_TYPE_TABLE, NODE_TYPE_VIEW } from '../shared/constants.js'
import { NODE_TYPE_TABLE, NODE_TYPE_VIEW, NAV_ENTRY_MODE } from '../shared/constants.js'
import { getCurrentUser } from '@nextcloud/auth'

Vue.use(Vuex)

Expand Down Expand Up @@ -359,7 +360,15 @@ export default new Vuex.Store({
// Avoid duplicate shares by checking if share exists first
const existingShare = previousReceivers.find((p) => p.receiver === share.receiver && p.receiver_type === share.receiverType)
if (!existingShare) {
await axios.post(generateUrl('/apps/tables/share'), share)
const createdShare = await axios.post(generateUrl('/apps/tables/share'), share)
if (createdShare?.data && createdShare?.data?.id) {
const shareId = createdShare.data.id
await dispatch('updateDisplayMode', { shareId, displayMode, target: 'default' })
// since we switch between NAV_ENTRY_MODE_HIDDEN and NAV_ENTRY_MODE_RECIPIENTS, we need to handle owner separately
if (receiver.id === getCurrentUser().uid) {
await dispatch('updateDisplayMode', { shareId, displayMode: displayMode === NAV_ENTRY_MODE.NAV_ENTRY_MODE_HIDDEN ? NAV_ENTRY_MODE.NAV_ENTRY_MODE_HIDDEN : NAV_ENTRY_MODE.NAV_ENTRY_MODE_ALL, target: 'self' })
}
}
}
}
} catch (e) {
Expand All @@ -374,6 +383,9 @@ export default new Vuex.Store({
})
if (!currentShare) {
await axios.delete(generateUrl('/apps/tables/share/' + previousReceiver.share_id))
} else {
const shareId = previousReceiver.share_id
await dispatch('updateDisplayMode', { shareId, displayMode, target: 'default' })
}
}
} catch (e) {
Expand Down

0 comments on commit ab66fcc

Please sign in to comment.