Spamworldpro Mini Shell
Spamworldpro


Server : Apache
System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64
User : corals ( 1002)
PHP Version : 7.4.33
Disable Function : exec,passthru,shell_exec,system
Directory :  /home/corals/mautic.corals.io/vendor/simshaun/recurr/src/Recurr/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/corals/mautic.corals.io/vendor/simshaun/recurr/src/Recurr/RecurrenceCollection.php
<?php

/*
 * Copyright 2014 Shaun Simmons
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace Recurr;

use \Doctrine\Common\Collections\ArrayCollection as BaseCollection;

/**
 * @package Recurr
 * @author  Shaun Simmons <[email protected]>
 */
class RecurrenceCollection extends BaseCollection
{
    /**
     * @param \DateTimeInterface $after
     * @param \DateTimeInterface $before
     * @param bool      $inc Include $after or $before if they happen to be a recurrence.
     *
     * @return RecurrenceCollection
     */
    public function startsBetween(\DateTimeInterface $after, \DateTimeInterface $before, $inc = false)
    {
        return $this->filter(
            function ($recurrence) use ($after, $before, $inc) {
                /** @var $recurrence Recurrence */
                $start = $recurrence->getStart();

                if ($inc) {
                    return $start >= $after && $start <= $before;
                }

                return $start > $after && $start < $before;
            }
        );
    }

    /**
     * @param \DateTimeInterface $before
     * @param bool               $inc Include $before if it is a recurrence.
     *
     * @return RecurrenceCollection
     */
    public function startsBefore(\DateTimeInterface $before, $inc = false)
    {
        return $this->filter(
            function ($recurrence) use ($before, $inc) {
                /** @var $recurrence Recurrence */
                $start = $recurrence->getStart();

                if ($inc) {
                    return $start <= $before;
                }

                return $start < $before;
            }
        );
    }

    /**
     * @param \DateTimeInterface $after
     * @param bool               $inc Include $after if it a recurrence.
     *
     * @return RecurrenceCollection
     */
    public function startsAfter(\DateTimeInterface $after, $inc = false)
    {
        return $this->filter(
            function ($recurrence) use ($after, $inc) {
                /** @var $recurrence Recurrence */
                $start = $recurrence->getStart();

                if ($inc) {
                    return $start >= $after;
                }

                return $start > $after;
            }
        );
    }

    /**
     * @param \DateTimeInterface $after
     * @param \DateTimeInterface $before
     * @param bool               $inc Include $after or $before if they happen to be a recurrence.
     *
     * @return RecurrenceCollection
     */
    public function endsBetween(\DateTimeInterface $after, \DateTimeInterface $before, $inc = false)
    {
        return $this->filter(
            function ($recurrence) use ($after, $before, $inc) {
                /** @var $recurrence Recurrence */
                $end = $recurrence->getEnd();

                if ($inc) {
                    return $end >= $after && $end <= $before;
                }

                return $end > $after && $end < $before;
            }
        );
    }

    /**
     * @param \DateTimeInterface $before
     * @param bool               $inc Include $before if it is a recurrence.
     *
     * @return RecurrenceCollection
     */
    public function endsBefore(\DateTimeInterface $before, $inc = false)
    {
        return $this->filter(
            function ($recurrence) use ($before, $inc) {
                /** @var $recurrence Recurrence */
                $end = $recurrence->getEnd();

                if ($inc) {
                    return $end <= $before;
                }

                return $end < $before;
            }
        );
    }

    /**
     * @param \DateTimeInterface $after
     * @param bool               $inc Include $after if it a recurrence.
     *
     * @return RecurrenceCollection
     */
    public function endsAfter(\DateTimeInterface $after, $inc = false)
    {
        return $this->filter(
            function ($recurrence) use ($after, $inc) {
                /** @var $recurrence Recurrence */
                $end = $recurrence->getEnd();

                if ($inc) {
                    return $end >= $after;
                }

                return $end > $after;
            }
        );
    }
}

Spamworldpro Mini