datatable.directory codebase
				https://datatable.directory/
			
			
		
			You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							81 lines
						
					
					
						
							2.1 KiB
						
					
					
				
			
		
		
	
	
							81 lines
						
					
					
						
							2.1 KiB
						
					
					
				| <?php
 | |
| 
 | |
| namespace App\Models;
 | |
| 
 | |
| /**
 | |
|  * Row in a data table
 | |
|  *
 | |
|  * @property int $id
 | |
|  * @property object|\RowData $data - JSONB, always containing _id
 | |
|  */
 | |
| class Row extends BaseModel
 | |
| {
 | |
|     protected $casts = [
 | |
|         'data' => 'object',
 | |
|     ];
 | |
| 
 | |
|     protected $guarded = [];
 | |
|     public $timestamps = false;
 | |
| 
 | |
|     public function getRowIdAttribute() {
 | |
|         return $this->data->_id;
 | |
|     }
 | |
| 
 | |
|     public function setRowIdAttribute($value) {
 | |
|         $this->data->_id = $value;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Allocate a single Global Row ID, application-unique.
 | |
|      *
 | |
|      * GRIDs are used to uniquely identify existing or proposed new rows,
 | |
|      * and are preserved after row modifications, to ensure change proposals have
 | |
|      * a clear target.
 | |
|      *
 | |
|      * @return int
 | |
|      */
 | |
|     public static function allocateRowID()
 | |
|     {
 | |
|         return \DB::selectOne("SELECT nextval('global_row_id_seq') AS rid;")->rid;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Allocate a block of Global Row IDs, application-unique.
 | |
|      *
 | |
|      * @see Row::allocateRowID()
 | |
|      *
 | |
|      * @return int[] first and last
 | |
|      */
 | |
|     public static function allocateRowIDs($count)
 | |
|     {
 | |
|         $last = \DB::selectOne("SELECT multi_nextval('global_row_id_seq', ?) AS last_id;", [$count])->last_id;
 | |
|         return [$last - $count + 1, $last];
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Allocate a single Global Column ID, application-unique.
 | |
|      *
 | |
|      * GCIDs are used to uniquely identify existing or proposed new columns,
 | |
|      * and are preserved after column modifications, to ensure change proposals have
 | |
|      * a clear target. This is the column equivalent of GRID.
 | |
|      *
 | |
|      * @return int
 | |
|      */
 | |
|     public static function allocateColID()
 | |
|     {
 | |
|         return \DB::selectOne("SELECT nextval('global_column_id_seq') AS cid;")->cid;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Allocate a block of Global Column IDs, application-unique.
 | |
|      *
 | |
|      * @see Row::allocateColID()
 | |
|      *
 | |
|      * @return int[] first and last
 | |
|      */
 | |
|     public static function allocateColIDs($count)
 | |
|     {
 | |
|         $last = \DB::selectOne("SELECT multi_nextval('global_column_id_seq', ?) AS last_id;", [$count])->last_id;
 | |
|         return [$last - $count + 1, $last];
 | |
|     }
 | |
| }
 | |
| 
 |