forked from DebaucheryLibrarian/traxxx
				
			
		
			
				
	
	
		
			62 lines
		
	
	
		
			956 B
		
	
	
	
		
			Vue
		
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			956 B
		
	
	
	
		
			Vue
		
	
	
	
| <template>
 | |
|     <div
 | |
|         :title="title"
 | |
|         :class="{ active }"
 | |
|         class="icon"
 | |
|         v-html="svg"
 | |
|     />
 | |
| </template>
 | |
| 
 | |
| <script>
 | |
| export default {
 | |
|     props: {
 | |
|         icon: {
 | |
|             type: String,
 | |
|             default: null,
 | |
|         },
 | |
|         title: {
 | |
|             type: String,
 | |
|             default: null,
 | |
|         },
 | |
|         active: {
 | |
|             type: Boolean,
 | |
|             default: false,
 | |
|         },
 | |
|     },
 | |
|     data() {
 | |
|         return {
 | |
|             svg: null,
 | |
|         };
 | |
|     },
 | |
|     beforeMount() {
 | |
|         this.svg = require(`../../img/${this.icon}.svg`).default;
 | |
|     },
 | |
| };
 | |
| </script>
 | |
| 
 | |
| <style lang="scss">
 | |
| @import '../../css/theme';
 | |
| 
 | |
| .icon {
 | |
|     fill: $text;
 | |
|     display: inline-block;
 | |
|     flex-shrink: 0;
 | |
|     width: 1rem;
 | |
|     height: 1rem;
 | |
| 
 | |
|     svg {
 | |
|         width: 100%;
 | |
|         height: 100%;
 | |
|     }
 | |
| 
 | |
|     &.active {
 | |
|         fill: $shadow;
 | |
| 
 | |
|         &:hover {
 | |
|             fill: $text;
 | |
|             cursor: pointer;
 | |
|         }
 | |
|     }
 | |
| }
 | |
| </style>
 |