我在我的项目中使用了laravel,所以我想在他接受医生的任命时更改病人的状态,这样他就可以有3个satuts,accept,waiting(当病人选择日期和时间时自动进行),not accept,我面临的问题是当我单击active按钮时数据库中没有任何更改。
这是状态控制器:
public function changeStatus(Request $request)
{
$user = rdv::where('IDP', $request->input('IDP'))->get();
if (count($user) > 0) {
if ($user->Etat_de_rdv == en_attente) {
$user->Etat_de_rdv = Accepté;
} else {
$user->Etat_de_rdv = Reservé;
}
$user->Etat_de_rdv = $request->input('status');
$user->save();
return response()->json(['success' => 'Status change successfully.']);
}
}
以下是脚本:
<script>
$('.toggle-class').change(function () {
var status = $(this).prop('checked') == true ? 'Accepter' : 'Temps charger';
var id = $(this).data('IDP');
console.log(id);
console.log(status);
$.ajax({
type: "get",
headers: {
'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
},
url: 'changeStatus',
data: {
Etat_de_rdv: status, //Should be like this
IDP: id
},
success: function (data) {
console.log(data.success);
}
});
});
</script>
这是医生看到所有任命者的观点;
<h3> Vos patient :</h3>
@foreach($pat as $lo)
@if ($lo->IDD== $med->ID)
<div class="admin">
<div class="info">
<h3> {{ $lo->Nom_et_prénom }} </h3>
<p>{{ $lo->Numéro_de_téléphone }}</p>
<p>{{ $lo->date}}</p>
<p>{{ $lo->time }}</p>
<input data-id="{{$lo->IPD}}" class="toggle-class" type="checkbox" data-onstyle="success"
data-offstyle="danger" data-toggle="toggle" data-on="Accepter"
data-off="Temps charger" {{ $lo->Etat_de_rdv ? 'checked' : '' }}>
</div>
</div>
@endif
@endforeach
- rdv平均值:任命表*idp:患者id
1条答案
按热度按时间zzoitvuj1#
->get();
返回集合,而不是数组。因此,你应该使用$user->count() > 0
相反。编辑:
->get()
返回对象的集合。所以,你不能使用$user->Etat_de_rdv == en_attente
. 有两种方法可以解决这个问题。如果您确定idp条件总是返回单个项目,那么您最好使用
->first()
而不是->get()
你不需要改变内部的if条件。如果有多个用户,那么首先将变量重命名为$users,然后像这样循环
$foreach($users as $user) { // your current code... }