2018-10-19 05:15:28 +00:00
|
|
|
<template lang="html">
|
2020-10-14 00:37:42 +00:00
|
|
|
<nav
|
2021-02-04 15:51:31 +00:00
|
|
|
class=" rounded position-fixed d-flex flex-column p-0 m-2 text-center border"
|
|
|
|
:class="{
|
|
|
|
'bg-dark text-white border-dark': nightMode,
|
|
|
|
'bg-white': !nightMode,
|
|
|
|
}"
|
2020-10-14 00:37:42 +00:00
|
|
|
>
|
2021-02-01 23:20:41 +00:00
|
|
|
<b-button
|
2021-01-20 22:44:04 +00:00
|
|
|
title="Dashboard"
|
2021-02-01 23:20:41 +00:00
|
|
|
variant="transparent"
|
|
|
|
class="my-2 p-0"
|
|
|
|
@click="handleLogoClick"
|
2020-11-23 23:36:03 +00:00
|
|
|
>
|
2020-10-14 00:37:42 +00:00
|
|
|
<img
|
|
|
|
:src="`/static/gamebrary-logo${nightMode ? '' : '-dark'}.png`"
|
|
|
|
width="32"
|
|
|
|
/>
|
2021-02-01 23:20:41 +00:00
|
|
|
</b-button>
|
2020-09-26 00:09:20 +00:00
|
|
|
|
2021-02-03 05:33:45 +00:00
|
|
|
<pinned-boards v-if="user" />
|
2021-02-01 19:38:17 +00:00
|
|
|
|
|
|
|
<b-dropdown
|
2021-02-03 04:58:45 +00:00
|
|
|
v-if="user"
|
2021-02-01 19:38:17 +00:00
|
|
|
dropright
|
|
|
|
right
|
|
|
|
no-caret
|
|
|
|
boundary="viewport"
|
|
|
|
:variant="nightMode ? 'dark' : 'transparent'"
|
|
|
|
:menu-class="nightMode ? 'bg-dark' : ''"
|
|
|
|
>
|
|
|
|
<template v-slot:button-content>
|
|
|
|
<i class="fas fa-ellipsis-h fa-fw" aria-hidden />
|
|
|
|
</template>
|
|
|
|
|
2021-02-01 23:46:28 +00:00
|
|
|
<template v-if="$route.name === 'board'">
|
|
|
|
<b-dropdown-header id="dropdown-header-label">
|
|
|
|
{{ board.name }}
|
|
|
|
</b-dropdown-header>
|
2021-02-01 23:20:41 +00:00
|
|
|
|
2021-02-03 21:04:02 +00:00
|
|
|
<b-dropdown-item
|
2021-02-03 23:39:16 +00:00
|
|
|
v-b-modal:edit-board
|
2021-02-03 21:04:02 +00:00
|
|
|
:variant="nightMode ? 'secondary' : null"
|
|
|
|
>
|
2021-02-03 04:58:18 +00:00
|
|
|
<i class="fas fa-edit fa-fw" aria-hidden />
|
|
|
|
Edit board
|
|
|
|
</b-dropdown-item>
|
|
|
|
|
2021-02-03 21:04:02 +00:00
|
|
|
<b-dropdown-item
|
|
|
|
v-b-modal:add-list
|
|
|
|
:variant="nightMode ? 'secondary' : null"
|
|
|
|
>
|
2021-02-03 04:58:18 +00:00
|
|
|
<i class="fas fa-folder-plus fa-fw" />
|
|
|
|
Add list
|
|
|
|
</b-dropdown-item>
|
2021-02-01 23:20:41 +00:00
|
|
|
|
2021-02-03 21:04:02 +00:00
|
|
|
<b-dropdown-item
|
|
|
|
@click="pinBoard"
|
|
|
|
:variant="nightMode ? 'secondary' : null"
|
|
|
|
>
|
2021-02-03 04:58:18 +00:00
|
|
|
<i class="fas fa-thumbtack fa-fw" />
|
2021-02-01 23:46:28 +00:00
|
|
|
{{ board.pinned ? 'Unpin from dock' : 'Pin to dock' }}
|
|
|
|
</b-dropdown-item>
|
2021-02-01 23:20:41 +00:00
|
|
|
|
2021-02-01 23:46:28 +00:00
|
|
|
<b-dd-divider />
|
|
|
|
</template>
|
2021-02-01 23:20:41 +00:00
|
|
|
|
2021-02-03 21:04:02 +00:00
|
|
|
<b-dropdown-item
|
|
|
|
v-b-modal:create-board
|
|
|
|
:variant="nightMode ? 'secondary' : null"
|
|
|
|
>
|
2021-02-01 23:46:28 +00:00
|
|
|
<i class="fas fa-plus fa-fw" aria-hidden />
|
2021-02-01 23:20:41 +00:00
|
|
|
Create board
|
|
|
|
</b-dropdown-item>
|
|
|
|
|
|
|
|
<b-dd-divider />
|
|
|
|
|
2021-02-03 21:04:02 +00:00
|
|
|
<b-dropdown-item
|
|
|
|
:to="{ name: 'boards' }"
|
|
|
|
:variant="nightMode ? 'secondary' : null"
|
|
|
|
>
|
2021-02-01 19:38:17 +00:00
|
|
|
<i class="fas fa-columns fa-fw" aria-hidden />
|
|
|
|
Boards
|
|
|
|
</b-dropdown-item>
|
|
|
|
|
2021-02-03 21:04:02 +00:00
|
|
|
<b-dropdown-item
|
|
|
|
:to="{ name: 'tags' }"
|
|
|
|
:variant="nightMode ? 'secondary' : null"
|
|
|
|
>
|
2021-02-01 19:38:17 +00:00
|
|
|
<i class="fas fa-tags fa-fw" aria-hidden />
|
|
|
|
Tags
|
|
|
|
</b-dropdown-item>
|
|
|
|
|
2021-02-03 21:04:02 +00:00
|
|
|
<b-dropdown-item
|
|
|
|
:to="{ name: 'notes' }"
|
|
|
|
:variant="nightMode ? 'secondary' : null"
|
|
|
|
>
|
2021-02-01 19:38:17 +00:00
|
|
|
<i class="fas fa-sticky-note fa-fw" aria-hidden />
|
|
|
|
Notes
|
|
|
|
</b-dropdown-item>
|
|
|
|
|
2021-02-03 21:04:02 +00:00
|
|
|
<b-dropdown-item
|
|
|
|
:to="{ name: 'wallpapers' }"
|
|
|
|
:variant="nightMode ? 'secondary' : null"
|
|
|
|
>
|
2021-02-01 19:38:17 +00:00
|
|
|
<i class="fas fa-images fa-fw" aria-hidden />
|
|
|
|
Wallpapers
|
|
|
|
</b-dropdown-item>
|
|
|
|
|
2021-02-03 21:04:02 +00:00
|
|
|
<b-dropdown-item
|
2021-02-09 18:55:08 +00:00
|
|
|
:to="{ name: 'profile' }"
|
2021-02-03 21:04:02 +00:00
|
|
|
:variant="nightMode ? 'secondary' : null"
|
|
|
|
>
|
2021-02-01 19:38:17 +00:00
|
|
|
<i class="fas fa-user fa-fw" aria-hidden />
|
2021-02-09 18:55:08 +00:00
|
|
|
Profile
|
|
|
|
</b-dropdown-item>
|
|
|
|
|
|
|
|
<b-dropdown-item
|
|
|
|
:variant="nightMode ? 'secondary' : null"
|
|
|
|
v-b-modal:keyboard-shortcuts
|
|
|
|
>
|
|
|
|
<i class="fas fa-keyboard fa-fw" aria-hidden />
|
|
|
|
Keyboard shortcuts
|
2021-02-01 19:38:17 +00:00
|
|
|
</b-dropdown-item>
|
|
|
|
|
2021-02-03 21:04:02 +00:00
|
|
|
<b-dropdown-item
|
|
|
|
:to="{ name: 'settings' }"
|
|
|
|
:variant="nightMode ? 'secondary' : null"
|
|
|
|
>
|
2021-02-01 19:38:17 +00:00
|
|
|
<i class="fas fa-cog fa-fw" aria-hidden />
|
|
|
|
Settings
|
|
|
|
</b-dropdown-item>
|
|
|
|
</b-dropdown>
|
2020-09-26 00:09:20 +00:00
|
|
|
</nav>
|
2018-10-19 05:15:28 +00:00
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
2020-09-01 17:47:56 +00:00
|
|
|
import { mapState, mapGetters } from 'vuex';
|
2021-01-25 21:05:35 +00:00
|
|
|
import PinnedBoards from '@/components/Board/PinnedBoards';
|
2018-10-19 05:15:28 +00:00
|
|
|
|
|
|
|
export default {
|
2020-10-14 21:53:23 +00:00
|
|
|
components: {
|
2021-01-25 21:05:35 +00:00
|
|
|
PinnedBoards,
|
2020-10-14 21:53:23 +00:00
|
|
|
},
|
|
|
|
|
2019-11-08 19:56:03 +00:00
|
|
|
computed: {
|
2021-02-01 23:20:41 +00:00
|
|
|
...mapState(['board', 'notification', 'settings', 'user']),
|
2020-10-21 17:33:22 +00:00
|
|
|
...mapGetters(['nightMode']),
|
2021-01-20 22:48:01 +00:00
|
|
|
|
|
|
|
isBoard() {
|
|
|
|
return ['public-board', 'board'].includes(this.$route.name);
|
|
|
|
},
|
2019-11-08 19:56:03 +00:00
|
|
|
},
|
2021-02-01 23:20:41 +00:00
|
|
|
|
|
|
|
methods: {
|
|
|
|
handleLogoClick() {
|
2021-02-03 21:04:02 +00:00
|
|
|
if (!this.user) {
|
2021-02-03 22:14:22 +00:00
|
|
|
if (this.$route.name === 'public-boards') {
|
|
|
|
this.$bvModal.show('authModal');
|
|
|
|
} else {
|
|
|
|
this.$router.push({ name: 'public-boards' });
|
|
|
|
}
|
2021-02-03 21:04:02 +00:00
|
|
|
}
|
|
|
|
|
2021-02-01 23:20:41 +00:00
|
|
|
if (this.user && this.$route.name !== 'boards') {
|
|
|
|
this.$router.push({ name: 'boards' });
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
async pinBoard() {
|
|
|
|
const payload = {
|
|
|
|
...this.board,
|
|
|
|
pinned: !this.board.pinned,
|
|
|
|
};
|
|
|
|
|
|
|
|
this.$store.commit('SET_ACTIVE_BOARD', payload);
|
|
|
|
|
|
|
|
await this.$store.dispatch('SAVE_BOARD')
|
|
|
|
.catch(() => {
|
|
|
|
this.$bvToast.toast('There was an error renaming list', { variant: 'danger' });
|
|
|
|
});
|
|
|
|
|
|
|
|
this.$bvToast.toast('Board settings saved');
|
|
|
|
},
|
|
|
|
},
|
2018-10-19 05:15:28 +00:00
|
|
|
};
|
|
|
|
</script>
|
2020-09-26 00:09:20 +00:00
|
|
|
|
|
|
|
<style lang="scss" rel="stylesheet/scss" scoped>
|
|
|
|
nav {
|
|
|
|
width: 50px;
|
2020-09-30 02:36:27 +00:00
|
|
|
z-index: 1;
|
2020-09-26 00:09:20 +00:00
|
|
|
}
|
|
|
|
</style>
|