jdate_words()   C
last analyzed

Complexity

Conditions 17
Paths 60

Size

Total Lines 72
Code Lines 57

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 1
Metric Value
cc 17
eloc 57
c 1
b 0
f 1
nc 60
nop 2
dl 0
loc 72
rs 5.2166

How to fix   Long Method    Complexity   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

1
<?php
2
declare(strict_types=1);
3
4
/**
5
 * @param $format
6
 * @param string $timestamp
7
 * @param string $none
8
 * @param string $time_zone
9
 * @param string $tr_num
10
 * @return string|string[]
11
 */
12
function jdate($format, $timestamp = '', $none = '', $time_zone = 'Asia/Tehran', $tr_num = 'fa')
13
{
14
    $T_sec = 0;
15
16
    if ($time_zone != 'local') {
17
        date_default_timezone_set(($time_zone === '') ? 'Asia/Tehran' : $time_zone);
18
    }
19
    $ts = $T_sec + (($timestamp === '') ? time() : tr_num($timestamp));
20
    $date = explode('_', date('H_i_j_n_O_P_s_w_Y', $ts));
21
    list($j_y, $j_m, $j_d) = gregorian_to_jalali($date[8], $date[3], $date[2]);
22
    $doy = ($j_m < 7) ? (($j_m - 1) * 31) + $j_d - 1 : (($j_m - 7) * 30) + $j_d + 185;
23
    $kab = (((($j_y % 33) % 4) - 1) == ((int)(($j_y % 33) * 0.05))) ? 1 : 0;
24
    $sl = strlen($format);
25
    $out = '';
26
    for ($i = 0; $i < $sl; $i++) {
27
        $sub = substr($format, $i, 1);
28
        if ($sub == '\\') {
29
            $out .= substr($format, ++$i, 1);
30
            continue;
31
        }
32
        switch ($sub) {
33
34
            case'E':
35
            case'R':
36
            case'x':
37
            case'X':
38
                $out .= 'https://DyarWeb.com';
39
                break;
40
41
            case'B':
42
            case'e':
43
            case'g':
44
            case'G':
45
            case'h':
46
            case'I':
47
            case'T':
48
            case'u':
49
            case'Z':
50
                $out .= date($sub, $ts);
51
                break;
52
53
            case'a':
54
                $out .= ($date[0] < 12) ? 'ق.ظ' : 'ب.ظ';
55
                break;
56
57
            case'A':
58
                $out .= ($date[0] < 12) ? 'قبل از ظهر' : 'بعد از ظهر';
59
                break;
60
61
            case'b':
62
                $out .= (int)($j_m / 3.1) + 1;
63
                break;
64
65
            case'c':
66
                $out .= $j_y . '/' . $j_m . '/' . $j_d . ' ،' . $date[0] . ':' . $date[1] . ':' . $date[6] . ' ' . $date[5];
67
                break;
68
69
            case'C':
70
                $out .= (int)(($j_y + 99) / 100);
71
                break;
72
73
            case'd':
74
                $out .= ($j_d < 10) ? '0' . $j_d : $j_d;
75
                break;
76
77
            case'D':
78
                $out .= jdate_words(['kh' => $date[7]], ' ');
79
                break;
80
81
            case'f':
82
                $out .= jdate_words(['ff' => $j_m], ' ');
83
                break;
84
85
            case'F':
86
                $out .= jdate_words(['mm' => $j_m], ' ');
87
                break;
88
89
            case'H':
90
                $out .= $date[0];
91
                break;
92
93
            case'i':
94
                $out .= $date[1];
95
                break;
96
97
            case'j':
98
                $out .= $j_d;
99
                break;
100
101
            case'J':
102
                $out .= jdate_words(['rr' => $j_d], ' ');
103
                break;
104
105
            case'k':
106
                $out .= tr_num(100 - (int)($doy / ($kab + 365) * 1000) / 10, $tr_num);
107
                break;
108
109
            case'K':
110
                $out .= tr_num((int)($doy / ($kab + 365) * 1000) / 10, $tr_num);
111
                break;
112
113
            case'l':
114
                $out .= jdate_words(['rh' => $date[7]], ' ');
115
                break;
116
117
            case'L':
118
                $out .= $kab;
119
                break;
120
121
            case'm':
122
                $out .= ($j_m > 9) ? $j_m : '0' . $j_m;
123
                break;
124
125
            case'M':
126
                $out .= jdate_words(['km' => $j_m], ' ');
127
                break;
128
129
            case'n':
130
                $out .= $j_m;
131
                break;
132
133
            case'N':
134
                $out .= $date[7] + 1;
135
                break;
136
137
            case'o':
138
                $jdw = ($date[7] == 6) ? 0 : $date[7] + 1;
139
                $dny = 364 + $kab - $doy;
140
                $out .= ($jdw > ($doy + 3) and $doy < 3) ? $j_y - 1 : (((3 - $dny) > $jdw and $dny < 3) ? $j_y + 1 : $j_y);
141
                break;
142
143
            case'O':
144
                $out .= $date[4];
145
                break;
146
147
            case'p':
148
                $out .= jdate_words(['mb' => $j_m], ' ');
149
                break;
150
151
            case'P':
152
                $out .= $date[5];
153
                break;
154
155
            case'q':
156
                $out .= jdate_words(['sh' => $j_y], ' ');
157
                break;
158
159
            case'Q':
160
                $out .= $kab + 364 - $doy;
161
                break;
162
163
            case'r':
164
                $key = jdate_words(['rh' => $date[7], 'mm' => $j_m]);
165
                $out .= $date[0] . ':' . $date[1] . ':' . $date[6] . ' ' . $date[4] . ' ' . $key['rh'] . '، ' . $j_d . ' ' . $key['mm'] . ' ' . $j_y;
166
                break;
167
168
            case's':
169
                $out .= $date[6];
170
                break;
171
172
            case'S':
173
                $out .= 'ام';
174
                break;
175
176
            case't':
177
                $out .= ($j_m != 12) ? (31 - (int)($j_m / 6.5)) : ($kab + 29);
178
                break;
179
180
            case'U':
181
                $out .= $ts;
182
                break;
183
184
            case'v':
185
                $out .= jdate_words(['ss' => ($j_y % 100)], ' ');
186
                break;
187
188
            case'V':
189
                $out .= jdate_words(['ss' => $j_y], ' ');
190
                break;
191
192
            case'w':
193
                $out .= ($date[7] == 6) ? 0 : $date[7] + 1;
194
                break;
195
196
            case'W':
197
                $avs = (($date[7] == 6) ? 0 : $date[7] + 1) - ($doy % 7);
198
                if ($avs < 0) {
199
                    $avs += 7;
200
                }
201
                $num = (int)(($doy + $avs) / 7);
202
                if ($avs < 4) {
203
                    $num++;
204
                } elseif ($num < 1) {
205
                    $num = ($avs == 4 or $avs == ((((($j_y % 33) % 4) - 2) == ((int)(($j_y % 33) * 0.05))) ? 5 : 4)) ? 53 : 52;
206
                }
207
                $aks = $avs + $kab;
208
                if ($aks == 7) {
209
                    $aks = 0;
210
                }
211
                $out .= (($kab + 363 - $doy) < $aks and $aks < 3) ? '01' : (($num < 10) ? '0' . $num : $num);
212
                break;
213
214
            case'y':
215
                $out .= substr($j_y, 2, 2);
216
                break;
217
218
            case'Y':
219
                $out .= $j_y;
220
                break;
221
222
            case'z':
223
                $out .= $doy;
224
                break;
225
226
            default:
227
                $out .= $sub;
228
        }
229
    }
230
    return ($tr_num != 'en') ? tr_num($out, 'fa', '.') : $out;
231
}
232
233
234
/**
235
 * @param $str
236
 * @param string $mod
237
 * @param string $mf
238
 * @return string|string[]
239
 */
