отображать календарь на 3 месяца с предыдущими и следующими стрелками вверху, используя codeigniter библиотеки календаря - PullRequest
0 голосов
/ 06 марта 2019

На изображении ниже представлено графическое представление того, что я пытаюсь получить.

Мой код:

application / controllers / DatePic_Controller.php

В контроллере функция build_display () вызывается с параметрами месяц и год.Этот месяц и год передаются функции генерирования файла модели, где мы вызываем функцию генерации библиотеки календаря codeigniter.

public function index() {

$year = date('Y');
$month = date('m');

$month2_year = date("Y",strtotime("+1 month"));
//echo 'month2_year:'.$month2_year;
$month2_month = date("m",strtotime("+1 month"));
//echo 'month2_month:'.$month2_month;


$month3_year = date("Y",strtotime("+2 month"));
//echo 'month2_year:'.$month2_year;
$month3_month = date("m",strtotime("+2 month"));

$cal_data['month1'] = $this->build_display($year,$month);

//print_r($cal_data['month1']);

$cal_data['month2'] = $this->build_display($month2_year, $month2_month);
//print_r($cal_data['month2']);

$cal_data['month3'] = $this->build_display($month3_year, $month3_month);

$this->load->view('calendar_view', $cal_data);
}


public function build_display($year,$month){

    //ini_set('display_errors', '1');

    $this->load->model("DatePic_model");


    if($day = $this->input->post('day')){

        $this->DatePic_model->add_calendar_data("$year-$month-$day",$this->input->post('data'));
    } 

    $calendar = $this->DatePic_model->generate($year,$month);
    //print_r($calendar);
    //echo $calendar_view = $this->load->view("datepic_view",$data,true);

     return $calendar; 
}

application / models / DatePic_model.php

InМодель, я использовал переменную conf для хранения настроек календаря и шаблона.

Кроме того, я использовал get_calendar_data (), чтобы отобразить праздник соответствующей даты в самом календаре. Но он не работает .....

public function  __construct(){



    $this->conf = array(
                'start_day' => 'monday',
                'show_next_prev' => true,
                'next_prev_url' => 'http://localhost/STUDY/CI_Mini_Projects/DatePic_Controller/display',
                'day_type' => 'short'
    );

    $this->conf['template'] = '


    {table_open}<table border="0" cellpadding="0" cellspacing="0" class="calendar">{/table_open}

    {heading_row_start}<tr class="heading">{/heading_row_start}

    {heading_previous_cell}<th><a href="{previous_url}">&lt;&lt;</a></th>{/heading_previous_cell}
    {heading_title_cell}<th colspan="{colspan}">{heading}</th>{/heading_title_cell}
    {heading_next_cell}<th><a href="{next_url}">&gt;&gt;</a></th>{/heading_next_cell}

    {heading_row_end}</tr>{/heading_row_end}

    {week_row_start}<tr class="weekdays">{/week_row_start}
    {week_day_cell}<td>{week_day}</td>{/week_day_cell}
    {week_row_end}</tr>{/week_row_end}

    {cal_row_start}<tr class="days">{/cal_row_start}
    {cal_cell_start}<td class="day">{/cal_cell_start}
    {cal_cell_start_today}<td>{/cal_cell_start_today}
    {cal_cell_start_other}<td class="other-month">{/cal_cell_start_other}

    {cal_cell_content}
        <div class="day_num">{day}</div>
        <div class="content">{content}</div>
    {/cal_cell_content}
    {cal_cell_content_today}
        <div class="day_num highlight">{day}</div>
        <div class="content">{content}</div>
    {/cal_cell_content_today}

    {cal_cell_no_content}
        <div class="day_num">{day}</div>
    {/cal_cell_no_content}
    {cal_cell_no_content_today}
        <div class="day_num highlight">{day}</div>
    {/cal_cell_no_content_today}

    {cal_cell_blank}&nbsp;{/cal_cell_blank}

    {cal_cell_other}
        <div class="day_num">{day}</div>
    {/cal_cel_other}

    {cal_cell_end}</td>{/cal_cell_end}
    {cal_cell_end_today}</td>{/cal_cell_end_today}
    {cal_cell_end_other}</td>{/cal_cell_end_other}
    {cal_row_end}</tr>{/cal_row_end}

    {table_close}</table>{/table_close}

    ';

}


