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];
 | 
						|
    }
 | 
						|
}
 | 
						|
 |