aboutsummaryrefslogtreecommitdiff
path: root/src/components/side_drawer
diff options
context:
space:
mode:
authorshpuld <shp@cock.li>2018-12-15 19:13:01 +0200
committershpuld <shp@cock.li>2018-12-15 19:13:01 +0200
commitbd2ed617a740ef3b37dedf3bed608e433dc0ec09 (patch)
tree7736cb1283bc835b1d075c8ac0cab0765afad0fe /src/components/side_drawer
parenteaf065c751610008bf9062cf812085c3016cadbc (diff)
Remove panel switcher, add rudimentary drawer
Diffstat (limited to 'src/components/side_drawer')
-rw-r--r--src/components/side_drawer/side_drawer.js13
-rw-r--r--src/components/side_drawer/side_drawer.vue116
2 files changed, 129 insertions, 0 deletions
diff --git a/src/components/side_drawer/side_drawer.js b/src/components/side_drawer/side_drawer.js
new file mode 100644
index 00000000..bf9df753
--- /dev/null
+++ b/src/components/side_drawer/side_drawer.js
@@ -0,0 +1,13 @@
+const SideDrawer = {
+ props: [ 'activatePanel', 'closed' ],
+ computed: {
+ currentUser () {
+ return this.$store.state.users.currentUser
+ },
+ chat () {
+ return this.$store.state.chat.channel
+ }
+ }
+}
+
+export default SideDrawer
diff --git a/src/components/side_drawer/side_drawer.vue b/src/components/side_drawer/side_drawer.vue
new file mode 100644
index 00000000..8e2629b8
--- /dev/null
+++ b/src/components/side_drawer/side_drawer.vue
@@ -0,0 +1,116 @@
+<template>
+ <div>
+ <div class="panel panel-default side-drawer" :class="{'side-drawer-closed': closed}">
+ <ul>
+ <li v-if='currentUser'>
+ <router-link @click.native="activatePanel('timeline')" to='/main/friends'>
+ {{ $t("nav.timeline") }}
+ </router-link>
+ </li>
+ <li v-if='currentUser'>
+ <router-link @click.native="activatePanel('timeline')" :to="{ name: 'mentions', params: { username: currentUser.screen_name } }">
+ {{ $t("nav.mentions") }}
+ </router-link>
+ </li>
+ <li v-if='currentUser'>
+ <router-link @click.native="activatePanel('timeline')" :to="{ name: 'dms', params: { username: currentUser.screen_name } }">
+ {{ $t("nav.dms") }}
+ </router-link>
+ </li>
+ <li v-if='currentUser && currentUser.locked'>
+ <router-link @click.native="activatePanel('timeline')" to='/friend-requests'>
+ {{ $t("nav.friend_requests") }}
+ </router-link>
+ </li>
+ <li>
+ <router-link @click.native="activatePanel('timeline')" to='/main/public'>
+ {{ $t("nav.public_tl") }}
+ </router-link>
+ </li>
+ <li>
+ <router-link @click.native="activatePanel('timeline')" to='/main/all'>
+ {{ $t("nav.twkn") }}
+ </router-link>
+ </li>
+ </ul>
+ </div>
+ </div>
+</template>
+
+<script src="./side_drawer.js" ></script>
+
+<style lang="scss">
+@import '../../_variables.scss';
+
+.side-drawer {
+ height: 100%; /* 100% Full-height */
+ position: fixed; /* Stay in place */
+ z-index: 1000; /* Stay on top */
+ top: 0; /* Stay at the top */
+ left: -200px;
+ overflow-x: hidden; /* Disable horizontal scroll */
+ transition: 0.5s; /* 0.5 second transition effect to slide in the sidenav */
+ transition-timing-function: cubic-bezier(0, 1, 0.5, 1);
+ margin: 0;
+ padding-left: 200px;
+}
+
+.side-drawer-closed {
+ left: calc(-100% - 200px);
+}
+
+.side-drawer .panel {
+ overflow: hidden;
+ margin: 0;
+}
+.side-drawer ul {
+ list-style: none;
+ margin: 0;
+ padding: 0;
+}
+
+.side-drawer li {
+ border-bottom: 1px solid;
+ border-color: $fallback--border;
+ border-color: var(--border, $fallback--border);
+ padding: 0;
+
+ &:first-child a {
+ border-top-right-radius: $fallback--panelRadius;
+ border-top-right-radius: var(--panelRadius, $fallback--panelRadius);
+ border-top-left-radius: $fallback--panelRadius;
+ border-top-left-radius: var(--panelRadius, $fallback--panelRadius);
+ }
+
+ &:last-child a {
+ border-bottom-right-radius: $fallback--panelRadius;
+ border-bottom-right-radius: var(--panelRadius, $fallback--panelRadius);
+ border-bottom-left-radius: $fallback--panelRadius;
+ border-bottom-left-radius: var(--panelRadius, $fallback--panelRadius);
+ }
+}
+
+.side-drawer li:last-child {
+ border: none;
+}
+
+.side-drawer a {
+ display: block;
+ padding: 0.8em 0.85em;
+
+ &:hover {
+ background-color: $fallback--lightBg;
+ background-color: var(--lightBg, $fallback--lightBg);
+ }
+
+ &.router-link-active {
+ font-weight: bolder;
+ background-color: $fallback--lightBg;
+ background-color: var(--lightBg, $fallback--lightBg);
+
+ &:hover {
+ text-decoration: underline;
+ }
+ }
+}
+</style>