2019-04-26 15:22:16 +02:00
|
|
|
<template>
|
|
|
|
<section class="container">
|
2019-06-17 17:15:27 +02:00
|
|
|
<div v-if="loggedPerson">
|
2019-04-26 15:22:16 +02:00
|
|
|
<div class="header">
|
2019-06-17 17:15:27 +02:00
|
|
|
<figure v-if="loggedPerson.banner" class="image is-3by1">
|
|
|
|
<img :src="loggedPerson.banner.url" alt="banner">
|
2019-04-26 15:22:16 +02:00
|
|
|
</figure>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="columns">
|
|
|
|
<div class="identities column is-4">
|
2019-06-17 17:15:27 +02:00
|
|
|
<identities v-bind:currentIdentityName="currentIdentityName"></identities>
|
|
|
|
</div>
|
|
|
|
<div class="column is-8">
|
|
|
|
<router-view></router-view>
|
2019-04-26 15:22:16 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</section>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<style lang="scss">
|
|
|
|
.header {
|
|
|
|
padding-bottom: 30px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.identities {
|
|
|
|
padding-right: 45px;
|
|
|
|
margin-right: 45px;
|
|
|
|
}
|
|
|
|
</style>
|
|
|
|
|
|
|
|
<script lang="ts">
|
|
|
|
import { LOGGED_PERSON } from '@/graphql/actor';
|
2019-06-17 17:15:27 +02:00
|
|
|
import { Component, Vue, Watch } from 'vue-property-decorator';
|
2019-04-26 15:22:16 +02:00
|
|
|
import EventCard from '@/components/Event/EventCard.vue';
|
|
|
|
import { IPerson } from '@/types/actor';
|
|
|
|
import Identities from '@/components/Account/Identities.vue';
|
|
|
|
|
|
|
|
@Component({
|
|
|
|
components: {
|
|
|
|
EventCard,
|
|
|
|
Identities,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
export default class MyAccount extends Vue {
|
2019-06-17 17:15:27 +02:00
|
|
|
loggedPerson: IPerson | null = null;
|
|
|
|
currentIdentityName: string | null = null;
|
|
|
|
|
|
|
|
@Watch('$route.params.identityName', { immediate: true })
|
|
|
|
async onIdentityParamChanged (val: string) {
|
|
|
|
if (!this.loggedPerson) {
|
|
|
|
this.loggedPerson = await this.loadLoggedPerson();
|
|
|
|
}
|
|
|
|
|
|
|
|
await this.redirectIfNoIdentitySelected(val);
|
|
|
|
|
|
|
|
this.currentIdentityName = val;
|
|
|
|
}
|
|
|
|
|
|
|
|
private async redirectIfNoIdentitySelected (identityParam?: string) {
|
|
|
|
if (!!identityParam) return;
|
|
|
|
|
|
|
|
if (!!this.loggedPerson) {
|
|
|
|
this.$router.push({ params: { identityName: this.loggedPerson.preferredUsername } });
|
|
|
|
}
|
|
|
|
}
|
2019-04-26 15:22:16 +02:00
|
|
|
|
2019-06-17 17:15:27 +02:00
|
|
|
private async loadLoggedPerson () {
|
2019-04-26 15:22:16 +02:00
|
|
|
const result = await this.$apollo.query({
|
|
|
|
query: LOGGED_PERSON,
|
|
|
|
});
|
|
|
|
|
2019-06-17 17:15:27 +02:00
|
|
|
return result.data.loggedPerson as IPerson;
|
2019-04-26 15:22:16 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
<style lang="scss">
|
|
|
|
@import "../../variables";
|
|
|
|
@import "~bulma/sass/utilities/_all";
|
|
|
|
@import "~bulma/sass/components/dropdown.sass";
|
|
|
|
</style>
|