コード例 #1
0
/**
 * 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 ? '&nbsp;(' . 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 ? '&nbsp;(' . 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 = '&nbsp;(' . 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);
                }
            }
        }
    }
}
コード例 #2
0
ファイル: date.php プロジェクト: vah7id/wp-persian-openshift
/**
 * 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;
}
コード例 #3
0
/**
 * 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;
}
コード例 #4
0
/**
 * 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);
}
コード例 #5
0
/**
 * 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)))) . '">&laquo; ' . $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)))) . '">&laquo; ' . $jdate_month_name[$jprevious[1]] . '</a></td>';
        }
    } else {
        $calendar_output .= "\n\t\t" . '<td colspan="3" id="prev" class="pad">&nbsp;</td>';
    }
    $calendar_output .= "\n\t\t" . '<td class="pad">&nbsp;</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]] . ' &raquo;</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]] . ' &raquo;</a></td>';
        }
    } else {
        $calendar_output .= "\n\t\t" . '<td colspan="3" id="next" class="pad">&nbsp;</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">&nbsp;</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) . '">&nbsp;</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);
    }
}