240
function tr_num($str, $mod = 'en', $mf = '٫')
241
{
242
    $num_a = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '.'];
243
    $key_a = ['۰', '۱', '۲', '۳', '۴', '۵', '۶', '۷', '۸', '۹', $mf];
244
    return ($mod == 'fa') ? str_replace($num_a, $key_a, $str) : str_replace($key_a, $num_a, $str);
245
}
246
247
/**
248
 * @param $array
249
 * @param string $mod
250
 * @return string
251
 */
252
function jdate_words($array, $mod = '')
253
{
254
    foreach ($array as $type => $num) {
255
        $num = (int)tr_num($num);
256
        switch ($type) {
257
258
            case'ss':
259
                $sl = strlen($num);
260
                $xy3 = substr($num, 2 - $sl, 1);
261
                $h3 = $h34 = $h4 = '';
262
                if ($xy3 == 1) {
263
                    $p34 = '';
264
                    $k34 = ['ده', 'یازده', 'دوازده', 'سیزده', 'چهارده', 'پانزده', 'شانزده', 'هفده', 'هجده', 'نوزده'];
265
                    $h34 = $k34[substr($num, 2 - $sl, 2) - 10];
266
                } else {
267
                    $xy4 = substr($num, 3 - $sl, 1);
268
                    $p34 = ($xy3 == 0 or $xy4 == 0) ? '' : ' و ';
269
                    $k3 = ['', '', 'بیست', 'سی', 'چهل', 'پنجاه', 'شصت', 'هفتاد', 'هشتاد', 'نود'];
270
                    $h3 = $k3[$xy3];
271
                    $k4 = ['', 'یک', 'دو', 'سه', 'چهار', 'پنج', 'شش', 'هفت', 'هشت', 'نه'];
272
                    $h4 = $k4[$xy4];
273
                }
274
                $array[$type] = (($num > 99) ? str_replace(['12', '13', '14', '19', '20'], ['هزار و دویست', 'هزار و سیصد', 'هزار و چهارصد', 'هزار و نهصد', 'دوهزار'], substr($num, 0, 2)) . ((substr($num, 2, 2) == '00') ? '' : ' و ') : '') . $h3 . $p34 . $h34 . $h4;
275
                break;
276
277
            case'mm':
278
                $key = ['فروردین', 'اردیبهشت', 'خرداد', 'تیر', 'مرداد', 'شهریور', 'مهر', 'آبان', 'آذر', 'دی', 'بهمن', 'اسفند'];
279
                $array[$type] = $key[$num - 1];
280
                break;
281
282
            case'rr':
283
                $key = ['یک', 'دو', 'سه', 'چهار', 'پنج', 'شش', 'هفت', 'هشت', 'نه', 'ده', 'یازده', 'دوازده', 'سیزده'
284
                    , 'چهارده', 'پانزده', 'شانزده', 'هفده', 'هجده', 'نوزده', 'بیست', 'بیست و یک', 'بیست و دو', 'بیست و سه'
285
                    , 'بیست و چهار', 'بیست و پنج', 'بیست و شش', 'بیست و هفت', 'بیست و هشت', 'بیست و نه', 'سی', 'سی و یک'];
286
                $array[$type] = $key[$num - 1];
287
                break;
288
289
            case'rh':
290
                $key = ['یکشنبه', 'دوشنبه', 'سه شنبه', 'چهارشنبه', 'پنجشنبه', 'جمعه', 'شنبه'];
291
                $array[$type] = $key[$num];
292
                break;
293
294
            case'sh':
295
                $key = ['مار', 'اسب', 'گوسفند', 'میمون', 'مرغ', 'سگ', 'خوک', 'موش', 'گاو', 'پلنگ', 'خرگوش', 'نهنگ'];
296
                $array[$type] = $key[$num % 12];
297
                break;
298
299
            case'mb':
300
                $key = array('حمل', 'ثور', 'جوزا', 'سرطان', 'اسد', 'سنبله', 'میزان', 'عقرب', 'قوس', 'جدی', 'دلو', 'حوت');
301
                $array[$type] = $key[$num - 1];
302
                break;
303
304
            case'ff':
305
                $key = ['بهار', 'تابستان', 'پاییز', 'زمستان'];
306
                $array[$type] = $key[(int)($num / 3.1)];
307
                break;
308
309
            case'km':
310
                $key = ['فر', 'ار', 'خر', 'تی‍', 'مر', 'شه‍', 'مه‍', 'آب‍', 'آذ', 'دی', 'به‍', 'اس‍'];
311
                $array[$type] = $key[$num - 1];
312
                break;
313
314
            case'kh':
315
                $key = ['ی', 'د', 'س', 'چ', 'پ', 'ج', 'ش'];
316
                $array[$type] = $key[$num];
317
                break;
318
319
            default:
320
                $array[$type] = $num;
321
        }
322
    }
323
    return ($mod === '') ? $array : implode($mod, $array);
324
}
325
326
/**
327
 * @param $gy
328
 * @param $gm
329
 * @param $gd
330
 * @param string $mod
331
 * @return array|string
332
 */
