59 lines
		
	
	
		
			854 B
		
	
	
	
		
			Vue
		
	
	
		
			Executable File
		
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			854 B
		
	
	
	
		
			Vue
		
	
	
		
			Executable File
		
	
	
| <template>
 | |
| 	<div
 | |
| 		:class="{ active }"
 | |
| 		:title="title"
 | |
| 		class="icon"
 | |
| 		v-html="svg"
 | |
| 	/>
 | |
| </template>
 | |
| 
 | |
| <script setup>
 | |
| import { ref } from 'vue';
 | |
| 
 | |
| const svg = ref(null);
 | |
| 
 | |
| const props = defineProps({
 | |
| 	icon: {
 | |
| 		type: String,
 | |
| 		default: null,
 | |
| 	},
 | |
| 	title: {
 | |
| 		type: String,
 | |
| 		default: null,
 | |
| 	},
 | |
| 	active: {
 | |
| 		type: Boolean,
 | |
| 		default: false,
 | |
| 	},
 | |
| });
 | |
| 
 | |
| import(`../../assets/img/icons/${props.icon}.svg?raw`).then((raw) => {
 | |
| 	svg.value = raw.default;
 | |
| });
 | |
| </script>
 | |
| 
 | |
| <style>
 | |
| .icon {
 | |
|     fill: var(--text);
 | |
|     display: inline-block;
 | |
|     flex-shrink: 0;
 | |
|     width: 1rem;
 | |
|     height: 1rem;
 | |
| 	font-size: 0; /* prevent flashing null before icon is loaded */
 | |
| 
 | |
|     svg {
 | |
|         width: 100%;
 | |
|         height: 100%;
 | |
|     }
 | |
| 
 | |
|     &.active {
 | |
|         fill: var(--glass);
 | |
| 
 | |
|         &:hover {
 | |
|             fill: var(--text);
 | |
|             cursor: pointer;
 | |
|         }
 | |
|     }
 | |
| }
 | |
| </style>
 |