* #120 - wip * #120 - add icon to home office * #120 - wip * #120 - wip * #120 - wip * #120 - wip * #120 - wip * #120 - ui fixes * #120 - fix * #120 - fix * #120 - fix * #120 - fix * #120 - translation fix * #120 - fix Co-authored-by: EwelinaLasowy <ewelina.lasowy@blumilk.pl>
		
			
				
	
	
		
			85 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
|   <Popper
 | |
|     hover
 | |
|     class="w-full"
 | |
|   >
 | |
|     <div class="flex text-white bg-white">
 | |
|       <div
 | |
|         v-show="stats.used > 0"
 | |
|         :style="`background-color: ${colors.used}; flex-basis: ${calculatePercent(stats.used)}%;`"
 | |
|         class="flex justify-center items-center py-2 px-0.5"
 | |
|       >
 | |
|         <strong>{{ stats.used }}</strong>
 | |
|       </div>
 | |
|       <div
 | |
|         v-show="stats.pending > 0"
 | |
|         :style="`background-color: ${colors.pending}; flex-basis: ${calculatePercent(stats.pending)}%;`"
 | |
|         class="flex justify-center items-center py-2 px-0.5"
 | |
|       >
 | |
|         <strong>{{ stats.pending }}</strong>
 | |
|       </div>
 | |
|       <div
 | |
|         v-show="stats.remaining > 0"
 | |
|         :style="`background-color: ${colors.remaining}; flex-basis: ${calculatePercent(stats.remaining)}%;`"
 | |
|         class="flex justify-center items-center py-2 px-0.5"
 | |
|       >
 | |
|         <strong>{{ stats.remaining }}</strong>
 | |
|       </div>
 | |
|     </div>
 | |
|     <template #content>
 | |
|       <div class="py-2 px-4 text-gray-900 bg-white rounded-lg border border-gray-400 text-md">
 | |
|         <div class="flex items-center font-normal">
 | |
|           <i
 | |
|             class="inline-block mr-3 w-5 h-3"
 | |
|             :style="`background-color: ${colors.used}`"
 | |
|           />
 | |
|           Wykorzystane:
 | |
|           <span class="ml-1 font-semibold">{{ stats.used }}</span>
 | |
|         </div>
 | |
|         <div class="flex items-center font-normal">
 | |
|           <i
 | |
|             class="inline-block mr-3 w-5 h-3"
 | |
|             :style="`background-color: ${colors.pending}`"
 | |
|           />
 | |
|           Rozpatrywane:
 | |
|           <span class="ml-1 font-semibold">{{ stats.pending }}</span>
 | |
|         </div>
 | |
|         <div class="flex items-center font-normal">
 | |
|           <i
 | |
|             class="inline-block mr-3 w-5 h-3"
 | |
|             :style="`background-color: ${colors.remaining}`"
 | |
|           />
 | |
|           Pozostałe:
 | |
|           <span class="ml-1 font-semibold">{{ stats.remaining }}</span>
 | |
|         </div>
 | |
|       </div>
 | |
|     </template>
 | |
|   </Popper>
 | |
| </template>
 | |
| 
 | |
| <script setup>
 | |
| import Popper from 'vue3-popper'
 | |
| 
 | |
| const props = defineProps({
 | |
|   stats: {
 | |
|     type: Object,
 | |
|     default: () => ({
 | |
|       used: 0,
 | |
|       pending: 0,
 | |
|       remaining: 0,
 | |
|     }),
 | |
|   },
 | |
| })
 | |
| 
 | |
| const colors = {
 | |
|   used: '#2C466F',
 | |
|   pending: '#AABDDD',
 | |
|   remaining: '#527ABA',
 | |
| }
 | |
| 
 | |
| function calculatePercent(value) {
 | |
|   return value / (props.stats.used + props.stats.pending + props.stats.remaining) * 100
 | |
| }
 | |
| 
 | |
| </script>
 |