Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
49 changes: 32 additions & 17 deletions app/Livewire/Conducting/StudySelection/PaperModal.php
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ class PaperModal extends Component
public $criterias;

public $selected_criterias = [];
public $temp_selected_criterias = [];

public $selected_status = "None";
public $note;
Expand Down Expand Up @@ -59,14 +60,16 @@ public function showPaper($paper, $criterias)

// Buscar o membro específico para o projeto atual
$member = Member::where('id_user', auth()->user()->id)
->where('id_project', $this->projectId) // Certificar-se de que o membro pertence ao projeto atual
->where('id_project', $this->projectId)
->first();

//carregar todos os critérios de uma vez
$this->selected_criterias = EvaluationCriteria::where('id_paper', $this->paper['id_paper'])
->where('id_member', $member->id_members)
->pluck('id_criteria')
->toArray();

$this->temp_selected_criterias = $this->selected_criterias;

//status selecionado com base no status salvo no banco de dados
$this->selected_status = $this->paper['status_description'];
Expand Down Expand Up @@ -155,35 +158,47 @@ public function saveNote()
$this->dispatch('refreshPaperStatus');
}

public function changePreSelected($criteriaId, $type)
public function saveSelectedCriterias()
{
// Buscar o membro específico para o projeto atual
$member = Member::where('id_user', auth()->user()->id)
->where('id_project', $this->projectId) // Certificar-se de que o membro pertence ao projeto atual
->where('id_project', $this->projectId)
->first();
$isSelected = in_array($criteriaId, $this->selected_criterias);

if ($isSelected) {
// Encontrar critérios que foram desmarcados
$removedCriterias = array_diff($this->selected_criterias, $this->temp_selected_criterias);

// Encontrar critérios que foram marcados
$addedCriterias = array_diff($this->temp_selected_criterias, $this->selected_criterias);

// Remover critérios desmarcados
foreach ($removedCriterias as $criteriaId) {
EvaluationCriteria::where('id_paper', $this->paper['id_paper'])
->where('id_criteria', $criteriaId)
->where('id_member', $member->id_members)
->delete();
}

// Adicionar novos critérios marcados
foreach ($addedCriterias as $criteriaId) {
EvaluationCriteria::create([
'id_paper' => $this->paper['id_paper'],
'id_criteria' => $criteriaId,
'id_member' => $member->id_members,
]);
} else {
EvaluationCriteria::where('id_paper', $this->paper['id_paper'])
->where('id_criteria', $criteriaId)
->where('id_member', $member->id_members)
->delete();
}

$this->updatePaperStatus($type);
session()->forget('successMessage');
session()->flash('successMessage', __("project/conducting.study-selection.messages.criteria_updated", ['status' => $this->getPaperStatusDescription($this->paper['status_selection'])]));
// Atualizar selected_criterias com os valores temporários
$this->selected_criterias = $this->temp_selected_criterias;

// Atualizar o status do paper
$criteria = Criteria::find(reset($addedCriterias));
if ($criteria) {
$this->updatePaperStatus($criteria->type);
}

// Atualiza a view para mostrar o alert
$message = 'Nota salva com sucesso.';
session()->flash('successMessage', $message);
$this->dispatch('show-success',$message);
session()->flash('successMessage', 'Critérios salvos com sucesso');
$this->dispatch('show-success');
$this->dispatch('refreshPaperStatus');
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -71,10 +71,10 @@
<td class="w-5 align-middle text-center">
<input type="checkbox" id="criteria-{{ $criteria['id_criteria'] }}"
wire:key="criteria-{{ $criteria['id_criteria'] }}"
wire:model.defer="selected_criterias"
wire:model="temp_selected_criterias"
value="{{ $criteria['id_criteria'] }}"
@if(in_array($criteria['id_criteria'], $selected_criterias)) checked @endif
@if(!$canEdit) disabled @endif
@if(in_array($criteria['id_criteria'], $temp_selected_criterias)) checked @endif

>
</td>
<td class="w-5 align-middle text-center">{{ $criteria['id'] }}</td>
Expand All @@ -85,6 +85,11 @@
@endforeach
</tbody>
</table>
<div class="text-end mb-3">
<button wire:click="saveSelectedCriterias" class="btn btn-primary">
<i class="fas fa-save"></i> Salvar Critérios
</button>
</div>
<hr />

<div class="d-flex flex-column mt-3">
Expand Down
Loading