How do I reload a repeater item after one of its fields have been updated?

I have a repeater in my form to add questionnaires to an event. Newly added items don't get persisted until one of the fields in the row is updated. Upon update, a round trip is made to the api of the remote data store and the record is created, and returned. This in turn is then added to the local database, and is working as expected. My problem is now injecting the record ID (and any other properties that might have come back from the api request) into the repeater item. Should I be reloading the relationship manually or refreshing the component? Or is this a sign that my model isn't correctly bound to the component? Code to follow...
1 Reply
charliefortune
charliefortuneOP17mo ago
public function mount(int $eventId): void
{
$this->event = Event::find($eventId);
$this->form->fill([
'event_id' => $this->event->id,
'eventQuestionnaires' => $this->event->eventQuestionnaires,
]);
}
public function mount(int $eventId): void
{
$this->event = Event::find($eventId);
$this->form->fill([
'event_id' => $this->event->id,
'eventQuestionnaires' => $this->event->eventQuestionnaires,
]);
}
Repeater::make('eventQuestionnaires')
->relationship()
->schema([
Select::make('questionnaire_id')
->options($this->event->clientAccount->questionnaires()->pluck('title', 'id'))
->afterStateUpdated(function (?EventQuestionnaire $record, Select $component, $state) {
if(!$record){
//Prepare data for INSERT
$data['questionnaire_id'] = $state;
$data['event_id'] = $this->event->id;
$state = $data;
}
$record = $this->upsert($record, $component->getName(), $state, 'EventQuestionnaire');
}),

Select::make('feedback_report_phase_id')
->options(FeedbackReportPhase::all()->sortBy('sort')->pluck('title', 'id'))
->lazy()
->afterStateUpdated(function (?EventQuestionnaire $record, Select $component, $state) {
if(!$record){
//Prepare data for INSERT
$data['feedback_report_phase_id'] = $state;
$data['event_id'] = $this->event->id;
$state = $data;
}
$record = $this->upsert($record, $component->getName(), $state, 'EventQuestionnaire');
}),
])
])
Repeater::make('eventQuestionnaires')
->relationship()
->schema([
Select::make('questionnaire_id')
->options($this->event->clientAccount->questionnaires()->pluck('title', 'id'))
->afterStateUpdated(function (?EventQuestionnaire $record, Select $component, $state) {
if(!$record){
//Prepare data for INSERT
$data['questionnaire_id'] = $state;
$data['event_id'] = $this->event->id;
$state = $data;
}
$record = $this->upsert($record, $component->getName(), $state, 'EventQuestionnaire');
}),

Select::make('feedback_report_phase_id')
->options(FeedbackReportPhase::all()->sortBy('sort')->pluck('title', 'id'))
->lazy()
->afterStateUpdated(function (?EventQuestionnaire $record, Select $component, $state) {
if(!$record){
//Prepare data for INSERT
$data['feedback_report_phase_id'] = $state;
$data['event_id'] = $this->event->id;
$state = $data;
}
$record = $this->upsert($record, $component->getName(), $state, 'EventQuestionnaire');
}),
])
])

Did you find this page helpful?