X-Git-Url: http://wagnertech.de/git?p=kivitendo-erp.git;a=blobdiff_plain;f=SL%2FHelper%2FDateTime.pm;fp=SL%2FHelper%2FDateTime.pm;h=15ab95a7b7473519989cd0f92aca72e4029a6830;hp=831e3018550c2a274fcf0da1ebdec84265e8fcfc;hb=53593baa211863fbf66540cf1bcc36c8fb37257f;hpb=deb4d2dbb676d7d6f69dfe7815d6e0cb09bd4a44 diff --git a/SL/Helper/DateTime.pm b/SL/Helper/DateTime.pm index 831e30185..15ab95a7b 100644 --- a/SL/Helper/DateTime.pm +++ b/SL/Helper/DateTime.pm @@ -2,8 +2,12 @@ package DateTime; use strict; +use DateTime::Format::Strptime; + use SL::Util qw(_hashify); +my ($ymd_parser, $ymdhms_parser); + sub new_local { my ($class, %params) = @_; return $class->new(hour => 0, minute => 0, second => 0, time_zone => $::locale->get_local_time_zone, %params); @@ -94,6 +98,37 @@ sub next_workday { return $self; } +sub from_ymd { + my ($class, $ymd_string) = @_; + + if (!$ymd_parser) { + $ymd_parser = DateTime::Format::Strptime->new( + pattern => '%Y-%m-%d', + locale => 'de_DE', + time_zone => 'local' + ); + } + + return $ymd_parser->parse_datetime($ymd_string // ''); +} + +sub from_ymdhms { + my ($class, $ymdhms_string) = @_; + + if (!$ymdhms_parser) { + $ymdhms_parser = DateTime::Format::Strptime->new( + pattern => '%Y-%m-%dT%H:%M:%S', + locale => 'de_DE', + time_zone => 'local' + ); + } + + $ymdhms_string //= ''; + $ymdhms_string =~ s{ }{T}; + + return $ymdhms_parser->parse_datetime($ymdhms_string); +} + 1; __END__ @@ -138,6 +173,17 @@ component (as opposed to L). The legacy name C is still supported. +=item C + +Parses a date string in the ISO 8601 format C and returns +an instance of L. The time is set to midnight (00:00:00). + +=item C + +Parses a date/time string in the ISO 8601 format +C (a space instead of C is also supported) and +returns an instance of L. + =item C Sets the object to the last day of object's month at midnight. Returns