forked from Public/pics
		
	Refactor processing of raw rows and their cell data.
This commit is contained in:
		
							parent
							
								
									6c662481bc
								
							
						
					
					
						commit
						ff808ba18d
					
				@ -57,8 +57,8 @@ class GenericTable
 | 
				
			|||||||
		// Okay, let's fetch the data!
 | 
							// Okay, let's fetch the data!
 | 
				
			||||||
		$data = $options['get_data'](...$parameters);
 | 
							$data = $options['get_data'](...$parameters);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		// Clean up a bit.
 | 
							// Extract data into local variables.
 | 
				
			||||||
		$rows = $data['rows'];
 | 
							$rawRowData = $data['rows'];
 | 
				
			||||||
		$this->sort_order = $data['order'];
 | 
							$this->sort_order = $data['order'];
 | 
				
			||||||
		$this->sort_direction = $data['direction'];
 | 
							$this->sort_direction = $data['direction'];
 | 
				
			||||||
		unset($data);
 | 
							unset($data);
 | 
				
			||||||
@ -71,12 +71,11 @@ class GenericTable
 | 
				
			|||||||
		if ($needsPageIndex)
 | 
							if ($needsPageIndex)
 | 
				
			||||||
			$this->generatePageIndex($options);
 | 
								$this->generatePageIndex($options);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		// Not a single row in sight?
 | 
							// Process the data to be shown into rows.
 | 
				
			||||||
		if (empty($rows))
 | 
							if (!empty($rawRowData))
 | 
				
			||||||
			$this->body = $options['no_items_label'] ?? '';
 | 
								$this->processAllRows($rawRowData, $options);
 | 
				
			||||||
		// Otherwise, parse it all!
 | 
					 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			$this->parseAllRows($rows, $options);
 | 
								$this->body = $options['no_items_label'] ?? '';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		// Got a title?
 | 
							// Got a title?
 | 
				
			||||||
		$this->title = $options['title'] ?? '';
 | 
							$this->title = $options['title'] ?? '';
 | 
				
			||||||