public function get_calendar_data($year,$month){

    $query = $this->db->select('date,data')->from('holiday')->like('date',"$year-$month",'after')->get();
    //SELECT date,data FROM holiday WHERE date LIKE '2019-04%'; ==>     2019-04-19   Nineteen

    $cal_data = array();

    foreach($query->result() as $row){

        $cal_data[substr($row->date,8,2)] = $row->data;

        //2019-04-19 : 19
    }
    print_r($cal_data);
    //return $cal_data;

    /* If you want to control where the wildcard (%) is placed, you can use an optional third argument. Your options are ‘before’, ‘after’, ‘none’ and ‘both’ (which is the default).

    $this->db->like('title', 'match', 'before');    // Produces: WHERE `title` LIKE '%match' ESCAPE '!'
    $this->db->like('title', 'match', 'after');     // Produces: WHERE `title` LIKE 'match%' ESCAPE '!'
    $this->db->like('title', 'match', 'none');      // Produces: WHERE `title` LIKE 'match' ESCAPE '!'
    $this->db->like('title', 'match', 'both');      // Produces: WHERE `title` LIKE '%match%' ESCAPE '!' */



}

public function add_calendar_data($date,$data){


    if($this->db->select('date')->from('holiday')->where('date',$date)->count_all_results()){

        $this->db->where('date',$date)
                        ->update('holiday',array(
                                'date'=>$date,
                                'data'=>$data));
        echo "update";                      

    }else{

    $this->db->insert('holiday',array(
                                'date'=>$date,
                                'data'=>$data));
    }

    echo "insert";
}

public function generate($year,$month){


    $this->load->library("calendar",$this->conf);

    /* $cal_data = array(
                15 => base_url().'User_Controller/create_user',
                17 => base_url().'role'
    ); */

    //$cal_data = $this->add_calendar_data('2019-03-04','foo');

    $cal_data = $this->get_calendar_data($year,$month);
    //print_r($cal_data);
    return $this->calendar->generate($year,$month,$cal_data);
}

application / views/calendar_view.php

Это файл вида

<script src= base_url()."/assets/jquery/jquery-3.3.1.min.js"></script>

$(document).ready(function(){
	$('.calendar .day').click(function(){
		day_num = $(this).find('.day_num').html();
		
		//alert(day_num);
		day_data = prompt('Enter Stuff',$(this).find('.content').html());
		if(day_data !=null){
			
			$.ajax({
					url:window.location,
					type:'POST',
					data:{
						day:day_num,
						data:day_data						
					},
					success:function(msg){
						location.reload();
						
					}
				
			});
		}
		
		
	});
	
	
});
.calendar{
	font-family:Arial;
	font-size:12px;
}
table.calendar{
	
	margin:auto;
	border-collapse:collapse;
}
.calendar .days td{
	width:50px;
	height:50px;
	border:2px solid black;
	padding:4px;
	vertical-align:top;
	background-color:#DEF;
	
}

.calendar .days td:hover{

	background-color:#FFF;
	
}

.calendar .weekdays td{
	
	border:2px solid black;
	padding:2px;
	text-align:center;
	background-color : #C0C0C0;
}

.calendar .heading th{
	
	text-transform:uppercase;
    font-size:16px;	
	padding:10px;
	
}

.calendar .highlight{
	
	font-weight:bold;
	color:blue;	
}

.calendar .content{
    float: left;
    display: inline-block;
    width: 40px;
    background-color: gray;
}
<div id="month1">
<?=$month1; ?>
</div>

<div id="month2">
<?=$month2; ?>
</div>

<div id="month3">
<?=$month3; ?>
</div>

Я поделился отображением вывода, которое я получаю

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...