mirror of
				https://github.com/crater-invoice/crater.git
				synced 2025-10-28 04:01:10 -04:00 
			
		
		
		
	Compare commits
	
		
			3 Commits
		
	
	
		
			dark-baseI
			...
			fix-tax-is
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| c8ee6389a4 | |||
| e4bd002fae | |||
| 05abf7fa74 | 
| @ -38,7 +38,7 @@ | ||||
|     "barryvdh/laravel-ide-helper": "^2.6", | ||||
|     "beyondcode/laravel-dump-server": "^1.0", | ||||
|     "facade/ignition": "^2.3.6", | ||||
|     "friendsofphp/php-cs-fixer": "^3.0", | ||||
|     "friendsofphp/php-cs-fixer": "^3.8", | ||||
|     "fakerphp/faker": "^1.9.1", | ||||
|     "mockery/mockery": "^1.3.1", | ||||
|     "nunomaduro/collision": "^5.0", | ||||
|  | ||||
							
								
								
									
										2331
									
								
								composer.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2331
									
								
								composer.lock
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -17,18 +17,7 @@ | ||||
|             <td class="px-5 py-4 text-left align-top"> | ||||
|               <div class="flex justify-start"> | ||||
|                 <div | ||||
|                   class=" | ||||
|                     flex | ||||
|                     items-center | ||||
|                     justify-center | ||||
|                     w-5 | ||||
|                     h-5 | ||||
|                     mt-2 | ||||
|                     text-gray-300 | ||||
|                     cursor-move | ||||
|                     handle | ||||
|                     mr-2 | ||||
|                   " | ||||
|                   class="flex items-center justify-center w-5 h-5 mt-2 mr-2 text-gray-300 cursor-move  handle" | ||||
|                 > | ||||
|                   <DragIcon /> | ||||
|                 </div> | ||||
| @ -108,7 +97,7 @@ | ||||
|  | ||||
|                           <BaseIcon | ||||
|                             name="ChevronDownIcon" | ||||
|                             class="w-4 h-4 text-gray-500 ml-1" | ||||
|                             class="w-4 h-4 ml-1 text-gray-500" | ||||
|                           /> | ||||
|                         </span> | ||||
|                       </BaseButton> | ||||
| @ -155,7 +144,7 @@ | ||||
|               <BaseContentPlaceholders v-if="loading"> | ||||
|                 <BaseContentPlaceholdersText | ||||
|                   :lines="1" | ||||
|                   class="w-24 h-8 rounded-md border" | ||||
|                   class="w-24 h-8 border rounded-md" | ||||
|                 /> | ||||
|               </BaseContentPlaceholders> | ||||
|  | ||||
| @ -175,6 +164,7 @@ | ||||
|                 :ability="abilities.CREATE_INVOICE" | ||||
|                 :store="store" | ||||
|                 :store-prop="storeProp" | ||||
|                 :discount="discount" | ||||
|                 @update="updateTax" | ||||
|               /> | ||||
|             </td> | ||||
|  | ||||
| @ -30,24 +30,13 @@ | ||||
|         <template v-if="userStore.hasAbilities(ability)" #action> | ||||
|           <button | ||||
|             type="button" | ||||
|             class=" | ||||
|               flex | ||||
|               items-center | ||||
|               justify-center | ||||
|               w-full | ||||
|               px-2 | ||||
|               cursor-pointer | ||||
|               py-2 | ||||
|               bg-gray-200 | ||||
|               border-none | ||||
|               outline-none | ||||
|             " | ||||
|             class="flex items-center justify-center w-full px-2 py-2 bg-gray-200 border-none outline-none cursor-pointer " | ||||
|             @click="openTaxModal" | ||||
|           > | ||||
|             <BaseIcon name="CheckCircleIcon" class="h-5 text-primary-400" /> | ||||
|  | ||||
|             <label | ||||
|               class="ml-2 text-sm leading-none text-primary-400 cursor-pointer" | ||||
|               class="ml-2 text-sm leading-none cursor-pointer text-primary-400" | ||||
|               >{{ $t('invoices.add_new_tax') }}</label | ||||
|             > | ||||
|           </button> | ||||
| @ -115,6 +104,10 @@ const props = defineProps({ | ||||
|     type: Number, | ||||
|     default: 0, | ||||
|   }, | ||||
|   discountedTotal: { | ||||
|     type: Number, | ||||
|     default: 0, | ||||
|   }, | ||||
|   currency: { | ||||
|     type: [Object, String], | ||||
|     required: true, | ||||
| @ -153,19 +146,19 @@ const filteredTypes = computed(() => { | ||||
| }) | ||||
|  | ||||
| const taxAmount = computed(() => { | ||||
|   if (localTax.compound_tax && props.total) { | ||||
|     return ((props.total + props.totalTax) * localTax.percent) / 100 | ||||
|   if (localTax.compound_tax && props.discountedTotal) { | ||||
|     return ((props.discountedTotal + props.totalTax) * localTax.percent) / 100 | ||||
|   } | ||||
|  | ||||
|   if (props.total && localTax.percent) { | ||||
|     return (props.total * localTax.percent) / 100 | ||||
|   if (props.discountedTotal && localTax.percent) { | ||||
|     return (props.discountedTotal * localTax.percent) / 100 | ||||
|   } | ||||
|  | ||||
|   return 0 | ||||
| }) | ||||
|  | ||||
| watch( | ||||
|   () => props.total, | ||||
|   () => props.discountedTotal, | ||||
|   () => { | ||||
|     updateRowTax() | ||||
|   } | ||||
|  | ||||
| @ -29,14 +29,7 @@ | ||||
|  | ||||
|       <label | ||||
|         v-else | ||||
|         class=" | ||||
|           flex | ||||
|           items-center | ||||
|           justify-center | ||||
|           m-0 | ||||
|           text-lg text-black | ||||
|           uppercase | ||||
|         " | ||||
|         class="flex items-center justify-center m-0 text-lg text-black uppercase " | ||||
|       > | ||||
|         <BaseFormatMoney | ||||
|           :amount="store.getSubTotal" | ||||
| @ -66,14 +59,7 @@ | ||||
|  | ||||
|       <label | ||||
|         v-else-if="store[storeProp].tax_per_item === 'YES'" | ||||
|         class=" | ||||
|           flex | ||||
|           items-center | ||||
|           justify-center | ||||
|           m-0 | ||||
|           text-lg text-black | ||||
|           uppercase | ||||
|         " | ||||
|         class="flex items-center justify-center m-0 text-lg text-black uppercase " | ||||
|       > | ||||
|         <BaseFormatMoney :amount="tax.amount" :currency="defaultCurrency" /> | ||||
|       </label> | ||||
| @ -98,7 +84,7 @@ | ||||
|       <BaseContentPlaceholders v-if="isLoading"> | ||||
|         <BaseContentPlaceholdersText | ||||
|           :lines="1" | ||||
|           class="w-24 h-8 rounded-md border" | ||||
|           class="w-24 h-8 border rounded-md" | ||||
|         /> | ||||
|       </BaseContentPlaceholders> | ||||
|       <div v-else class="flex" style="width: 140px" role="group"> | ||||
| @ -114,7 +100,7 @@ | ||||
|         <BaseDropdown position="bottom-end"> | ||||
|           <template #activator> | ||||
|             <BaseButton | ||||
|               class="rounded-tr-md rounded-br-md p-2 rounded-none" | ||||
|               class="p-2 rounded-none rounded-tr-md rounded-br-md" | ||||
|               type="button" | ||||
|               variant="white" | ||||
|             > | ||||
| @ -127,7 +113,7 @@ | ||||
|  | ||||
|                 <BaseIcon | ||||
|                   name="ChevronDownIcon" | ||||
|                   class="w-4 h-4 text-gray-500 ml-1" | ||||
|                   class="w-4 h-4 ml-1 text-gray-500" | ||||
|                 /> | ||||
|               </span> | ||||
|             </BaseButton> | ||||
| @ -180,15 +166,7 @@ | ||||
|     </div> | ||||
|  | ||||
|     <div | ||||
|       class=" | ||||
|         flex | ||||
|         items-center | ||||
|         justify-between | ||||
|         w-full | ||||
|         pt-2 | ||||
|         mt-5 | ||||
|         border-t border-gray-200 border-solid | ||||
|       " | ||||
|       class="flex items-center justify-between w-full pt-2 mt-5 border-t border-gray-200 border-solid " | ||||
|     > | ||||
|       <BaseContentPlaceholders v-if="isLoading"> | ||||
|         <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" /> | ||||
| @ -204,14 +182,7 @@ | ||||
|       </BaseContentPlaceholders> | ||||
|       <label | ||||
|         v-else | ||||
|         class=" | ||||
|           flex | ||||
|           items-center | ||||
|           justify-center | ||||
|           text-lg | ||||
|           uppercase | ||||
|           text-primary-400 | ||||
|         " | ||||
|         class="flex items-center justify-center text-lg uppercase  text-primary-400" | ||||
|       > | ||||
|         <BaseFormatMoney :amount="store.getTotal" :currency="defaultCurrency" /> | ||||
|       </label> | ||||
| @ -334,6 +305,7 @@ function selectPercentage() { | ||||
|  | ||||
| function onSelectTax(selectedTax) { | ||||
|   let amount = 0 | ||||
|  | ||||
|   if (selectedTax.compound_tax && props.store.getSubtotalWithDiscount) { | ||||
|     amount = Math.round( | ||||
|       ((props.store.getSubtotalWithDiscount + props.store.getTotalSimpleTax) * | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	