diff --git a/src/client/app/desktop/views/components/ui.sidebar.vue b/src/client/app/desktop/views/components/ui.sidebar.vue
index 8e586eb259..a411080734 100644
--- a/src/client/app/desktop/views/components/ui.sidebar.vue
+++ b/src/client/app/desktop/views/components/ui.sidebar.vue
@@ -23,28 +23,43 @@
-
- %fa:star%
-
-
+
+
+
+
+
+
+
+
+
+
@@ -56,12 +71,14 @@ import MkSettingsWindow from './settings-window.vue';
import MkDriveWindow from './drive-window.vue';
import MkMessagingWindow from './messaging-window.vue';
import MkGameWindow from './game-window.vue';
+import contains from '../../../common/scripts/contains';
export default Vue.extend({
data() {
return {
hasGameInvitations: false,
- connection: null
+ connection: null,
+ showNotifications: false
};
},
@@ -130,6 +147,37 @@ export default Vue.extend({
(this as any).os.signout();
},
+ notifications() {
+ this.showNotifications ? this.closeNotifications() : this.openNotifications();
+ },
+
+ openNotifications() {
+ this.showNotifications = true;
+ Array.from(document.querySelectorAll('body *')).forEach(el => {
+ el.addEventListener('mousedown', this.onMousedown);
+ });
+ },
+
+ closeNotifications() {
+ this.showNotifications = false;
+ Array.from(document.querySelectorAll('body *')).forEach(el => {
+ el.removeEventListener('mousedown', this.onMousedown);
+ });
+ },
+
+ onMousedown(e) {
+ e.preventDefault();
+ if (
+ !contains(this.$refs.notifications, e.target) &&
+ this.$refs.notifications != e.target &&
+ !contains(this.$refs.notificationsButton, e.target) &&
+ this.$refs.notificationsButton != e.target
+ ) {
+ this.closeNotifications();
+ }
+ return false;
+ },
+
dark() {
this.$store.commit('device/set', {
key: 'darkmode',
@@ -157,7 +205,7 @@ export default Vue.extend({
width $width
height 100%
background var(--desktopHeaderBg)
- box-shadow var(--shadow)
+ box-shadow var(--shadowRight)
&.left
left 0
@@ -165,28 +213,6 @@ export default Vue.extend({
&.right
right 0
- > .nav
- > *
- &.active
- box-shadow -4px 0 var(--primary) inset
-
- > *
- display block
- width $width
- line-height 52px
- text-align center
- font-size 18px
- color var(--desktopHeaderFg)
-
- &:hover
- color var(--desktopHeaderHoverFg)
- text-decoration none
-
- > .nav.bottom
- position absolute
- bottom 64px
- left 0
-
> .post
width $width
height $width
@@ -219,15 +245,52 @@ export default Vue.extend({
background var(--primaryDarken10) !important
transition background 0s ease
+ .nav
+ > *
+ &.active
+ box-shadow -4px 0 var(--primary) inset
+
+ > *
+ display block
+ width $width
+ line-height 52px
+ text-align center
+ font-size 18px
+ color var(--desktopHeaderFg)
+
+ &:hover
+ background rgba(0, 0, 0, 0.05)
+ color var(--desktopHeaderHoverFg)
+ text-decoration none
+
+ &:active
+ background rgba(0, 0, 0, 0.1)
+
+ > .nav.bottom
+ position absolute
+ bottom 128px
+ left 0
+
> .account
position absolute
- bottom 0
+ bottom 64px
left 0
width $width
height $width
padding 14px
- > *
+ > .menu
+ display none
+ position absolute
+ bottom 64px
+ left 0
+ background var(--desktopHeaderBg)
+
+ &:hover
+ > .menu
+ display block
+
+ > *:not(.menu)
display block
width 100%
height 100%
@@ -237,4 +300,30 @@ export default Vue.extend({
width 100%
height 100%
+ > .dark
+ position absolute
+ bottom 0
+ left 0
+ width $width
+ height $width
+
+ > .notifications
+ position fixed
+ top 0
+ left $width
+ width 350px
+ height 100%
+ overflow auto
+ background var(--face)
+ box-shadow var(--shadowRight)
+
+.slide-enter-active,
+.slide-leave-active {
+ transition: all 0.2s ease;
+}
+
+.slide-enter, .slide-leave-to {
+ transform: translateX(-16px);
+ opacity: 0;
+}
diff --git a/src/client/app/init.ts b/src/client/app/init.ts
index ad9909374a..d5faf4557c 100644
--- a/src/client/app/init.ts
+++ b/src/client/app/init.ts
@@ -124,11 +124,14 @@ export default (callback: (launch: (router: VueRouter, api?: (os: MiOS) => API)
//#region shadow
const shadow = '0 3px 8px rgba(0, 0, 0, 0.2)';
+ const shadowRight = '4px 0 4px rgba(0, 0, 0, 0.1)';
if (os.store.state.settings.useShadow) document.documentElement.style.setProperty('--shadow', shadow);
+ if (os.store.state.settings.useShadow) document.documentElement.style.setProperty('--shadowRight', shadowRight);
os.store.watch(s => {
return s.settings.useShadow;
}, v => {
document.documentElement.style.setProperty('--shadow', v ? shadow : 'none');
+ document.documentElement.style.setProperty('--shadowRight', v ? shadowRight : 'none');
});
//#endregion