mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-26 05:22:51 -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 ''; | ||||
|         } | ||||
| 
 | ||||
|         // 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()); | ||||
| 
 | ||||
|         $replacements = [ | ||||
|  | ||||
| @ -264,7 +264,8 @@ trait MakesInvoiceValues | ||||
|      * @return array | ||||
|      */ | ||||
|     public function transformLineItems($items, $table_type = '$product') :array | ||||
|     { | ||||
|     {   //$start = microtime(true);
 | ||||
| 
 | ||||
|         $entity = $this->client ? $this->client : $this->company; | ||||
| 
 | ||||
|         $data = []; | ||||
| @ -274,6 +275,8 @@ trait MakesInvoiceValues | ||||
| 
 | ||||
|         $locale_info = localeconv(); | ||||
| 
 | ||||
|         $entity_currency = $entity->currency(); | ||||
| 
 | ||||
|         foreach ($items as $key => $item) { | ||||
|             if ($table_type == '$product' && $item->type_id != 1) { | ||||
|                 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.'.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}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}4"] = $helpers->formatCustomFieldValue($this->company->custom_fields, "{$_table_type}4", $item->custom_value4, $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"] = 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"] = 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"] = 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) { | ||||
|                 $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); | ||||
| 
 | ||||
| @ -357,6 +360,8 @@ trait MakesInvoiceValues | ||||
|             $data[$key]['task_id'] = property_exists($item, 'task_id') ? $item->task_id : ''; | ||||
|         } | ||||
| 
 | ||||
|         //nlog(microtime(true) - $start);
 | ||||
|          | ||||
|         return $data; | ||||
|     } | ||||
| 
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user