115 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			115 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\View\Components\Table;
 | |
| 
 | |
| use App\Abstracts\View\Component;
 | |
| 
 | |
| class Actions extends Component
 | |
| {
 | |
|     public $model;
 | |
| 
 | |
|     /** @var array */
 | |
|     public $actions;
 | |
| 
 | |
|     /**
 | |
|      * Create a new component instance.
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function __construct(
 | |
|         $model = false,
 | |
|         array $actions = []
 | |
|     ) {
 | |
|         $this->model = $model;
 | |
|         $this->actions = $this->getActions($actions);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the view / contents that represent the component.
 | |
|      *
 | |
|      * @return \Illuminate\Contracts\View\View|string
 | |
|      */
 | |
|     public function render()
 | |
|     {
 | |
|         return view('components.table.actions');
 | |
|     }
 | |
| 
 | |
|     protected function getActions($actions)
 | |
|     {
 | |
|         if (empty($actions)) {
 | |
|             $actions = [];
 | |
| 
 | |
|             if ($this->model && ! empty($this->model->line_actions)) {
 | |
|                 $actions = $this->model->line_actions;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         foreach ($actions as $key => $action) {
 | |
|             $attributes = [];
 | |
| 
 | |
|             if (! empty($action['attributes'])) {
 | |
|                 $attributes = $action['attributes'];
 | |
|             }
 | |
| 
 | |
|             $actions[$key]['attributes'] = $this->getAttributes($attributes);
 | |
|         }
 | |
| 
 | |
|         return $actions;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Build an HTML attribute string from an array.
 | |
|      *
 | |
|      * @param array $attributes
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     public function getAttributes($attributes)
 | |
|     {
 | |
|         $html = [];
 | |
| 
 | |
|         foreach ((array) $attributes as $key => $value) {
 | |
|             $element = $this->attributeElement($key, $value);
 | |
| 
 | |
|             if (! is_null($element)) {
 | |
|                 $html[] = $element;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         return count($html) > 0 ? ' ' . implode(' ', $html) : '';
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Build a single attribute element.
 | |
|      *
 | |
|      * @param string $key
 | |
|      * @param string $value
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     protected function attributeElement($key, $value)
 | |
|     {
 | |
|         // For numeric keys we will assume that the value is a boolean attribute
 | |
|         // where the presence of the attribute represents a true value and the
 | |
|         // absence represents a false value.
 | |
|         // This will convert HTML attributes such as "required" to a correct
 | |
|         // form instead of using incorrect numerics.
 | |
|         if (is_numeric($key)) {
 | |
|             return $value;
 | |
|         }
 | |
| 
 | |
|         // Treat boolean attributes as HTML properties
 | |
|         if (is_bool($value) && $key !== 'value') {
 | |
|             return $value ? $key : '';
 | |
|         }
 | |
| 
 | |
|         if (is_array($value) && $key === 'class') {
 | |
|             return 'class=' . implode(' ', $value);
 | |
|         }
 | |
| 
 | |
|         if (! is_null($value)) {
 | |
|             return $key . '=' . e($value, false);
 | |
|         }
 | |
|     }
 | |
| }
 |