/** * own widget function */ function ztjalali_archive_widget($type = 'monthly', $format = 'html', $show_post_count = false, $limit = 12, $before = '', $after = '') { global $wpdb, $jdate_month_name, $ztjalali_option; if ($type === "yearly") { $YearlyQry = $wpdb->get_results("SELECT DATE_FORMAT( post_date ,'%Y-%m-%d' ) as date,\n count(ID) as count,\n YEAR(post_date) AS `year`, \n MONTH(post_date) AS `month`, \n DAYOFMONTH(post_date) AS `dayofmonth` \n FROM {$wpdb->posts} \n WHERE post_date < NOW() \n AND post_type = 'post' \n AND post_status = 'publish' \n GROUP BY date ORDER BY post_date DESC"); if (!empty($YearlyQry)) { $jYears = array(); $i = 1; foreach ($YearlyQry as $res) { $jalali_year = gregorian_to_jalali($res->year, $res->month, $res->dayofmonth); $jYears[$jalali_year[0]]['year'] = $res->year; if (!array_key_exists('count', $jYears[$jalali_year[0]])) { $jYears[$jalali_year[0]]['count'] = 0; } $jYears[$jalali_year[0]]['count'] += $res->count; } foreach ($jYears as $jYear => $data) { if ($ztjalali_option['change_url_date_to_jalali']) { $url = get_year_link($jYear); } else { $url = get_year_link($data['year']); } $jYear = ztjalali_persian_num($jYear); $c_after = $show_post_count ? ' (' . ztjalali_persian_num($data['count']) . ')' . $after : ''; echo get_archives_link($url, $jYear, $format, $before, $c_after); if ($i == $limit) { break; } $i++; } } } elseif ("monthly" == $type or empty($type)) { $MonthlyQry = $wpdb->get_results("SELECT DATE_FORMAT( post_date ,'%Y-%m-%d' ) as date,\n count(ID) as count,\n YEAR(post_date) AS `year`, \n MONTH(post_date) AS `month`, \n DAYOFMONTH(post_date) AS `dayofmonth` \n FROM {$wpdb->posts} \n WHERE post_date < NOW() \n AND post_type = 'post' \n AND post_status = 'publish' \n GROUP BY date ORDER BY post_date DESC"); if (!empty($MonthlyQry)) { $jMonths = array(); foreach ($MonthlyQry as $res) { $jalali_month = gregorian_to_jalali($res->year, $res->month, $res->dayofmonth); $jMonths[$jalali_month[0] . '-' . $jalali_month[1]]['year'] = $res->year; $jMonths[$jalali_month[0] . '-' . $jalali_month[1]]['month'] = $res->month; if (!array_key_exists('count', $jMonths[$jalali_month[0] . '-' . $jalali_month[1]])) { $jMonths[$jalali_month[0] . '-' . $jalali_month[1]]['count'] = 0; } $jMonths[$jalali_month[0] . '-' . $jalali_month[1]]['count'] += $res->count; } $i = 1; foreach ($jMonths as $jMonth => $data) { list($jY, $jM) = explode('-', $jMonth); if ($ztjalali_option['change_url_date_to_jalali']) { $url = get_month_link($jY, $jM); } else { $url = get_month_link($data['year'], $data['month']); } $jY = ztjalali_persian_num($jY); $jM = $jdate_month_name[$jM]; $c_after = $show_post_count ? ' (' . ztjalali_persian_num($data['count']) . ')' . $after : ''; echo get_archives_link($url, $jM . ' ' . $jY, $format, $before, $c_after); if ($i == $limit) { break; } $i++; } } } elseif ("daily" == $type) { $limStr = ''; if (!empty($limit)) { $limit = (int) $limit; $limStr = ' LIMIT ' . $limit; } $DailyQry = $wpdb->get_results("SELECT DATE_FORMAT( post_date ,'%Y-%m-%d' ) as date,\n count(ID) as count,\n YEAR(post_date) AS `year`, \n MONTH(post_date) AS `month`, \n DAYOFMONTH(post_date) AS `dayofmonth` \n FROM {$wpdb->posts} \n WHERE post_date < NOW() \n AND post_type = 'post' \n AND post_status = 'publish' \n GROUP BY date ORDER BY post_date DESC " . $limStr); if (!empty($DailyQry)) { foreach ($DailyQry as $Daily) { list($jY, $jM, $jD) = gregorian_to_jalali($Daily->year, $Daily->month, $Daily->dayofmonth); if ($ztjalali_option['change_url_date_to_jalali']) { $url = get_day_link($jY, $jM, $jD); } else { $url = get_day_link($Daily->year, $Daily->month, $Daily->dayofmonth); } $date = mktime(0, 0, 0, $Daily->month, $Daily->dayofmonth, $Daily->year); $text = jdate(get_option('date_format'), $date); if ($show_post_count) { $c_after = ' (' . ztjalali_persian_num($Daily->count) . ')' . $after; } echo get_archives_link($url, $text, $format, $before, $c_after); } } } elseif ('postbypost' == $type) { $limStr = ''; if (!empty($limit)) { $limit = (int) $limit; $limStr = ' LIMIT ' . $limit; } $byPosts = $wpdb->get_results("SELECT ID, post_date, post_title FROM {$wpdb->posts} WHERE post_type='post' AND post_date < NOW() AND post_status = 'publish' ORDER BY post_date DESC" . $limStr); if (!empty($byPosts)) { foreach ($byPosts as $aPost) { if ($aPost->post_date != '0000-00-00 00:00:00') { $url = get_permalink($aPost->ID); echo get_archives_link($url, strip_tags($aPost->post_title), $format, $before, $after); } } } } }
/** * Format a local time/date according to locale settings (jalali equivalent of php strftime() function) * @global array $jdate_month_name * @param string $format for example 'Y-m-d H:i:s' * @param timestamp $timestamp [optional] * @param bool $fanum [optional]<br/>convert number to persian ?<br/> * default : get from plugin option * @return type * @since 5.0.0 */ function jstrftime($format, $timestamp = NULL, $fanum = false) { global $jdate_month_name; static $jdate_month_days = array(0, 31, 31, 31, 31, 31, 31, 30, 30, 30, 30, 30, 29); static $jdate_week_name = array('شنبه', 'یکشنبه', 'دوشنبه', 'سه شنبه', 'چهارشنبه', 'پنج شنبه', 'جمعه'); if (!$timestamp) { $timestamp = time(); } # Create need date parametrs list($gYear, $gMonth, $gDay, $gWeek) = explode('-', date('Y-m-d-w', $timestamp)); list($pYear, $pMonth, $pDay) = gregorian_to_jalali($gYear, $gMonth, $gDay); $pWeek = $gWeek + 1; if ($pWeek >= 7) { $pWeek = 0; } $lenghFormat = strlen($format); $i = 0; $result = ''; while ($i < $lenghFormat) { $par = $format[$i]; if ($par == '%') { $type = $format[++$i]; switch ($type) { # Day case 'a': $result .= substr($jdate_week_name[$pWeek], 0, 2); break; case 'A': $result .= $jdate_week_name[$pWeek]; break; case 'd': $result .= $pDay < 10 ? '0' . $pDay : $pDay; break; case 'e': $result .= $pDay; break; case 'j': $dayinM = jday_of_year($pMonth, $pDay); $result .= $dayinM < 10 ? '00' . $dayinM : $dayinM < 100 ? '0' . $dayinM : $dayinM; break; case 'u': $result .= $pWeek + 1; break; case 'w': $result .= $pWeek; break; # Week # Week case 'U': $result .= floor(jday_of_year($pMonth, $pDay) / 7); break; case 'V': case 'W': $result .= ceil(jday_of_year($pMonth, $pDay) / 7); break; # Month # Month case 'b': case 'h': $result .= substr($jdate_month_name[$pMonth], 0, 6); break; case 'B': $result .= $jdate_month_name[$pMonth]; break; case 'm': $result .= $pMonth < 10 ? '0' . $pMonth : $pMonth; break; # Year # Year case 'C': $result .= ceil($pYear / 100); break; case 'g': case 'y': $result .= substr($pYear, 2); break; case 'G': case 'Y': $result .= $pYear; break; # Time # Time case 'H': case 'I': case 'l': case 'M': case 'R': case 'S': case 'T': case 'X': case 'z': case 'Z': $result .= strftime('%' . $type, $timestamp); break; case 'p': case 'P': case 'r': if (date('a', $timestamp) == 'am') { $result .= $type == 'p' ? 'ق.ظ' : $type == 'P' ? 'قبل از ظهر' : strftime("%I:%M:%S قبل از ظهر", $timestamp); } else { $result .= $type == 'p' ? 'ب.ظ' : $type == 'P' ? 'بعد از ظهر' : strftime("%I:%M:%S بعد از ظهر", $timestamp); } break; # Time and Date Stamps # Time and Date Stamps case 'c': $result .= substr($jdate_week_name[$pWeek], 0, 2) . ' ' . substr($jdate_month_name[$pMonth], 0, 6) . ' ' . $pDay . ' ' . strftime("%T", $timestamp) . ' ' . $pYear; break; case 'D': case 'x': $result .= ($pMonth < 10 ? '0' . $pMonth : $pMonth) . '-' . ($pDay < 10 ? '0' . $pDay : $pDay) . '-' . substr($pYear, 2); break; case 'F': $result .= $pYear . '-' . ($pMonth < 10 ? '0' . $pMonth : $pMonth) . '-' . ($pDay < 10 ? '0' . $pDay : $pDay); break; case 's': $result .= $timestamp; break; # Miscellaneous # Miscellaneous case 'n': $result .= "\n"; break; case 't': $result .= "\t"; break; case '%': $result .= '%'; break; default: $result .= '%' . $type; } } else { $result .= $par; } $i++; } if ($fanum) { return ztjalali_persian_num($result); } return $result; }
/** * change archive title filter handler * @global array $jdate_month_name * @global array $wp_query * @param string $title * @param string $sep * @param string $seplocation * @return string */ function ztjalali_ch_archive_title($title, $sep, $seplocation) { global $jdate_month_name, $wp_query; $query = $wp_query->query; $new_title = ''; if (is_archive()) { if (isset($query['monthnum'])) { if ($query['year'] < 1700) { $new_title = $jdate_month_name[(int) $query['monthnum']] . ' ' . $query['year']; } } elseif (isset($query['year'])) { $new_title = $query['year']; } elseif (isset($query['m'])) { $year = substr($query['m'], 0, 4); if ($year < 1700) { $monthnum = (int) substr($query['m'], 4, 2); $new_title = $jdate_month_name[$monthnum] . ' ' . $year; } } if (!empty($new_title)) { // if ($seplocation == 'right') // $new_title.= $sep . ' ' . get_bloginfo('name'); // else // $new_title .= get_bloginfo('name') . ' ' . $sep; $new_title .= ' - ' . get_bloginfo('name'); return ztjalali_persian_num($new_title); } } return $title; }
/** * use <b>ztjalali_persian_num()</b> OR <b>ztjalali_persian_num_all()</b> instead farsi_num() * @deprecated since 5.0.0 */ function farsi_num($str, $fake = null, $fake2 = null) { return ztjalali_persian_num($str); }
/** * own widget function */ function ztjalali_calendar_widget($shortname = TRUE, $echo = TRUE, $thisyear = 0, $thismonth = 0) { global $wpdb, $posts, $wp; global $jdate_month_name, $ztjalali_option; if (isset($wp->query_vars['m'])) { $m_year = (int) substr($wp->query_vars['m'], 0, 4); $m_month = (int) substr($wp->query_vars['m'], 4, 2); if ($m_year < 1700) { list($m_year, $m_month, $tmp_day) = jalali_to_gregorian($m_year, $m_month, 15); } } elseif (isset($wp->query_vars['m'])) { $thisyear = (int) substr($wp->query_vars['m'], 0, 4); } if (empty($thisyear)) { if (isset($wp->query_vars['year'])) { $thisyear = (int) $wp->query_vars['year']; } elseif (isset($m_year)) { $thisyear = $m_year; } else { $thisyear = date('Y', time()); } } if (empty($thismonth)) { if (isset($wp->query_vars['monthnum'])) { $thismonth = (int) $wp->query_vars['monthnum']; } elseif (isset($m_month)) { $thismonth = $m_month; } else { $thismonth = date('m', time()); } } //doing: support $_GET['w'] // if (isset($_GET['w'])) // $w = '' . (int)($_GET['w']); // if (!empty($w)) { //// We need to get the month from MySQL // $thisyear = '' . (int)(substr($m, 0, 4)); // $d = (($w - 1) * 7) + 6; //it seems MySQL's weeks disagree with PHP's // $thismonth = $wpdb->get_var("SELECT DATE_FORMAT((DATE_ADD('{$thisyear}0101', INTERVAL $d DAY) ), '%m')"); // } /* doing : cache */ $cache = array(); $key = md5($thismonth . $thisyear); if ($cache = wp_cache_get('ztjalali_calendar', 'calendar')) { if (is_array($cache) && isset($cache[$key])) { if ($echo) { /** This filter is documented in wp-includes/general-template.php */ echo apply_filters('ztjalali_calendar', $cache[$key]); return; } else { /** This filter is documented in wp-includes/general-template.php */ return apply_filters('ztjalali_calendar', $cache[$key]); } } } if (!is_array($cache)) { $cache = array(); } // Quick check. If we have no posts at all, abort! if (!$posts) { $gotsome = $wpdb->get_var("SELECT 1 as test FROM {$wpdb->posts} WHERE post_type = 'post' AND post_status = 'publish' LIMIT 1"); if (!$gotsome) { $cache[$key] = ''; wp_cache_set('ztjalali_calendar', $cache, 'calendar'); return; } } if ($thisyear > 1700) { list($thisyear, $thismonth, $thisday) = gregorian_to_jalali($thisyear, $thismonth, 1); } $unixmonth = jmktime(0, 0, 0, $thismonth, 1, $thisyear); $jthisyear = $thisyear; $jthismonth = $thismonth; list($thisyear, $thismonth, $jthisday) = jalali_to_gregorian($jthisyear, $jthismonth, 1); $last_day = jdate('t', $unixmonth, FALSE, FALSE); // Get the next and previous month and year with at least one post $startdate = date("Y:m:d", jmktime(0, 0, 0, $jthismonth, 1, $jthisyear)); $enddate = date("Y:m:d", jmktime(23, 59, 59, $jthismonth, $last_day, $jthisyear)); $previous = $wpdb->get_row("SELECT DAYOFMONTH(post_date) AS `dayofmonth`,MONTH(post_date) AS month, YEAR(post_date) AS year\n\t\tFROM {$wpdb->posts}\n\t\tWHERE post_date < '{$startdate}'\n\t\tAND post_type = 'post' AND post_status = 'publish'\n\t\t\tORDER BY post_date DESC\n\t\t\tLIMIT 1"); $next = $wpdb->get_row("SELECT DAYOFMONTH(post_date) AS `dayofmonth`,MONTH(post_date) AS month, YEAR(post_date) AS year\n\t\tFROM {$wpdb->posts}\n\t\tWHERE post_date > '{$enddate} 23:59:59'\n\t\tAND post_type = 'post' AND post_status = 'publish'\n\t\t\tORDER BY post_date ASC\n\t\t\tLIMIT 1"); /* translators: Calendar caption: 1: month name, 2: 4-digit year */ $calendar_caption = _x('%1$s %2$s', 'calendar caption'); $calendar_output = '<table id="wp-calendar" class="widget_calendar"> <caption>' . sprintf($calendar_caption, $jdate_month_name[(int) $jthismonth], jdate('Y', $unixmonth)) . '</caption> <thead> <tr>'; $myweek = $myshortweek = array(); $week_begins = (int) get_option('start_of_week'); for ($wdcount = 0; $wdcount <= 6; $wdcount++) { $myweek[] = ztjalali_get_week_name(($wdcount + $week_begins) % 7); $myshortweek[] = ztjalali_get_short_week_name(($wdcount + $week_begins) % 7); } foreach ($myweek as $k => $wd) { $day_name = true == $shortname ? $myshortweek[$k] : $wd; $wd = esc_attr($wd); $calendar_output .= "\n\t\t<th scope=\"col\" title=\"{$wd}\">{$day_name}</th>"; } $calendar_output .= ' </tr> </thead> <tfoot> <tr>'; if ($previous) { $jprevious = gregorian_to_jalali($previous->year, $previous->month, $previous->dayofmonth); if ($ztjalali_option['change_url_date_to_jalali']) { $calendar_output .= "\n\t\t" . '<td colspan="3" id="prev"><a href="' . get_month_link($jprevious[0], $jprevious[1]) . '" title="' . esc_attr(sprintf(__('View posts for %1$s %2$s', 'ztjalali'), $jdate_month_name[$jprevious[1]], jdate('Y', mktime(0, 0, 0, $previous->month, 1, $previous->year)))) . '">« ' . $jdate_month_name[$jprevious[1]] . '</a></td>'; } else { $calendar_output .= "\n\t\t" . '<td colspan="3" id="prev"><a href="' . get_month_link($previous->year, $previous->month) . '" title="' . esc_attr(sprintf(__('View posts for %1$s %2$s', 'ztjalali'), $jdate_month_name[$jprevious[1]], jdate('Y', mktime(0, 0, 0, $previous->month, 1, $previous->year)))) . '">« ' . $jdate_month_name[$jprevious[1]] . '</a></td>'; } } else { $calendar_output .= "\n\t\t" . '<td colspan="3" id="prev" class="pad"> </td>'; } $calendar_output .= "\n\t\t" . '<td class="pad"> </td>'; if ($next) { $jnext = gregorian_to_jalali($next->year, $next->month, $next->dayofmonth); if ($ztjalali_option['change_url_date_to_jalali']) { $calendar_output .= "\n\t\t" . '<td colspan="3" id="next"><a href="' . get_month_link($jnext[0], $jnext[1]) . '" title="' . esc_attr(sprintf(__('View posts for %1$s %2$s', 'ztjalali'), $jdate_month_name[$jnext[1]], jdate('Y', mktime(0, 0, 0, $next->month, 1, $next->year)))) . '">' . $jdate_month_name[$jnext[1]] . ' »</a></td>'; } else { $calendar_output .= "\n\t\t" . '<td colspan="3" id="next"><a href="' . get_month_link($next->year, $next->month) . '" title="' . esc_attr(sprintf(__('View posts for %1$s %2$s', 'ztjalali'), $jdate_month_name[$jnext[1]], jdate('Y', mktime(0, 0, 0, $next->month, 1, $next->year)))) . '">' . $jdate_month_name[$jnext[1]] . ' »</a></td>'; } } else { $calendar_output .= "\n\t\t" . '<td colspan="3" id="next" class="pad"> </td>'; } $calendar_output .= ' </tr> </tfoot> <tbody> <tr>'; // Get days with posts $dayswithposts = $wpdb->get_results("SELECT DISTINCT post_date\n\t\tFROM {$wpdb->posts} WHERE post_date >= '{$startdate} 00:00:00'\n\t\tAND post_type = 'post' AND post_status = 'publish'\n\t\tAND post_date <= '{$enddate} 23:59:59'", ARRAY_N); if ($dayswithposts) { foreach ((array) $dayswithposts as $daywith) { $jdaywithpost[] = jdate('j', strtotime($daywith[0]), FALSE, FALSE); } } else { $jdaywithpost = array(); } if (strpos($_SERVER['HTTP_USER_AGENT'], 'MSIE') !== false || stripos($_SERVER['HTTP_USER_AGENT'], 'camino') !== false || stripos($_SERVER['HTTP_USER_AGENT'], 'safari') !== false) { $ak_title_separator = "\n"; } else { $ak_title_separator = ', '; } $ak_titles_for_day = array(); $ak_post_titles = $wpdb->get_results("SELECT ID, post_title, post_date as dom " . "FROM {$wpdb->posts} " . "WHERE post_date >= '{$startdate} 00:00:00' " . "AND post_date <= '{$enddate} 23:59:59' " . "AND post_type = 'post' AND post_status = 'publish'"); if ($ak_post_titles) { foreach ((array) $ak_post_titles as $ak_post_title) { /** This filter is documented in wp-includes/post-template.php */ $post_title = esc_attr(apply_filters('the_title', $ak_post_title->post_title, $ak_post_title->ID)); $jdom = $jdaywithpost[] = jdate('j', strtotime($ak_post_title->dom), FALSE, FALSE); if (empty($ak_titles_for_day['day_' . $jdom])) { $ak_titles_for_day['day_' . $jdom] = ''; } if (empty($ak_titles_for_day["{$jdom}"])) { // first one $ak_titles_for_day["{$jdom}"] = $post_title; } else { $ak_titles_for_day["{$jdom}"] .= $ak_title_separator . $post_title; } } } // See how much we should pad in the beginning $pad = calendar_week_mod(jdate('w', $unixmonth, false, false) - $week_begins); $pad--; if ($pad < 0) { $pad = 6; } if (0 != $pad) { $calendar_output .= "\n\t\t" . '<td colspan="' . esc_attr($pad) . '" class="pad"> </td>'; } $jdaysinmonth = (int) jdate('t', $unixmonth, FALSE, FALSE); for ($jday = 1; $jday <= $jdaysinmonth; ++$jday) { if (isset($newrow) && $newrow) { $calendar_output .= "\n\t</tr>\n\t<tr>\n\t\t"; } $newrow = false; if ($jday == jdate('j', time(), FALSE, FALSE) && $jthismonth == jdate('m', time(), FALSE, FALSE) && $jthisyear == jdate('Y', time(), FALSE, FALSE)) { $calendar_output .= '<td id="today">'; } else { $calendar_output .= '<td>'; } if (in_array($jday, $jdaywithpost)) { // any posts today? $day = jalali_to_gregorian($jthisyear, $jthismonth, $jday); if ($ztjalali_option['change_url_date_to_jalali']) { $calendar_output .= '<a href="' . get_day_link($jthisyear, $jthismonth, $jday) . '" title="' . esc_attr($ak_titles_for_day[$jday]) . "\">{$jday}</a>"; } else { $calendar_output .= '<a href="' . get_day_link($day[0], $day[1], $day[2]) . '" title="' . esc_attr($ak_titles_for_day[$jday]) . "\">{$jday}</a>"; } } else { $calendar_output .= $jday; } $calendar_output .= '</td>'; jdate('w', jmktime(0, 0, 0, $jthismonth, $jday, $jthisyear), FALSE, FALSE); if (6 == calendar_week_mod(date('w', jmktime(0, 0, 0, $jthismonth, $jday, $jthisyear)) - $week_begins)) { $newrow = true; } } $pad = 7 - calendar_week_mod(date('w', jmktime(0, 0, 0, $jthismonth, $jday, $jthisyear)) - $week_begins); if ($pad != 0 && $pad != 7) { $calendar_output .= "\n\t\t" . '<td class="pad" colspan="' . esc_attr($pad) . '"> </td>'; } $calendar_output .= "\n\t</tr>\n\t</tbody>\n\t</table>"; $cache[$key] = $calendar_output; wp_cache_set('ztjalali_calendar', $cache, 'calendar'); if ($ztjalali_option['change_jdate_number_to_persian']) { $calendar_output = ztjalali_persian_num($calendar_output); } if ($echo) { /** * Filter the HTML calendar output. * * @since 3.0.0 * * @param string $calendar_output HTML output of the calendar. */ echo apply_filters('ztjalali_calendar', $calendar_output); } else { /** This filter is documented in wp-includes/general-template.php */ return apply_filters('ztjalali_calendar', $calendar_output); } }