This commit is contained in:
j3d1 2023-05-11 20:26:48 +02:00
parent 9381d229c5
commit 297ad7bd99
12 changed files with 121 additions and 40 deletions

View file

@ -6,14 +6,7 @@
<a class="sidebar-toggle d-flex">
<i class="hamburger align-self-center"></i>
</a>
<form class="d-none d-sm-inline-block">
<div class="input-group input-group-navbar">
<input type="text" class="form-control" placeholder="Search…" aria-label="Search">
<button class="btn" type="button">
<b-icon-search class="bi-valign-middle"></b-icon-search>
</button>
</div>
</form>
<SearchBox/>
<div class="navbar-collapse collapse">
<ul class="navbar-nav navbar-align">
<Notifications :notifications="notifications"/>
@ -30,32 +23,26 @@
<script>
import {mapGetters, mapMutations, mapState} from 'vuex';
import * as BIcons from "bootstrap-icons-vue";
import Notifications from "@/components/Notifications.vue";
import Messages from "@/components/Messages.vue";
import Footer from "@/components/Footer.vue";
import Sidebar from "@/components/Sidebar.vue";
import UserDropdown from "@/components/UserDropdown.vue";
import SearchBox from "@/components/SearchBox.vue";
export default {
name: 'BaseLayout',
components: {
SearchBox,
UserDropdown,
Sidebar,
Footer,
Messages,
Notifications,
...BIcons
Notifications
},
computed: {
...mapState(['messages']),
...mapGetters(['notifications']),
username() {
return this.$route.params.username
},
},
methods: {
...mapMutations(['logout'])
...mapGetters(['notifications'])
},
async mounted() {
}

View file

@ -82,7 +82,6 @@
</template>
<script>
import {mapGetters, mapMutations} from 'vuex';
import * as BIcons from "bootstrap-icons-vue";
export default {

View file

@ -0,0 +1,44 @@
<template>
<form class="d-none d-sm-inline-block">
<div class="input-group input-group-navbar">
<input type="text" class="form-control" placeholder="Search…" aria-label="Search" v-model="query" id="searchText">
<button class="btn" type="button" @click.prevent="search">
<b-icon-search class="bi-valign-middle"></b-icon-search>
</button>
</div>
</form>
</template>
<script>
import * as BIcons from "bootstrap-icons-vue";
export default {
name: "SearchBox",
components: {
...BIcons
},
data() {
return {
query: ""
}
},
methods: {
search() {
if(this.query.length > 0)
this.$router.push("/search/" + encodeURIComponent(this.query));
else
document.getElementById("searchText").focus();
}
},
mounted() {
console.log(this.$route)
console.log(this.$route.params.query)
this.query = decodeURIComponent(this.$route.params.query || encodeURIComponent(""));
}
}
</script>
<style scoped>
</style>

View file

@ -26,9 +26,13 @@
</template>
<script>
import * as BIcons from "bootstrap-icons-vue";
export default {
name: "Sidebar"
name: "Sidebar",
components: {
...BIcons
},
}
</script>

View file

@ -8,10 +8,10 @@
<a class="nav-link dropdown-toggle d-none d-sm-inline-block" href="#"
data-toggle="dropdown">
<!--<img src="/static/assets/img/avatars/avatar.png" class="avatar img-fluid rounded mr-1"
alt="Charles Hall"/>-->
<img src="/assets/img/avatars/avatar.png" class="avatar img-fluid rounded mr-1"
alt="Charles Hall"/>
<span class="text-dark">
<!--{{ request.user.username }}-->
{{ username }}
</span>
</a>
@ -32,12 +32,22 @@
</template>
<script>
import Messages from "@/components/Messages.vue";
import * as BIcons from "bootstrap-icons-vue";
import {mapMutations} from "vuex";
export default {
name: "UserDropdown",
components: {Messages}
components: {
...BIcons
},
methods: {
...mapMutations(['logout'])
},
computed: {
username() {
return this.$route.params.username
},
}
}
</script>