@ -122,92 +121,6 @@ class GenericTable
 | 
				
			|||||||
		]);
 | 
							]);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	private function parseAllRows($rows, $options)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
		foreach ($rows as $i => $row)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
			$newRow = [
 | 
					 | 
				
			||||||
				'cells' => [],
 | 
					 | 
				
			||||||
			];
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			foreach ($options['columns'] as $column)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
				// The hard way?
 | 
					 | 
				
			||||||
				if (isset($column['parse']))
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
					if (!isset($column['parse']['type']))
 | 
					 | 
				
			||||||
						$column['parse']['type'] = 'value';
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
					// Parse the basic value first.
 | 
					 | 
				
			||||||
					switch ($column['parse']['type'])
 | 
					 | 
				
			||||||
					{
 | 
					 | 
				
			||||||
						// value: easy as pie.
 | 
					 | 
				
			||||||
						default:
 | 
					 | 
				
			||||||
						case 'value':
 | 
					 | 
				
			||||||
							$value = $row[$column['parse']['data']];
 | 
					 | 
				
			||||||
							break;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
						// sprintf: filling the gaps!
 | 
					 | 
				
			||||||
						case 'sprintf':
 | 
					 | 
				
			||||||
							$parameters = [$column['parse']['data']['pattern']];
 | 
					 | 
				
			||||||
							foreach ($column['parse']['data']['arguments'] as $identifier)
 | 
					 | 
				
			||||||
								$parameters[] = $row[$identifier];
 | 
					 | 
				
			||||||
							$value = sprintf(...$parameters);
 | 
					 | 
				
			||||||
							break;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
						// timestamps: let's make them readable!
 | 
					 | 
				
			||||||
						case 'timestamp':
 | 
					 | 
				
			||||||
							if (empty($column['parse']['data']['pattern']) || $column['parse']['data']['pattern'] === 'long')
 | 
					 | 
				
			||||||
								$pattern = '%F %H:%M';
 | 
					 | 
				
			||||||
							elseif ($column['parse']['data']['pattern'] === 'short')
 | 
					 | 
				
			||||||
								$pattern = '%F';
 | 
					 | 
				
			||||||
							else
 | 
					 | 
				
			||||||
								$pattern = $column['parse']['data']['pattern'];
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
							if (!is_numeric($row[$column['parse']['data']['timestamp']]))
 | 
					 | 
				
			||||||
								$timestamp = strtotime($row[$column['parse']['data']['timestamp']]);
 | 
					 | 
				
			||||||
							else
 | 
					 | 
				
			||||||
								$timestamp = (int) $row[$column['parse']['data']['timestamp']];
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
							if (isset($column['parse']['data']['if_null']) && $timestamp == 0)
 | 
					 | 
				
			||||||
								$value = $column['parse']['data']['if_null'];
 | 
					 | 
				
			||||||
							else
 | 
					 | 
				
			||||||
								$value = strftime($pattern, $timestamp);
 | 
					 | 
				
			||||||
							break;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
						// function: the flexible way!
 | 
					 | 
				
			||||||
						case 'function':
 | 
					 | 
				
			||||||
							$value = $column['parse']['data']($row);
 | 
					 | 
				
			||||||
							break;
 | 
					 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
					// Generate a link, if requested.
 | 
					 | 
				
			||||||
					if (!empty($column['parse']['link']))
 | 
					 | 
				
			||||||
					{
 | 
					 | 
				
			||||||
						// First, generate the replacement variables.
 | 
					 | 
				
			||||||
						$keys = array_keys($row);
 | 
					 | 
				
			||||||
						$values = array_values($row);
 | 
					 | 
				
			||||||
						foreach ($keys as $keyKey => $keyValue)
 | 
					 | 
				
			||||||
							$keys[$keyKey] = '{' . strtoupper($keyValue) . '}';
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
						$value = '<a href="' . str_replace($keys, $values, $column['parse']['link']) . '">' . $value . '</a>';
 | 
					 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
				// The easy way!
 | 
					 | 
				
			||||||
				else
 | 
					 | 
				
			||||||
					$value = $row[$column['value']];
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
				// Append the cell to the row.
 | 
					 | 
				
			||||||
				$newRow['cells'][] = [
 | 
					 | 
				
			||||||
					'value' => $value,
 | 
					 | 
				
			||||||
				];
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			// Append the new row in the body.
 | 
					 | 
				
			||||||
			$this->body[] = $newRow;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	public function getLink($start = null, $order = null, $dir = null)
 | 
						public function getLink($start = null, $order = null, $dir = null)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
		if ($start === null)
 | 
							if ($start === null)
 | 
				
			||||||
@ -254,4 +167,94 @@ class GenericTable
 | 
				
			|||||||
	{
 | 
						{
 | 
				
			||||||
		return $this->title_class;
 | 
							return $this->title_class;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						private function processAllRows($rows, $options)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							foreach ($rows as $i => $row)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								$newRow = [
 | 
				
			||||||
 | 
									'cells' => [],
 | 
				
			||||||
 | 
								];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								foreach ($options['columns'] as $column)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
									// Process data for this particular cell.
 | 
				
			||||||
 | 
									if (isset($column['parse']))
 | 
				
			||||||
 | 
										$value = self::processCell($column['parse'], $row);
 | 
				
			||||||
 | 
									else
 | 
				
			||||||
 | 
										$value = $row[$column['value']];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									// Append the cell to the row.
 | 
				
			||||||
 | 
									$newRow['cells'][] = [
 | 
				
			||||||
 | 
										'value' => $value,
 | 
				
			||||||
 | 
									];
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								// Append the new row in the body.
 | 
				
			||||||
 | 
								$this->body[] = $newRow;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						private function processCell($options, $rowData)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							if (!isset($options['type']))
 | 
				
			||||||
 | 
								$options['type'] = 'value';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							// Parse the basic value first.
 | 
				
			||||||
 | 
							switch ($options['type'])
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								// Basic option: simply take a use a particular data property.
 | 
				
			||||||
 | 
								case 'value':
 | 
				
			||||||
 | 
									$value = $rowData[$options['data']];
 | 
				
			||||||
 | 
									break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								// Processing via a lambda function.
 | 
				
			||||||
 | 
								case 'function':
 | 
				
			||||||
 | 
									$value = $options['data']($rowData);
 | 
				
			||||||
 | 
									break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								// Using sprintf to fill out a particular pattern.
 | 
				
			||||||
 | 
								case 'sprintf':
 | 
				
			||||||
 | 
									$parameters = [$options['data']['pattern']];
 | 
				
			||||||
 | 
									foreach ($options['data']['arguments'] as $identifier)
 | 
				
			||||||
 | 
										$parameters[] = $rowData[$identifier];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									$value = sprintf(...$parameters);
 | 
				
			||||||
 | 
									break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								// Timestamps get custom treatment.
 | 
				
			||||||
 | 
								case 'timestamp':
 | 
				
			||||||
 | 
									if (empty($options['data']['pattern']) || $options['data']['pattern'] === 'long')
 | 
				
			||||||
 | 
										$pattern = '%F %H:%M';
 | 
				
			||||||
 | 
									elseif ($options['data']['pattern'] === 'short')
 | 
				
			||||||
 | 
										$pattern = '%F';
 | 
				
			||||||
 | 
									else
 | 
				
			||||||
 | 
										$pattern = $options['data']['pattern'];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									if (!is_numeric($rowData[$options['data']['timestamp']]))
 | 
				
			||||||
 | 
										$timestamp = strtotime($rowData[$options['data']['timestamp']]);
 | 
				
			||||||
 | 
									else
 | 
				
			||||||
 | 
										$timestamp = (int) $rowData[$options['data']['timestamp']];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									if (isset($options['data']['if_null']) && $timestamp == 0)
 | 
				
			||||||
 | 
										$value = $options['data']['if_null'];
 | 
				
			||||||
 | 
									else
 | 
				
			||||||
 | 
										$value = strftime($pattern, $timestamp);
 | 
				
			||||||
 | 
									break;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							// Generate a link, if requested.
 | 
				
			||||||
 | 
							if (!empty($options['link']))
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								// First, generate the replacement variables.
 | 
				
			||||||
 | 
								$keys = array_keys($rowData);
 | 
				
			||||||
 | 
								$values = array_values($rowData);
 | 
				
			||||||
 | 
								foreach ($keys as $keyKey => $keyValue)
 | 
				
			||||||
 | 
									$keys[$keyKey] = '{' . strtoupper($keyValue) . '}';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								$value = '<a href="' . str_replace($keys, $values, $options['link']) . '">' . $value . '</a>';
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							return $value;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user