125 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			125 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace Illuminate\Database\Eloquent\Concerns;
 | |
| 
 | |
| trait HidesAttributes
 | |
| {
 | |
|     /**
 | |
|      * The attributes that should be hidden for serialization.
 | |
|      *
 | |
|      * @var array<string>
 | |
|      */
 | |
|     protected $hidden = [];
 | |
| 
 | |
|     /**
 | |
|      * The attributes that should be visible in serialization.
 | |
|      *
 | |
|      * @var array<string>
 | |
|      */
 | |
|     protected $visible = [];
 | |
| 
 | |
|     /**
 | |
|      * Get the hidden attributes for the model.
 | |
|      *
 | |
|      * @return array<string>
 | |
|      */
 | |
|     public function getHidden()
 | |
|     {
 | |
|         return $this->hidden;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set the hidden attributes for the model.
 | |
|      *
 | |
|      * @param  array<string>  $hidden
 | |
|      * @return $this
 | |
|      */
 | |
|     public function setHidden(array $hidden)
 | |
|     {
 | |
|         $this->hidden = $hidden;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the visible attributes for the model.
 | |
|      *
 | |
|      * @return array<string>
 | |
|      */
 | |
|     public function getVisible()
 | |
|     {
 | |
|         return $this->visible;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set the visible attributes for the model.
 | |
|      *
 | |
|      * @param  array<string>  $visible
 | |
|      * @return $this
 | |
|      */
 | |
|     public function setVisible(array $visible)
 | |
|     {
 | |
|         $this->visible = $visible;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Make the given, typically hidden, attributes visible.
 | |
|      *
 | |
|      * @param  array<string>|string|null  $attributes
 | |
|      * @return $this
 | |
|      */
 | |
|     public function makeVisible($attributes)
 | |
|     {
 | |
|         $attributes = is_array($attributes) ? $attributes : func_get_args();
 | |
| 
 | |
|         $this->hidden = array_diff($this->hidden, $attributes);
 | |
| 
 | |
|         if (! empty($this->visible)) {
 | |
|             $this->visible = array_merge($this->visible, $attributes);
 | |
|         }
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Make the given, typically hidden, attributes visible if the given truth test passes.
 | |
|      *
 | |
|      * @param  bool|\Closure  $condition
 | |
|      * @param  array<string>|string|null  $attributes
 | |
|      * @return $this
 | |
|      */
 | |
|     public function makeVisibleIf($condition, $attributes)
 | |
|     {
 | |
|         return value($condition, $this) ? $this->makeVisible($attributes) : $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Make the given, typically visible, attributes hidden.
 | |
|      *
 | |
|      * @param  array<string>|string|null  $attributes
 | |
|      * @return $this
 | |
|      */
 | |
|     public function makeHidden($attributes)
 | |
|     {
 | |
|         $this->hidden = array_merge(
 | |
|             $this->hidden, is_array($attributes) ? $attributes : func_get_args()
 | |
|         );
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Make the given, typically visible, attributes hidden if the given truth test passes.
 | |
|      *
 | |
|      * @param  bool|\Closure  $condition
 | |
|      * @param  array<string>|string|null  $attributes
 | |
|      * @return $this
 | |
|      */
 | |
|     public function makeHiddenIf($condition, $attributes)
 | |
|     {
 | |
|         return value($condition, $this) ? $this->makeHidden($attributes) : $this;
 | |
|     }
 | |
| }
 |