333
function gregorian_to_jalali($gy, $gm, $gd, $mod = '')
334
{
335
    list($gy, $gm, $gd) = explode('_', tr_num($gy . '_' . $gm . '_' . $gd));/* <= Extra :اين سطر ، جزء تابع اصلي نيست */
336
    $g_d_m = [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334];
337
    if ($gy > 1600) {
338
        $jy = 979;
339
        $gy -= 1600;
340
    } else {
341
        $jy = 0;
342
        $gy -= 621;
343
    }
344
    $gy2 = ($gm > 2) ? ($gy + 1) : $gy;
345
    $days = (365 * $gy) + ((int)(($gy2 + 3) / 4)) - ((int)(($gy2 + 99) / 100)) + ((int)(($gy2 + 399) / 400)) - 80 + $gd + $g_d_m[$gm - 1];
346
    $jy += 33 * ((int)($days / 12053));
347
    $days %= 12053;
348
    $jy += 4 * ((int)($days / 1461));
349
    $days %= 1461;
350
    $jy += (int)(($days - 1) / 365);
351
    if ($days > 365) {
352
        $days = ($days - 1) % 365;
353
    }
354
    if ($days < 186) {
355
        $jm = 1 + (int)($days / 31);
356
        $jd = 1 + ($days % 31);
357
    } else {
358
        $jm = 7 + (int)(($days - 186) / 30);
359
        $jd = 1 + (($days - 186) % 30);
360
    }
361
    return ($mod === '') ? [$jy, $jm, $jd] : $jy . $mod . $jm . $mod . $jd;
362
}
363