В настоящее время у меня есть отношение ownToMany между двумя таблицами, Skus
а также Medias
, Я назвал таблицу соединений skus_images, хотя.
Я пытаюсь сохранить только идентификаторы, а не вставлять новые данные способом HABTM.
Я имею в своей форме:
echo $this->Form->input('images._ids', ['options' => $images, 'multiple' => 'checkbox']);
И там все работает нормально, я правильно вывел свой Medias в список.
Но всякий раз, когда я пытаюсь отправить форму, я получаю это:
Error: Call to a member function get() on a non-object
File /home/weshguillaume/AndyToGaby/vendor/cakephp/cakephp/src/ORM/Association/BelongsToMany.php
Line: 874
Я определил мои отношения как таковые в SkusTable
:
$this->belongsToMany('Images', [
'className' => 'Media.Medias',
'joinTable' => 'skus_images',
'targetForeignKey' => 'image_id'
]);
Контекст не дает никакой информации, как и стек, так как он (почти) пуст. Спасибо 🙂
РЕДАКТИРОВАТЬ:
Метод добавления контроллера:
public function add($product_id)
{
$skus = $this->Skus->newEntity();
if ($this->request->is('post')) {
$skus = $this->Skus->patchEntity($skus, $this->request->data(), [
'associated' => [
'Attributes'
]
]);
if ($this->Skus->save($skus)) {
$this->Flash->success('The skus has been saved.');
return $this->redirect(['action' => 'index']);
} else {
$this->Flash->error('The skus could not be saved. Please, try again.');
}
}
$attributes = $this->Skus->Attributes->find('list');
$images = $this->Skus->Products->getMedias('list', $product_id, 'photo');
$this->set(compact('skus', 'products', 'attributes', 'images', 'product_id'));
$this->set('_serialize', ['skus']);
}
Контроллер разместил данные:
[
'product_id' => '65',
'attributes' => [
'_ids' => ''
],
'reference' => '',
'quantity' => '420',
'is_default' => '0',
'images' => [
'_ids' => [
(int) 0 => '90'
]
]
]
Забыл добавить название ассоциации в патче Entity associated
вариант. Тем не менее не следует выдавать фатальную ошибку, поэтому я создал билет GitHub.
Других решений пока нет …