use SL::Util qw(_hashify);
+sub new_local {
+ my ($class, %params) = @_;
+ return $class->new(hour => 0, minute => 0, second => 0, time_zone => $::locale->get_local_time_zone, %params);
+}
+
sub now_local {
return shift->now(time_zone => $::locale->get_local_time_zone);
}
$self->add_business_duration(%params);
}
+sub end_of_month {
+ my ($self) = @_;
+ return $self->truncate(to => 'month')->add(months => 1)->subtract(days => 1);
+}
+
+sub next_workday {
+ my ($self, %params) = @_;
+
+ my $extra_days = $params{extra_days} // 1;
+ $self->add(days => $extra_days);
+
+ my $day_of_week = $self->day_of_week;
+ $self->add(days => (8 - $day_of_week)) if $day_of_week >= 6;
+
+ return $self;
+}
+
1;
__END__
=over 4
+=item C<new_local %params>
+
+Returns the time given in C<%params> with the time zone set to the
+local time zone.
+
=item C<now_local>
Returns the current time with the time zone set to the local time zone.
The legacy name C<from_lxoffice> is still supported.
+=item C<end_of_month>
+
+Sets the object to the last day of object's month at midnight. Returns
+the object itself.
+
+=item C<next_workday %params>
+
+Sets the object to the next workday. The recognized parameter is:
+
+=over 2
+
+=item * C<extra_days> - optional: If C<extra_days> is given, then
+that amount of days is added to the objects date and if the resulting
+date is not a workday, the object is set to the next workday.
+Defaults to 1.
+
+=back
+
+Returns the object itself.
+
=back
=head1 AUTHOR