Я делаю систему управления врачом.У меня есть три поля формы department
, doctor
и doctor_time
.Используя AJAX, я могу получить имя доктора по департаментам, затем, когда я выберу имя доктора, я получу Дату этого доктора, но снова, если я поменяю имя доктора, я все равно получу дату старого доктора.В консоли массив дат врачей отображается правильно, но в HTML datepicker
он не обновляется со сменой доктора.
VIEW
<!-- DOCTIRS DEPARTMENT -->
<div class="col-md-6">
<div class="form-group">
<label>DEPARTMENT</label>
<select class="form-control" id="docdept" name="deptid">
<option selected value="">SELECT FROM BELOW</option>
<?php foreach($depts as $dept) : ?>
<option value="<?php echo $dept['id'] ?>"><?php echo $dept['name'] ?></option>
<?php endforeach; ?>
</select>
</div>
</div>
<!-- DEPARTMENT WISE DATA FETCHING OF DOCTOR -->
<div class="col-6">
<div class="form-group">
<label>DOCTOR's Name</label>
<select class="form-control" id="docname" name="doctorid" disabled>
<option selected disabled>SELECT FROM BELOW</option>
</select>
</div>
</div>
<!-- DEPARTMENT WISE DOCTOR'S TIME FETCHING -->
<div class="col-6">
<div class="form-group">
<label>DOCTOR Timings</label>
<input type="text" id="doctortime" class="form-control doctortime" placeholder="Doctor Date" name="dates" data-date-format="mm/dd/yyyy" readonly />
</div>
</div>
JQuery
$(document).ready(function(){
// Get The doctor Name department wise
$('#docdept').on('change',function(){
var docdept_id = $(this).val();
// console.log(docdept_id);
if(docdept_id == ''){
$('#docname').prop('disabled',true);
$('#doctortime').prop('readonly',true);
}else{
$('#docname').prop('disabled',false);
// Ajax codeing start
$.ajax({
url:'http://localhost/doctor/admin/Bookings_controller/get_docname',
type:"POST",
data: {'docdept_id' : docdept_id},
dataType:'json',
success:function(data){
$('#docname').html(data.docbox);
// $('#doctortime').val(data.doctime);
},
error:function(){
alert('error is there');
}
});
}
});
//Get the Time of doctor doctor name wise
$('#docname').on('change',function(){
var docname_id = $(this).val();
console.log(docname_id);
if(docname_id == ''){
$('#doctortime').prop('readonly',true);
}else{
$('#doctortime').prop('readonly',false);
// Ajax codeing start
$.ajax({
url:"http://localhost/doctor/admin/Bookings_controller/get_doctime",
type:"POST",
data: {'docname_id' : docname_id},
dataType:'json',
success:function(data){
// alert(data.doctime);
// console.log(data.doctime);
var onlyThisDates = data.doctime.split(",");
console.log(onlyThisDates);
$('#doctortime').datepicker({
format: "mm/dd/yyyy",
autoclose: true,
beforeShowDay: function (date) {
var dt_ddmmyyyy = ('0' + (date.getMonth() + 1)).slice(-2) + '/' + ('0' + date.getDate()).slice(-2) + '/' + date.getFullYear();
return (onlyThisDates.indexOf(dt_ddmmyyyy) != -1);
}
});
},
error:function(){
alert('error is there');
}
});
}
});
});
Контроллер
public function doctor(){
$data['subview'] = 'admin/doctor_view';
$data['depts'] = $this->Doctors_model->get_dept();
$this->load->view('admin_layout',$data);
}
//Get Doctor name by selecting doctor department
public function get_docname(){
$docdept_id = $this->input->post('docdept_id');
$docs = $this->Doctors_model->get_docname_query($docdept_id);
if(count($docs) > 0){
// For The Doctor Name Get Department Wise
$docbox = "";
$docbox .='<option>Select Doctor from below</option>';
foreach($docs as $doc){
$docbox .='<option value="'.$doc['id'].'">'.$doc['name'].'</option>';
}
echo json_encode(array('docbox' => $docbox));
}
}
// Get the times by doctor name wise
public function get_doctime(){
$docname_id = $this->input->post('docname_id');
$times = $this->Doctors_model->get_doctime_query($docname_id);
if(count($times) > 0){
// For The Doctor Name Wise Time Get
$doctime = "";
$doctime .= $times['dates'];
echo json_encode(array('doctime' => $doctime));
}
}
МОДЕЛЬ
//get doctor By department
public function get_docname_query($docdept_id){
$this->db->select('doctors.*,department.id as deptid,department.name as deptname');
//joining The Department Table
$this->db->join('department','department.id = doctors.specialisation','left');
$query = $this->db->get_where('doctors',array('doctors.specialisation' => $docdept_id));
return $query->result_array();
}
//GET DOCTOR TIME
public function get_doctime_query($docname_id){
$query= $this->db->get_where('doctors', array('id' => $docname_id));
return $query->row_array();
}
В базе данных у меня естьдва стола department
и doctors
.department
таблица имеет id
, name
.doctors
таблица имеет id
, doc_name
, timing
.
Я использую Codeigniter.Я могу получить имя доктора, выбрав отдел и изменив отдел, имена врачей также меняются, но когда я пытаюсь получить дату, выбирая имя доктора, оно отображается правильно, но если я меняю имя доктора, то я 'Я не могу просмотреть измененную дату врачей.
Пожалуйста, дайте мне знать, что не так в моем коде.