カレンダークラス¶
カレンダークラスを使うと動的にカレンダーを 生成できます。カレンダーはデザインのどんな 側面も100%コントロール可能なカレンダーテン プレートをもとに整形されます。
カレンダークラスを使う¶
クラスの初期化¶
CodeIgniter の大半のクラスと同様に、カレンダークラスはコントローラの中で、 $this->load->library メソッドを使って初期化します:
$this->load->library('calendar');
一旦呼び出せば、カレンダーオブジェクトは $this->calendar を使用することで利用できます。:
$this->calendar
カレンダーの表示¶
カレンダーの表示方法の非常に簡単な例です:
$this->load->library('calendar');
echo $this->calendar->generate();
上のコードは、サーバ時間の年月のカレンダーを生成します。 特定の年月のカレンダーを表示させるには、カレンダー生成 関数に次のように情報を渡します:
$this->load->library('calendar');
echo $this->calendar->generate(2006, 6);
上のコードは、2006年6月を表示するカレンダ ーを生成します。最初の引数は年を、2番目の 引数は月を指定します。
カレンダーのセルへのデータ引き渡し¶
カレンダーのセルにデータを追加するには、埋め込みたい日をキーにし、 それに対応する値に埋め込むデータを入れた連想配列を作成します。 作成した配列は、カレンダー生成関数の第3引数に渡します。 次のような例が考えられます:
$this->load->library('calendar');
$data = array(
3 => 'http://example.com/news/article/2006/03/',
7 => 'http://example.com/news/article/2006/07/',
13 => 'http://example.com/news/article/2006/13/',
26 => 'http://example.com/news/article/2006/26/'
);
echo $this->calendar->generate(2006, 6, $data);
上の例を使用すると、3,7,13および26日が渡された URL を指すリンクになります。
Note
初期状態では、配列にはリンクが含まれるものとされています。 下のカレンダーテンプレートを説明した箇所では、セルに渡されたデータが どのように扱われるかが示されています。 そこで、違う情報のタイプを指定 することができ、どのようにしてカスタマイズ可能かを知ることができます。
表示設定の変更¶
7つの設定項目でカレンダーの様々な面をコントロールできます。 設定項目は呼び出し関数の第2引数に配列として渡して設定します。 例です:
$prefs = array(
'start_day' => 'saturday',
'month_type' => 'long',
'day_type' => 'short'
);
$this->load->library('calendar', $prefs);
echo $this->calendar->generate();
上のコードは、土曜日から始まり、「長い」形式の月名と「短い」 形式の曜日名をヘッダに使用します。 設定項目についての詳しい 情報は下記のとおりです。
設定項目 | 初期値 | オプション | 説明 |
---|---|---|---|
template | None | None | カレンダーテンプレートの文字列。テンプレート のセクションを参照。 |
local_time | time() | None | 現在時刻として関連づける UNIX タイムスタンプ。 |
start_day | sunday | Any week day (sunday, monday, tuesday, etc.) | カレンダーの開始曜日。 |
month_type | long | long, short |
|
day_type | abr | long, short, abr | ヘッダのカラムの曜日名の形式にどの形式を用いるか。 long = Sunday, short = Sun, abr = Su. |
show_next_prev | FALSE | TRUE/FALSE (boolean) | 次/ 前 の 月に移動できる URL を表示するかどうか。 この機能については下記参照。 |
next_prev_url | controller/method | A URL | 次の月/ 前の月 のリンクを利用する場合の基準パス。 |
show_other_days | FALSE | TRUE/FALSE (boolean) | 暦月の最初であるか先週を分ける他の月日を表示するべきか どうか決定します。 |
次の月 / 前の月 リンクの表示¶
次へ / 前へ のリンクを経由してカレンダーを動的に進める / 戻る ようにするには、次の例のようなコードをカレンダーのコードに設定 する必要があります:
$prefs = array(
'show_next_prev' => TRUE,
'next_prev_url' => 'http://example.com/index.php/calendar/show/'
);
$this->load->library('calendar', $prefs);
echo $this->calendar->generate($this->uri->segment(3), $this->uri->segment(4));
上のサンプルで、何点か気づいた点があるはずです:
- “show_next_prev” を TRUE にする必要があります。
- “next_prev_url” の設定項目でカレンダーが設置されている コントローラへの URL を指定しなければなりません。 指定しなければ、 controller/method にセットされます。
- カレンダー生成関数に指定する「年」と「月」には、 URI セグメントに出現するものを指定します (Note: カレンダークラスは基準の URL に対して 年と月を自動的に追加します)
カレンダーテンプレートの作成¶
カレンダーテンプレートを作成することで、カレンダーのデザイン を100%コントロールできます。 カレンダーの各部品は次に示す 擬似変数のペアの間に配置されます:
$prefs['template'] = '
{table_open}<table border="0" cellpadding="0" cellspacing="0">{/table_open}
{heading_row_start}<tr>{/heading_row_start}
{heading_previous_cell}<th><a href="{previous_url}"><<</a></th>{/heading_previous_cell}
{heading_title_cell}<th colspan="{colspan}">{heading}</th>{/heading_title_cell}
{heading_next_cell}<th><a href="{next_url}">>></a></th>{/heading_next_cell}
{heading_row_end}</tr>{/heading_row_end}
{week_row_start}<tr>{/week_row_start}
{week_day_cell}<td>{week_day}</td>{/week_day_cell}
{week_row_end}</tr>{/week_row_end}
{cal_row_start}<tr>{/cal_row_start}
{cal_cell_start}<td>{/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}<a href="{content}">{day}</a>{/cal_cell_content}
{cal_cell_content_today}<div class="highlight"><a href="{content}">{day}</a></div>{/cal_cell_content_today}
{cal_cell_no_content}{day}{/cal_cell_no_content}
{cal_cell_no_content_today}<div class="highlight">{day}</div>{/cal_cell_no_content_today}
{cal_cell_blank} {/cal_cell_blank}
{cal_cell_other}{day}{/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}
';
$this->load->library('calendar', $prefs);
echo $this->calendar->generate();
配列を使用して、 key=>value ペアを渡すことで多くの 望む値を渡すことができます。省略するとCalendarクラス で継承されたデフォルト値を使用します
使用例:
$prefs['template'] = array(
'table_open' => '<table class="calendar">',
'cal_cell_start' => '<td class="day">',
'cal_cell_start_today' => '<td class="today">'
);
$this->load->library('calendar', $prefs);
echo $this->calendar->generate();
クラスリファレンス¶
-
class
CI_Calendar
¶ -
initialize
([$config = array()])¶ パラメータ array $config: 構成パラメータ 返り値: CI_Calendar インスタンス (メソッドチェーン) 返り値型: CI_Calendar カレンダーの環境設定を初期化します。表示設定を含む入力として連想配列を受け入れます。
-
generate
([$year = ''[, $month = ''[, $data = array()]]])¶ パラメータ int $year: 年 パラメータ int $month: 月 パラメータ array $data: カレンダーセルにデータを表示 返り値: HTMLフォーマット カレンダー 返り値型: string カレンダーを生成
-
get_month_name
($month)¶ パラメータ int $month: 月 返り値: 月名 返り値型: string 月の数値に基づいての月名を生成します。
-
get_day_names
($day_type = '')¶ パラメータ string $day_type: ‘long’, ‘short’, or ‘abr’ 返り値: Array of day names 返り値型: array 型に基づき、曜日名(日曜日、月曜日、など)の配列を返します。 オプション:long, short, abr または なし
$day_type
が提供 されていない場合(または無効な型が提供されている場合) 「省略」を返します
-
adjust_date
($month, $year)¶ パラメータ int $month: 月 パラメータ int $year: 年 返り値: 月と年を含む連想配列 返り値型: array この方法では、有効な月/年保持していることを確認します。 例えば月に13を提出した場合、年が増加すると月が1月 になります:
print_r($this->calendar->adjust_date(13, 2014));
outputs:
Array ( [month] => '01' [year] => '2015' )
-
get_total_days
($month, $year)¶ パラメータ int $month: 月 パラメータ int $year: 年 返り値: 指定された月の日数カウント 返り値型: int 指定された月の総日数:
echo $this->calendar->get_total_days(2, 2012); // 29
Note
このメソッドの別名 Date Helper function
days_in_month()
.
-
default_template
()¶ 返り値: テンプレート値の配列 返り値型: array デフォルトのテンプレートを設定します。このメソッドはあなたが作成していない ときに使用される独自のテンプレートを返します。
-
parse_template
()¶ 返り値: CI_Calendar インスタンス (メソッドチェーン) 返り値型: CI_Calendar テンプレート内のデータを収集
{疑似変数}
カレンダーを表示するために使用されます。
-