added sync method to has_many relationship.
This commit is contained in:
parent
3518f68633
commit
df70987679
|
@ -12,6 +12,40 @@ public function results()
|
|||
return parent::get();
|
||||
}
|
||||
|
||||
/**
|
||||
* Sync the association table with an array of models.
|
||||
*
|
||||
* @param array $models
|
||||
* @return bool
|
||||
*/
|
||||
public function sync(array $models)
|
||||
{
|
||||
$current = $this->table->lists($this->model->key());
|
||||
|
||||
// When syncing the has many relationship, we'll just spin the attributes and
|
||||
// create a fresh model instances for each row. If the "id" is set on the
|
||||
// array of attributes, we'll set the exists flag to true for update.
|
||||
foreach ($models as $attributes)
|
||||
{
|
||||
$attributes[$this->foreign_key()] = $this->base->get_key();
|
||||
|
||||
$model = $this->fresh_model($attributes);
|
||||
|
||||
$id = $model->get_key();
|
||||
|
||||
$model->exists = ( ! is_null($id) and in_array($id, $current));
|
||||
|
||||
// Before saving we'll force the entire model to be "dirty" so all of
|
||||
// the attributes are saved. It shouldn't affect the updates as
|
||||
// saving all the attributes shouldn't hurt anything.
|
||||
$model->original = array();
|
||||
|
||||
$model->save();
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Initialize a relationship on an array of parent models.
|
||||
*
|
||||
|
|
Loading…
Reference in New Issue