Merge remote-tracking branch 'origin/master' into stable22
This commit is contained in:
@@ -36,8 +36,8 @@ class Circle extends RelationalObject {
|
|||||||
public function getObjectSerialization() {
|
public function getObjectSerialization() {
|
||||||
return [
|
return [
|
||||||
'uid' => $this->object->getUniqueId(),
|
'uid' => $this->object->getUniqueId(),
|
||||||
'displayname' => $this->object->getName(),
|
'displayname' => $this->object->getDisplayName(),
|
||||||
'typeString' => $this->object->getTypeString(),
|
'typeString' => '',
|
||||||
'circleOwner' => $this->object->getOwner(),
|
'circleOwner' => $this->object->getOwner(),
|
||||||
'type' => 7
|
'type' => 7
|
||||||
];
|
];
|
||||||
|
|||||||
@@ -268,7 +268,11 @@ class PermissionService {
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach ($circle->getMembers() as $member) {
|
foreach ($circle->getInheritedMembers() as $member) {
|
||||||
|
if ($member->getUserType() !== 1) {
|
||||||
|
// deck currently only supports user members in circles
|
||||||
|
continue;
|
||||||
|
}
|
||||||
$user = $this->userManager->get($member->getUserId());
|
$user = $this->userManager->get($member->getUserId());
|
||||||
if ($user === null) {
|
if ($user === null) {
|
||||||
$this->logger->info('No user found for circle member ' . $member->getUserId());
|
$this->logger->info('No user found for circle member ' . $member->getUserId());
|
||||||
|
|||||||
@@ -168,6 +168,7 @@ export default {
|
|||||||
|
|
||||||
},
|
},
|
||||||
close() {
|
close() {
|
||||||
|
this.$emit('close')
|
||||||
this.$root.$emit('close')
|
this.$root.$emit('close')
|
||||||
},
|
},
|
||||||
async select() {
|
async select() {
|
||||||
|
|||||||
@@ -25,6 +25,12 @@
|
|||||||
<div v-if="overviewName" class="board-title">
|
<div v-if="overviewName" class="board-title">
|
||||||
<div class="board-bullet icon-calendar-dark" />
|
<div class="board-bullet icon-calendar-dark" />
|
||||||
<h2>{{ overviewName }}</h2>
|
<h2>{{ overviewName }}</h2>
|
||||||
|
<Actions>
|
||||||
|
<ActionButton icon="icon-add" @click="clickShowAddCardModel">
|
||||||
|
{{ t('deck', 'Add card') }}
|
||||||
|
</ActionButton>
|
||||||
|
</Actions>
|
||||||
|
<CardCreateDialog v-if="showAddCardModal" @close="clickHideAddCardModel" />
|
||||||
</div>
|
</div>
|
||||||
<div v-else-if="board" class="board-title">
|
<div v-else-if="board" class="board-title">
|
||||||
<div :style="{backgroundColor: '#' + board.color}" class="board-bullet" />
|
<div :style="{backgroundColor: '#' + board.color}" class="board-bullet" />
|
||||||
@@ -206,11 +212,12 @@
|
|||||||
import { mapState, mapGetters } from 'vuex'
|
import { mapState, mapGetters } from 'vuex'
|
||||||
import { Actions, ActionButton, Popover, Avatar } from '@nextcloud/vue'
|
import { Actions, ActionButton, Popover, Avatar } from '@nextcloud/vue'
|
||||||
import labelStyle from '../mixins/labelStyle'
|
import labelStyle from '../mixins/labelStyle'
|
||||||
|
import CardCreateDialog from '../CardCreateDialog'
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'Controls',
|
name: 'Controls',
|
||||||
components: {
|
components: {
|
||||||
Actions, ActionButton, Popover, Avatar,
|
Actions, ActionButton, Popover, Avatar, CardCreateDialog,
|
||||||
},
|
},
|
||||||
mixins: [labelStyle],
|
mixins: [labelStyle],
|
||||||
props: {
|
props: {
|
||||||
@@ -233,6 +240,7 @@ export default {
|
|||||||
showArchived: false,
|
showArchived: false,
|
||||||
isAddStackVisible: false,
|
isAddStackVisible: false,
|
||||||
filter: { tags: [], users: [], due: '', unassigned: false },
|
filter: { tags: [], users: [], due: '', unassigned: false },
|
||||||
|
showAddCardModal: false,
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
@@ -318,6 +326,12 @@ export default {
|
|||||||
this.$store.dispatch('setFilter', { ...filterReset })
|
this.$store.dispatch('setFilter', { ...filterReset })
|
||||||
this.filter = filterReset
|
this.filter = filterReset
|
||||||
},
|
},
|
||||||
|
clickShowAddCardModel() {
|
||||||
|
this.showAddCardModal = true
|
||||||
|
},
|
||||||
|
clickHideAddCardModel() {
|
||||||
|
this.showAddCardModal = false
|
||||||
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|||||||
@@ -32,7 +32,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<EmptyContent v-else-if="isEmpty" key="empty" icon="icon-deck">
|
<EmptyContent v-else-if="isEmpty" key="empty" icon="icon-deck">
|
||||||
{{ t('deck', 'No lists available') }}
|
{{ t('deck', 'No lists available') }}
|
||||||
<template #desc>
|
<template v-if="canManage" #desc>
|
||||||
{{ t('deck', 'Create a new list to add cards to this board') }}
|
{{ t('deck', 'Create a new list to add cards to this board') }}
|
||||||
<form @submit.prevent="addNewStack()">
|
<form @submit.prevent="addNewStack()">
|
||||||
<input id="new-stack-input-main"
|
<input id="new-stack-input-main"
|
||||||
@@ -110,6 +110,7 @@ export default {
|
|||||||
}),
|
}),
|
||||||
...mapGetters([
|
...mapGetters([
|
||||||
'canEdit',
|
'canEdit',
|
||||||
|
'canManage',
|
||||||
]),
|
]),
|
||||||
stacksByBoard() {
|
stacksByBoard() {
|
||||||
return this.$store.getters.stacksByBoard(this.board.id)
|
return this.$store.getters.stacksByBoard(this.board.id)
|
||||||
|
|||||||
@@ -21,32 +21,39 @@
|
|||||||
-->
|
-->
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<DashboardWidget :items="cards"
|
<div>
|
||||||
empty-content-icon="icon-deck"
|
<DashboardWidget :items="cards"
|
||||||
:empty-content-message="t('deck', 'No upcoming cards')"
|
empty-content-icon="icon-deck"
|
||||||
:show-more-text="t('deck', 'upcoming cards')"
|
:empty-content-message="t('deck', 'No upcoming cards')"
|
||||||
:show-more-url="showMoreUrl"
|
:show-more-text="t('deck', 'upcoming cards')"
|
||||||
:loading="loading"
|
:loading="loading"
|
||||||
@hide="() => {}"
|
@hide="() => {}"
|
||||||
@markDone="() => {}">
|
@markDone="() => {}">
|
||||||
<template #default="{ item }">
|
<template #default="{ item }">
|
||||||
<a :key="item.id"
|
<a :key="item.id"
|
||||||
:href="cardLink(item)"
|
:href="cardLink(item)"
|
||||||
target="_blank"
|
target="_blank"
|
||||||
class="card">
|
class="card">
|
||||||
<div class="card--header">
|
<div class="card--header">
|
||||||
<DueDate class="right" :card="item" />
|
<DueDate class="right" :card="item" />
|
||||||
<span class="title">{{ item.title }}</span>
|
<span class="title">{{ item.title }}</span>
|
||||||
</div>
|
</div>
|
||||||
<ul v-if="item.labels && item.labels.length"
|
<ul v-if="item.labels && item.labels.length"
|
||||||
class="labels">
|
class="labels">
|
||||||
<li v-for="label in item.labels" :key="label.id" :style="labelStyle(label)">
|
<li v-for="label in item.labels" :key="label.id" :style="labelStyle(label)">
|
||||||
<span>{{ label.title }}</span>
|
<span>{{ label.title }}</span>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
</a>
|
</a>
|
||||||
</template>
|
</template>
|
||||||
</DashboardWidget>
|
</DashboardWidget>
|
||||||
|
<div class="center-button">
|
||||||
|
<button @click="toggleAddCardModel">
|
||||||
|
{{ t('deck', 'Add card') }}
|
||||||
|
</button>
|
||||||
|
<CardCreateDialog v-if="showAddCardModal" @close="toggleAddCardModel" />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
@@ -55,17 +62,20 @@ import { mapGetters } from 'vuex'
|
|||||||
import labelStyle from './../mixins/labelStyle'
|
import labelStyle from './../mixins/labelStyle'
|
||||||
import DueDate from '../components/cards/badges/DueDate'
|
import DueDate from '../components/cards/badges/DueDate'
|
||||||
import { generateUrl } from '@nextcloud/router'
|
import { generateUrl } from '@nextcloud/router'
|
||||||
|
import CardCreateDialog from '../CardCreateDialog'
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'Dashboard',
|
name: 'Dashboard',
|
||||||
components: {
|
components: {
|
||||||
DueDate,
|
DueDate,
|
||||||
DashboardWidget,
|
DashboardWidget,
|
||||||
|
CardCreateDialog,
|
||||||
},
|
},
|
||||||
mixins: [labelStyle],
|
mixins: [labelStyle],
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
loading: false,
|
loading: false,
|
||||||
|
showAddCardModal: false,
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
@@ -81,7 +91,7 @@ export default {
|
|||||||
list.sort((a, b) => {
|
list.sort((a, b) => {
|
||||||
return (new Date(a.duedate)).getTime() - (new Date(b.duedate)).getTime()
|
return (new Date(a.duedate)).getTime() - (new Date(b.duedate)).getTime()
|
||||||
})
|
})
|
||||||
return list
|
return list.slice(0, 6)
|
||||||
},
|
},
|
||||||
cardLink() {
|
cardLink() {
|
||||||
return (card) => {
|
return (card) => {
|
||||||
@@ -98,12 +108,21 @@ export default {
|
|||||||
this.loading = false
|
this.loading = false
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
methods: {
|
||||||
|
toggleAddCardModel() {
|
||||||
|
this.showAddCardModal = !this.showAddCardModal
|
||||||
|
},
|
||||||
|
},
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
@import './../css/labels';
|
@import './../css/labels';
|
||||||
|
|
||||||
|
.center-button {
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
#deck-widget-empty-content {
|
#deck-widget-empty-content {
|
||||||
text-align: center;
|
text-align: center;
|
||||||
margin-top: 5vh;
|
margin-top: 5vh;
|
||||||
|
|||||||
Reference in New Issue
Block a user