function jstrftime($format, $timestamp = '', $none = '', $time_zone = 'Asia/Tehran', $tr_num = 'fa') { $T_sec = 0; /* <= رفع خطاي زمان سرور ، با اعداد '+' و '-' بر حسب ثانيه */ if ($time_zone != 'local') { date_default_timezone_set($time_zone == '' ? 'Asia/Tehran' : $time_zone); } $ts = $T_sec + (($timestamp == '' or $timestamp == 'now') ? time() : tr_num($timestamp)); $date = explode('_', date('h_H_i_j_n_s_w_Y', $ts)); list($j_y, $j_m, $j_d) = gregorian_to_jalali($date[7], $date[4], $date[3]); $doy = $j_m < 7 ? ($j_m - 1) * 31 + $j_d - 1 : ($j_m - 7) * 30 + $j_d + 185; $kab = $j_y % 33 % 4 - 1 == (int) ($j_y % 33 * 0.05) ? 1 : 0; $sl = strlen($format); $out = ''; for ($i = 0; $i < $sl; $i++) { $sub = substr($format, $i, 1); if ($sub == '%') { $sub = substr($format, ++$i, 1); } else { $out .= $sub; continue; } switch ($sub) { /* Day */ case 'a': $out .= jdate_words(array('kh' => $date[6]), ' '); break; case 'A': $out .= jdate_words(array('rh' => $date[6]), ' '); break; case 'd': $out .= $j_d < 10 ? '0' . $j_d : $j_d; break; case 'e': $out .= $j_d < 10 ? ' ' . $j_d : $j_d; break; case 'j': $out .= str_pad($doy + 1, 3, 0, STR_PAD_LEFT); break; case 'u': $out .= $date[6] + 1; break; case 'w': $out .= $date[6] == 6 ? 0 : $date[6] + 1; break; /* Week */ /* Week */ case 'U': $avs = ($date[6] < 5 ? $date[6] + 2 : $date[6] - 5) - $doy % 7; if ($avs < 0) { $avs += 7; } $num = (int) (($doy + $avs) / 7) + 1; if ($avs > 3 or $avs == 1) { $num--; } $out .= $num < 10 ? '0' . $num : $num; break; case 'V': $avs = ($date[6] == 6 ? 0 : $date[6] + 1) - $doy % 7; if ($avs < 0) { $avs += 7; } $num = (int) (($doy + $avs) / 7); if ($avs < 4) { $num++; } elseif ($num < 1) { $num = ($avs == 4 or $avs == ($j_y % 33 % 4 - 2 == (int) ($j_y % 33 * 0.05) ? 5 : 4)) ? 53 : 52; } $aks = $avs + $kab; if ($aks == 7) { $aks = 0; } $out .= ($kab + 363 - $doy < $aks and $aks < 3) ? '01' : ($num < 10 ? '0' . $num : $num); break; case 'W': $avs = ($date[6] == 6 ? 0 : $date[6] + 1) - $doy % 7; if ($avs < 0) { $avs += 7; } $num = (int) (($doy + $avs) / 7) + 1; if ($avs > 3) { $num--; } $out .= $num < 10 ? '0' . $num : $num; break; /* Month */ /* Month */ case 'b': case 'h': $out .= jdate_words(array('km' => $j_m), ' '); break; case 'B': $out .= jdate_words(array('mm' => $j_m), ' '); break; case 'm': $out .= $j_m > 9 ? $j_m : '0' . $j_m; break; /* Year */ /* Year */ case 'C': $out .= substr($j_y, 0, 2); break; case 'g': $jdw = $date[6] == 6 ? 0 : $date[6] + 1; $dny = 364 + $kab - $doy; $out .= substr(($jdw > $doy + 3 and $doy < 3) ? $j_y - 1 : ((3 - $dny > $jdw and $dny < 3) ? $j_y + 1 : $j_y), 2, 2); break; case 'G': $jdw = $date[6] == 6 ? 0 : $date[6] + 1; $dny = 364 + $kab - $doy; $out .= ($jdw > $doy + 3 and $doy < 3) ? $j_y - 1 : ((3 - $dny > $jdw and $dny < 3) ? $j_y + 1 : $j_y); break; case 'y': $out .= substr($j_y, 2, 2); break; case 'Y': $out .= $j_y; break; /* Time */ /* Time */ case 'H': $out .= $date[1]; break; case 'I': $out .= $date[0]; break; case 'l': $out .= $date[0] > 9 ? $date[0] : ' ' . (int) $date[0]; break; case 'M': $out .= $date[2]; break; case 'p': $out .= $date[1] < 12 ? 'قبل از ظهر' : 'بعد از ظهر'; break; case 'P': $out .= $date[1] < 12 ? 'ق.ظ' : 'ب.ظ'; break; case 'r': $out .= $date[0] . ':' . $date[2] . ':' . $date[5] . ' ' . ($date[1] < 12 ? 'قبل از ظهر' : 'بعد از ظهر'); break; case 'R': $out .= $date[1] . ':' . $date[2]; break; case 'S': $out .= $date[5]; break; case 'T': $out .= $date[1] . ':' . $date[2] . ':' . $date[5]; break; case 'X': $out .= $date[0] . ':' . $date[2] . ':' . $date[5]; break; case 'z': $out .= date('O', $ts); break; case 'Z': $out .= date('T', $ts); break; /* Time and Date Stamps */ /* Time and Date Stamps */ case 'c': $key = jdate_words(array('rh' => $date[6], 'mm' => $j_m)); $out .= $date[1] . ':' . $date[2] . ':' . $date[5] . ' ' . date('P', $ts) . ' ' . $key['rh'] . '، ' . $j_d . ' ' . $key['mm'] . ' ' . $j_y; break; case 'D': $out .= substr($j_y, 2, 2) . '/' . ($j_m > 9 ? $j_m : '0' . $j_m) . '/' . ($j_d < 10 ? '0' . $j_d : $j_d); break; case 'F': $out .= $j_y . '-' . ($j_m > 9 ? $j_m : '0' . $j_m) . '-' . ($j_d < 10 ? '0' . $j_d : $j_d); break; case 's': $out .= $ts; break; case 'x': $out .= substr($j_y, 2, 2) . '/' . ($j_m > 9 ? $j_m : '0' . $j_m) . '/' . ($j_d < 10 ? '0' . $j_d : $j_d); break; /* Miscellaneous */ /* Miscellaneous */ case 'n': $out .= "\n"; break; case 't': $out .= "\t"; break; case '%': $out .= '%'; break; default: $out .= $sub; } } return $tr_num != 'en' ? tr_num($out, 'fa', '.') : $out; }
public function jdate($format, $timestamp = '', $none = '', $time_zone = 'Asia/Tehran', $tr_num = 'en') { $T_sec = 0; /* <= رفع خطاي زمان سرور ، با اعداد '+' و '-' بر حسب ثانيه */ if ($time_zone != 'local') { date_default_timezone_set($time_zone == '' ? 'Asia/Tehran' : $time_zone); } $ts = $T_sec + (($timestamp == '' or $timestamp == 'now') ? time() : $this->tr_num($timestamp)); $date = explode('_', date('H_i_j_n_O_P_s_w_Y', $ts)); list($j_y, $j_m, $j_d) = $this->gregorian_to_jalali($date[8], $date[3], $date[2]); $doy = $j_m < 7 ? ($j_m - 1) * 31 + $j_d - 1 : ($j_m - 7) * 30 + $j_d + 185; $kab = $j_y % 33 % 4 - 1 == (int) ($j_y % 33 * 0.05) ? 1 : 0; $sl = strlen($format); $out = ''; for ($i = 0; $i < $sl; $i++) { $sub = substr($format, $i, 1); if ($sub == '\\') { $out .= substr($format, ++$i, 1); continue; } switch ($sub) { case 'E': case 'R': case 'x': case 'X': $out .= 'http://jdf.scr.ir'; break; case 'B': case 'e': case 'g': case 'G': case 'h': case 'I': case 'T': case 'u': case 'Z': $out .= date($sub, $ts); break; case 'a': $out .= $date[0] < 12 ? 'ق.ظ' : 'ب.ظ'; break; case 'A': $out .= $date[0] < 12 ? 'قبل از ظهر' : 'بعد از ظهر'; break; case 'b': $out .= (int) ($j_m / 3.1) + 1; break; case 'c': $out .= $j_y . '/' . $j_m . '/' . $j_d . ' ،' . $date[0] . ':' . $date[1] . ':' . $date[6] . ' ' . $date[5]; break; case 'C': $out .= (int) (($j_y + 99) / 100); break; case 'd': $out .= $j_d < 10 ? '0' . $j_d : $j_d; break; case 'D': $out .= $this->jdate_words(array('kh' => $date[7]), ' '); break; case 'f': $out .= $this->jdate_words(array('ff' => $j_m), ' '); break; case 'F': $out .= $this->jdate_words(array('mm' => $j_m), ' '); break; case 'H': $out .= $date[0]; break; case 'i': $out .= $date[1]; break; case 'j': $out .= $j_d; break; case 'J': $out .= $this->jdate_words(array('rr' => $j_d), ' '); break; case 'k': $out .= $this->tr_num(100 - (int) ($doy / ($kab + 365) * 1000) / 10, $tr_num); break; case 'K': $out .= $this->tr_num((int) ($doy / ($kab + 365) * 1000) / 10, $tr_num); break; case 'l': $out .= $this->jdate_words(array('rh' => $date[7]), ' '); break; case 'L': $out .= $kab; break; case 'm': $out .= $j_m > 9 ? $j_m : '0' . $j_m; break; case 'M': $out .= $this->jdate_words(array('km' => $j_m), ' '); break; case 'n': $out .= $j_m; break; case 'N': $out .= $date[7] + 1; break; case 'o': $jdw = $date[7] == 6 ? 0 : $date[7] + 1; $dny = 364 + $kab - $doy; $out .= ($jdw > $doy + 3 and $doy < 3) ? $j_y - 1 : ((3 - $dny > $jdw and $dny < 3) ? $j_y + 1 : $j_y); break; case 'O': $out .= $date[4]; break; case 'p': $out .= jdate_words(array('mb' => $j_m), ' '); break; case 'P': $out .= $date[5]; break; case 'q': $out .= $this->jdate_words(array('sh' => $j_y), ' '); break; case 'Q': $out .= $kab + 364 - $doy; break; case 'r': $key = $this->jdate_words(array('rh' => $date[7], 'mm' => $j_m)); $out .= $date[0] . ':' . $date[1] . ':' . $date[6] . ' ' . $date[4] . ' ' . $key['rh'] . '، ' . $j_d . ' ' . $key['mm'] . ' ' . $j_y; break; case 's': $out .= $date[6]; break; case 'S': $out .= 'ام'; break; case 't': $out .= $j_m != 12 ? 31 - (int) ($j_m / 6.5) : $kab + 29; break; case 'U': $out .= $ts; break; case 'v': $out .= $this->jdate_words(array('ss' => substr($j_y, 2, 2)), ' '); break; case 'V': $out .= $this->jdate_words(array('ss' => $j_y), ' '); break; case 'w': $out .= $date[7] == 6 ? 0 : $date[7] + 1; break; case 'W': $avs = ($date[7] == 6 ? 0 : $date[7] + 1) - $doy % 7; if ($avs < 0) { $avs += 7; } $num = (int) (($doy + $avs) / 7); if ($avs < 4) { $num++; } elseif ($num < 1) { $num = ($avs == 4 or $avs == ($j_y % 33 % 4 - 2 == (int) ($j_y % 33 * 0.05) ? 5 : 4)) ? 53 : 52; } $aks = $avs + $kab; if ($aks == 7) { $aks = 0; } $out .= ($kab + 363 - $doy < $aks and $aks < 3) ? '01' : ($num < 10 ? '0' . $num : $num); break; case 'y': $out .= substr($j_y, 2, 2); break; case 'Y': $out .= $j_y; break; case 'z': $out .= $doy; break; default: $out .= $sub; } } return $tr_num != 'en' ? $this->tr_num($out, 'fa', '.') : $out; }