Refactor the GenericTables class #51
@ -70,10 +70,8 @@ class ManageErrors extends HTMLController
 | 
				
			|||||||
				'time' => [
 | 
									'time' => [
 | 
				
			||||||
					'format' => [
 | 
										'format' => [
 | 
				
			||||||
						'type' => 'timestamp',
 | 
											'type' => 'timestamp',
 | 
				
			||||||
						'data' => [
 | 
											'pattern' => 'long',
 | 
				
			||||||
							'timestamp' => 'time',
 | 
											'value' => 'time',
 | 
				
			||||||
							'pattern' => 'long',
 | 
					 | 
				
			||||||
						],
 | 
					 | 
				
			||||||
					],
 | 
										],
 | 
				
			||||||
					'header' => 'Time',
 | 
										'header' => 'Time',
 | 
				
			||||||
					'is_sortable' => true,
 | 
										'is_sortable' => true,
 | 
				
			||||||
 | 
				
			|||||||
@ -60,10 +60,8 @@ class ManageUsers extends HTMLController
 | 
				
			|||||||
				'last_action_time' => [
 | 
									'last_action_time' => [
 | 
				
			||||||
					'format' => [
 | 
										'format' => [
 | 
				
			||||||
						'type' => 'timestamp',
 | 
											'type' => 'timestamp',
 | 
				
			||||||
						'data' => [
 | 
											'pattern' => 'long',
 | 
				
			||||||
							'timestamp' => 'last_action_time',
 | 
											'value' => 'last_action_time',
 | 
				
			||||||
							'pattern' => 'long',
 | 
					 | 
				
			||||||
						],
 | 
					 | 
				
			||||||
					],
 | 
										],
 | 
				
			||||||
					'header' => 'Last activity',
 | 
										'header' => 'Last activity',
 | 
				
			||||||
					'is_sortable' => true,
 | 
										'is_sortable' => true,
 | 
				
			||||||
 | 
				
			|||||||
@ -217,39 +217,30 @@ class GenericTable
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	private function processFormatting($options, $rowData)
 | 
						private function processFormatting($options, $rowData)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
		// Parse the basic value first.
 | 
							if ($options['type'] === 'timestamp')
 | 
				
			||||||
		switch ($options['type'])
 | 
					 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
			// Timestamps get custom treatment.
 | 
								if (empty($options['pattern']) || $options['pattern'] === 'long')
 | 
				
			||||||
			case 'timestamp':
 | 
									$pattern = 'Y-m-d H:i';
 | 
				
			||||||
				if (empty($options['data']['pattern']) || $options['data']['pattern'] === 'long')
 | 
								elseif ($options['pattern'] === 'short')
 | 
				
			||||||
					$pattern = 'Y-m-d H:i';
 | 
									$pattern = 'Y-m-d';
 | 
				
			||||||
				elseif ($options['data']['pattern'] === 'short')
 | 
								else
 | 
				
			||||||
					$pattern = 'Y-m-d';
 | 
									$pattern = $options['pattern'];
 | 
				
			||||||
				else
 | 
					 | 
				
			||||||
					$pattern = $options['data']['pattern'];
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
				if (!isset($rowData[$options['data']['timestamp']]))
 | 
								assert(isset($rowData[$options['value']]));
 | 
				
			||||||
					$timestamp = 0;
 | 
								if (!is_numeric($rowData[$options['value']]))
 | 
				
			||||||
				elseif (!is_numeric($rowData[$options['data']['timestamp']]))
 | 
									$timestamp = strtotime($rowData[$options['value']]);
 | 
				
			||||||
					$timestamp = strtotime($rowData[$options['data']['timestamp']]);
 | 
								else
 | 
				
			||||||
				else
 | 
									$timestamp = (int) $rowData[$options['value']];
 | 
				
			||||||
					$timestamp = (int) $rowData[$options['data']['timestamp']];
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
				if (isset($options['data']['if_null']) && $timestamp == 0)
 | 
								if (isset($options['if_null']) && $timestamp == 0)
 | 
				
			||||||
					$value = $options['data']['if_null'];
 | 
									$value = $options['if_null'];
 | 
				
			||||||
				else
 | 
								else
 | 
				
			||||||
					$value = date($pattern, $timestamp);
 | 
									$value = date($pattern, $timestamp);
 | 
				
			||||||
				break;
 | 
					
 | 
				
			||||||
 | 
								return $value;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
							else
 | 
				
			||||||
		// TODO: deprecated
 | 
								throw ValueError('Unexpected formatter type: ' . $options['type']);
 | 
				
			||||||
		if (!empty($options['link']))
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
			$value = $this->processLink($options['link'], $value, $rowData);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		return $value;
 | 
					 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	private function processLink($template, $value, array $rowData)
 | 
						private function processLink($template, $value, array $rowData)
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user