Mostly finished the button for the custom dropdown component. Just need to update the text displayed to reflect the current selection.

This commit is contained in:
ajdj100
2023-05-18 23:13:51 -04:00
parent babb36f048
commit 0cdd98fa99
5 changed files with 34 additions and 7 deletions

View File

@@ -8,6 +8,7 @@
"name": "17th-website", "name": "17th-website",
"version": "0.0.0", "version": "0.0.0",
"dependencies": { "dependencies": {
"@mahdikhashan/vue3-click-outside": "^0.1.2",
"vue": "^3.2.47", "vue": "^3.2.47",
"vue-router": "^4.2.0" "vue-router": "^4.2.0"
}, },
@@ -1038,6 +1039,17 @@
"dev": true, "dev": true,
"peer": true "peer": true
}, },
"node_modules/@mahdikhashan/vue3-click-outside": {
"version": "0.1.2",
"resolved": "https://registry.npmjs.org/@mahdikhashan/vue3-click-outside/-/vue3-click-outside-0.1.2.tgz",
"integrity": "sha512-8tJI5fvjemU4bG37EcxVvuYZJj6CHj3cDx1aAiYcOD/pzU5zQ7+BoJoXyI2Fx3fNH8Nwt+iQ1GsO4HRIUaqChQ==",
"dependencies": {
"vue": "^3.2.37"
},
"peerDependencies": {
"vue": "3.x.x"
}
},
"node_modules/@node-ipc/js-queue": { "node_modules/@node-ipc/js-queue": {
"version": "2.0.3", "version": "2.0.3",
"resolved": "https://registry.npmjs.org/@node-ipc/js-queue/-/js-queue-2.0.3.tgz", "resolved": "https://registry.npmjs.org/@node-ipc/js-queue/-/js-queue-2.0.3.tgz",
@@ -10107,6 +10119,14 @@
"dev": true, "dev": true,
"peer": true "peer": true
}, },
"@mahdikhashan/vue3-click-outside": {
"version": "0.1.2",
"resolved": "https://registry.npmjs.org/@mahdikhashan/vue3-click-outside/-/vue3-click-outside-0.1.2.tgz",
"integrity": "sha512-8tJI5fvjemU4bG37EcxVvuYZJj6CHj3cDx1aAiYcOD/pzU5zQ7+BoJoXyI2Fx3fNH8Nwt+iQ1GsO4HRIUaqChQ==",
"requires": {
"vue": "^3.2.37"
}
},
"@node-ipc/js-queue": { "@node-ipc/js-queue": {
"version": "2.0.3", "version": "2.0.3",
"resolved": "https://registry.npmjs.org/@node-ipc/js-queue/-/js-queue-2.0.3.tgz", "resolved": "https://registry.npmjs.org/@node-ipc/js-queue/-/js-queue-2.0.3.tgz",

View File

@@ -10,6 +10,7 @@
"format": "prettier --write src/" "format": "prettier --write src/"
}, },
"dependencies": { "dependencies": {
"@mahdikhashan/vue3-click-outside": "^0.1.2",
"vue": "^3.2.47", "vue": "^3.2.47",
"vue-router": "^4.2.0" "vue-router": "^4.2.0"
}, },

View File

@@ -1,6 +1,7 @@
<script> <script>
import { provide } from 'vue'; import { provide } from 'vue';
import { Icon } from '@iconify/vue' import { Icon } from '@iconify/vue'
import clickOutSide from '@mahdikhashan/vue3-click-outside'
export default { export default {
name: 'Dropdown', name: 'Dropdown',
@@ -29,12 +30,15 @@ export default {
}, },
props: { props: {
title: String title: String
},
directives: {
clickOutSide,
} }
} }
</script> </script>
<template> <template>
<div id="button" @click="toggle" v-click-away="away"> <div id="button" @click="toggle" v-click-out-side="away">
<slot name="toggler"> <slot name="toggler">
<button> <button>
<p>{{ title }}</p> <p>{{ title }}</p>

View File

@@ -11,10 +11,14 @@ export default {
</template> </template>
<style scoped> <style scoped>
div { * {
background-color: aliceblue; color: var(--white);
padding: 5px;
} }
h1 {
color: black !important; div:hover {
background-color: var(--accent-primary);
transition: color 0.5s;
} }
</style> </style>

View File

@@ -62,8 +62,6 @@ export default {
</DropdownContent> </DropdownContent>
</dropdown> </dropdown>
<Icon icon="carbon:caret-down" />
<!-- This button needs to get finished --> <!-- This button needs to get finished -->
<button @click="resetFilters()">Clear Filters</button> <button @click="resetFilters()">Clear Filters</button>
</div> </div>