mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-26 13:42:53 -04:00 
			
		
		
		
	Return early to improve PDF generation performance
This commit is contained in:
		
							parent
							
								
									8a8580ecba
								
							
						
					
					
						commit
						c26904645b
					
				| @ -114,6 +114,22 @@ class Helpers | |||||||
|             return ''; |             return ''; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         // 04-10-2022 Return Early if no reserved keywords are present, this is a very expenseive process
 | ||||||
|  |         $string_hit = false; | ||||||
|  | 
 | ||||||
|  |         foreach ( [':MONTH',':YEAR',':QUARTER',':WEEK'] as $string )  | ||||||
|  |         { | ||||||
|  |          | ||||||
|  |             if(stripos($value, $string) !== FALSE) { | ||||||
|  |                 $string_hit = true;  | ||||||
|  |             } | ||||||
|  |              | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         if(!$string_hit) | ||||||
|  |             return $value; | ||||||
|  |         // 04-10-2022 Return Early if no reserved keywords are present, this is a very expenseive process
 | ||||||
|  | 
 | ||||||
|         Carbon::setLocale($entity->locale()); |         Carbon::setLocale($entity->locale()); | ||||||
| 
 | 
 | ||||||
|         $replacements = [ |         $replacements = [ | ||||||
|  | |||||||
| @ -264,7 +264,8 @@ trait MakesInvoiceValues | |||||||
|      * @return array |      * @return array | ||||||
|      */ |      */ | ||||||
|     public function transformLineItems($items, $table_type = '$product') :array |     public function transformLineItems($items, $table_type = '$product') :array | ||||||
|     { |     {   //$start = microtime(true);
 | ||||||
|  | 
 | ||||||
|         $entity = $this->client ? $this->client : $this->company; |         $entity = $this->client ? $this->client : $this->company; | ||||||
| 
 | 
 | ||||||
|         $data = []; |         $data = []; | ||||||
| @ -274,6 +275,8 @@ trait MakesInvoiceValues | |||||||
| 
 | 
 | ||||||
|         $locale_info = localeconv(); |         $locale_info = localeconv(); | ||||||
| 
 | 
 | ||||||
|  |         $entity_currency = $entity->currency(); | ||||||
|  | 
 | ||||||
|         foreach ($items as $key => $item) { |         foreach ($items as $key => $item) { | ||||||
|             if ($table_type == '$product' && $item->type_id != 1) { |             if ($table_type == '$product' && $item->type_id != 1) { | ||||||
|                 if ($item->type_id != 4 && $item->type_id != 6 && $item->type_id != 5) { |                 if ($item->type_id != 4 && $item->type_id != 6 && $item->type_id != 5) { | ||||||
| @ -297,13 +300,13 @@ trait MakesInvoiceValues | |||||||
|             $data[$key][$table_type.'.notes'] = Helpers::processReservedKeywords($item->notes, $entity); |             $data[$key][$table_type.'.notes'] = Helpers::processReservedKeywords($item->notes, $entity); | ||||||
|             $data[$key][$table_type.'.description'] = Helpers::processReservedKeywords($item->notes, $entity); |             $data[$key][$table_type.'.description'] = Helpers::processReservedKeywords($item->notes, $entity); | ||||||
| 
 | 
 | ||||||
|             $data[$key][$table_type.".{$_table_type}1"] = $helpers->formatCustomFieldValue($this->company->custom_fields, "{$_table_type}1", $item->custom_value1, $entity); |             $data[$key][$table_type.".{$_table_type}1"] = strlen($item->custom_value1) > 1 ? $helpers->formatCustomFieldValue($this->company->custom_fields, "{$_table_type}1", $item->custom_value1, $entity) : ''; | ||||||
|             $data[$key][$table_type.".{$_table_type}2"] = $helpers->formatCustomFieldValue($this->company->custom_fields, "{$_table_type}2", $item->custom_value2, $entity); |             $data[$key][$table_type.".{$_table_type}2"] = strlen($item->custom_value1) > 2 ? $helpers->formatCustomFieldValue($this->company->custom_fields, "{$_table_type}2", $item->custom_value2, $entity) : ''; | ||||||
|             $data[$key][$table_type.".{$_table_type}3"] = $helpers->formatCustomFieldValue($this->company->custom_fields, "{$_table_type}3", $item->custom_value3, $entity); |             $data[$key][$table_type.".{$_table_type}3"] = strlen($item->custom_value1) > 3 ? $helpers->formatCustomFieldValue($this->company->custom_fields, "{$_table_type}3", $item->custom_value3, $entity) : ''; | ||||||
|             $data[$key][$table_type.".{$_table_type}4"] = $helpers->formatCustomFieldValue($this->company->custom_fields, "{$_table_type}4", $item->custom_value4, $entity); |             $data[$key][$table_type.".{$_table_type}4"] = strlen($item->custom_value1) > 4 ? $helpers->formatCustomFieldValue($this->company->custom_fields, "{$_table_type}4", $item->custom_value4, $entity) : ''; | ||||||
| 
 | 
 | ||||||
|             if ($item->quantity > 0 || $item->cost > 0) { |             if ($item->quantity > 0 || $item->cost > 0) { | ||||||
|                 $data[$key][$table_type.'.quantity'] = Number::formatValueNoTrailingZeroes($item->quantity, $entity->currency()); |                 $data[$key][$table_type.'.quantity'] = Number::formatValueNoTrailingZeroes($item->quantity, $entity_currency); | ||||||
| 
 | 
 | ||||||
|                 $data[$key][$table_type.'.unit_cost'] = Number::formatMoneyNoRounding($item->cost, $entity); |                 $data[$key][$table_type.'.unit_cost'] = Number::formatMoneyNoRounding($item->cost, $entity); | ||||||
| 
 | 
 | ||||||
| @ -357,6 +360,8 @@ trait MakesInvoiceValues | |||||||
|             $data[$key]['task_id'] = property_exists($item, 'task_id') ? $item->task_id : ''; |             $data[$key]['task_id'] = property_exists($item, 'task_id') ? $item->task_id : ''; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         //nlog(microtime(true) - $start);
 | ||||||
|  |          | ||||||
|         return $data; |         return $data; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user