/var/www/html_uk/wp-content/plugins/automatewoo/includes/DateTime.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
<?php

namespace AutomateWoo;

use 
DateInterval;
use 
DateTimeZone;

defined'ABSPATH' ) || exit;

/**
 * Class DateTime
 *
 * @since 4.3.0
 */
class DateTime extends \DateTime {

    
/**
     * Same as parent but forces UTC timezone if no timezone is supplied instead of using the PHP default.
     *
     * @param string              $time
     * @param DateTimeZone|string $timezone
     *
     * @throws \Exception Emits Exception in case of an error.
     * @throws \DateMalformedStringException When a malformed time string is used (PHP 8.3+).
     */
    
public function __construct$time 'now'$timezone null ) {
        if ( ! 
$timezone ) {
            
$timezone = new DateTimeZone'UTC' );
        }

        
parent::__construct$time$timezone instanceof DateTimeZone $timezone null );
    }


    
/**
     * Convert DateTime from site timezone to UTC.
     *
     * Note this doesn't actually set the timezone property, it directly modifies the date.
     *
     * @return $this
     */
    
public function convert_to_utc_time() {
        
Time_Helper::convert_to_gmt$this );
        return 
$this;
    }


    
/**
     * Convert DateTime from UTC to the site timezone.
     *
     * Note this doesn't actually set the timezone property, it directly modifies the date.
     *
     * @return $this
     */
    
public function convert_to_site_time() {
        
Time_Helper::convert_from_gmt$this );
        return 
$this;
    }


    
/**
     * @since 4.4.0
     *
     * @return string
     */
    
public function to_mysql_string() {
        return 
$this->format'Y-m-d H:i:s' );
    }

    
/**
     * Set time to the day end in the current timezone.
     *
     * @return $this
     *
     * @since 4.6.0
     */
    
public function set_time_to_day_start() {
        
$this->setTime00);
        return 
$this;
    }

    
/**
     * Set time to the day start in the current timezone.
     *
     * @return $this
     *
     * @since 4.6.0
     */
    
public function set_time_to_day_end() {
        
$this->setTime235959 );
        return 
$this;
    }

    
/**
     * Return a formatted localised date. Wrapper for date_i18n function.
     *
     * @since  4.9.8
     * @param  string $format Date format.
     * @return string
     */
    
public function format_i18n$format 'Y-m-d' ) {
        return 
date_i18n$format$this->getTimestamp() );
    }

    
/**
     * Naturally add months without skipping into the next month.
     *
     * @since 5.1.0
     * @param integer $months_to_add
     * @throws \Exception When months isn't a valid number.
     */
    
public function add_natural_months$months_to_add ) {
        
$original_day $this->format'd' );
        
$this->add( new DateInterval'P' intval$months_to_add ) . 'M' ) );
        
$new_day $this->format'd' );

        if ( 
$original_day !== $new_day ) {
            
// Check if the day is changed, if so we skipped to another month.
            // Subtract days to go back to the last day of previous month.
            
$this->sub( new DateInterval'P' intval$new_day ) . 'D' ) );
        }
    }
}