summaryrefslogtreecommitdiff
path: root/includes/composer/vendor
diff options
context:
space:
mode:
authorRaindropsSys <raindrops@equestria.dev>2024-03-30 23:40:33 +0100
committerRaindropsSys <raindrops@equestria.dev>2024-03-30 23:40:33 +0100
commit6b796258d413f00e498ce7f80f73a9f6c061f29c (patch)
tree49e64a5dd4cde2acff7f0a93ed3f8e20e1cb2dc8 /includes/composer/vendor
parent5860551daa0f60103ad24e93da29f401a653f144 (diff)
downloadpluralconnect-6b796258d413f00e498ce7f80f73a9f6c061f29c.tar.gz
pluralconnect-6b796258d413f00e498ce7f80f73a9f6c061f29c.tar.bz2
pluralconnect-6b796258d413f00e498ce7f80f73a9f6c061f29c.zip
Updated 5 files, added 2 files, deleted 495 files and renamed 7 files (automated)
Diffstat (limited to 'includes/composer/vendor')
-rw-r--r--includes/composer/vendor/autoload.php25
-rw-r--r--includes/composer/vendor/composer/ClassLoader.php585
-rw-r--r--includes/composer/vendor/composer/InstalledVersions.php352
-rw-r--r--includes/composer/vendor/composer/LICENSE21
-rw-r--r--includes/composer/vendor/composer/autoload_classmap.php14
-rw-r--r--includes/composer/vendor/composer/autoload_namespaces.php9
-rw-r--r--includes/composer/vendor/composer/autoload_psr4.php10
-rw-r--r--includes/composer/vendor/composer/autoload_real.php38
-rw-r--r--includes/composer/vendor/composer/autoload_static.php40
-rw-r--r--includes/composer/vendor/composer/installed.json123
-rw-r--r--includes/composer/vendor/composer/installed.php41
-rw-r--r--includes/composer/vendor/composer/platform_check.php26
-rw-r--r--includes/composer/vendor/ksubileau/color-thief-php/LICENSE21
-rw-r--r--includes/composer/vendor/ksubileau/color-thief-php/composer.json45
-rw-r--r--includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Color.php145
-rw-r--r--includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/ColorThief.php539
-rw-r--r--includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/Exception.php21
-rw-r--r--includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/InvalidArgumentException.php22
-rw-r--r--includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/NotReadableException.php22
-rw-r--r--includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/NotSupportedException.php22
-rw-r--r--includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/RuntimeException.php19
-rw-r--r--includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/AbstractAdapter.php78
-rw-r--r--includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/AdapterInterface.php74
-rw-r--r--includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/GdAdapter.php119
-rw-r--r--includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/GmagickAdapter.php105
-rw-r--r--includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/ImagickAdapter.php116
-rw-r--r--includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/ImageLoader.php195
-rw-r--r--includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/PQueue.php129
-rw-r--r--includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/VBox.php219
-rw-r--r--includes/composer/vendor/om/icalparser/.github/workflows/php.yml40
-rw-r--r--includes/composer/vendor/om/icalparser/.github/workflows/typo.yml14
-rw-r--r--includes/composer/vendor/om/icalparser/.gitignore4
-rw-r--r--includes/composer/vendor/om/icalparser/LICENSE24
-rw-r--r--includes/composer/vendor/om/icalparser/bin/timezones.php20
-rw-r--r--includes/composer/vendor/om/icalparser/composer.json33
-rw-r--r--includes/composer/vendor/om/icalparser/example/index.php33
-rw-r--r--includes/composer/vendor/om/icalparser/readme.md79
-rw-r--r--includes/composer/vendor/om/icalparser/src/EventsList.php56
-rw-r--r--includes/composer/vendor/om/icalparser/src/Freq.php634
-rw-r--r--includes/composer/vendor/om/icalparser/src/IcalParser.php502
-rw-r--r--includes/composer/vendor/om/icalparser/src/Recurrence.php234
-rw-r--r--includes/composer/vendor/om/icalparser/src/WindowsTimezones.php214
-rw-r--r--includes/composer/vendor/om/icalparser/tests/bootstrap.php21
-rw-r--r--includes/composer/vendor/om/icalparser/tests/cal/38_weekly_recurring_event_missing_day.ics59
-rw-r--r--includes/composer/vendor/om/icalparser/tests/cal/FrenchHolidays.ics382
-rw-r--r--includes/composer/vendor/om/icalparser/tests/cal/basic.ics616
-rwxr-xr-xincludes/composer/vendor/om/icalparser/tests/cal/blank_description.ics51
-rwxr-xr-xincludes/composer/vendor/om/icalparser/tests/cal/blank_line_end.ics4
-rwxr-xr-xincludes/composer/vendor/om/icalparser/tests/cal/blank_line_mid.ics4
-rwxr-xr-xincludes/composer/vendor/om/icalparser/tests/cal/daily_recur.ics52
-rwxr-xr-xincludes/composer/vendor/om/icalparser/tests/cal/daily_recur2.ics41
-rwxr-xr-xincludes/composer/vendor/om/icalparser/tests/cal/day_long_recur_yearly.ics52
-rwxr-xr-xincludes/composer/vendor/om/icalparser/tests/cal/forced_types.ics50
-rwxr-xr-xincludes/composer/vendor/om/icalparser/tests/cal/google_birthday.ics90
-rwxr-xr-xincludes/composer/vendor/om/icalparser/tests/cal/minimal.ics39
-rw-r--r--includes/composer/vendor/om/icalparser/tests/cal/missing-timezone.ics47
-rw-r--r--includes/composer/vendor/om/icalparser/tests/cal/missing_RRULE_notice.ics39
-rw-r--r--includes/composer/vendor/om/icalparser/tests/cal/multiline_description.ics52
-rwxr-xr-xincludes/composer/vendor/om/icalparser/tests/cal/multiple_attachments.ics45
-rwxr-xr-xincludes/composer/vendor/om/icalparser/tests/cal/multiple_categories.ics67
-rwxr-xr-xincludes/composer/vendor/om/icalparser/tests/cal/multiple_rrules.ics45
-rwxr-xr-xincludes/composer/vendor/om/icalparser/tests/cal/parserv2.ics45
-rw-r--r--includes/composer/vendor/om/icalparser/tests/cal/readme.md3
-rwxr-xr-xincludes/composer/vendor/om/icalparser/tests/cal/recur_instances.ics92
-rwxr-xr-xincludes/composer/vendor/om/icalparser/tests/cal/recur_instances_finite.ics50
-rw-r--r--includes/composer/vendor/om/icalparser/tests/cal/recur_instances_with_modifications.ics63
-rw-r--r--includes/composer/vendor/om/icalparser/tests/cal/recur_instances_with_modifications_and_interval.ics578
-rwxr-xr-xincludes/composer/vendor/om/icalparser/tests/cal/recur_instances_with_modifications_to_first_day.ics57
-rw-r--r--includes/composer/vendor/om/icalparser/tests/cal/rrule_interval.ics34
-rw-r--r--includes/composer/vendor/om/icalparser/tests/cal/url.ics32
-rwxr-xr-xincludes/composer/vendor/om/icalparser/tests/cal/utc_negative_zero.ics27
-rw-r--r--includes/composer/vendor/om/icalparser/tests/cal/weird_windows_timezones.ics237
-rw-r--r--includes/composer/vendor/om/icalparser/tests/cal/wrong_dates.ics37
-rw-r--r--includes/composer/vendor/om/icalparser/tests/event.attachements.phpt26
-rw-r--r--includes/composer/vendor/om/icalparser/tests/event.categories.phpt25
-rw-r--r--includes/composer/vendor/om/icalparser/tests/event.dates.phpt25
-rw-r--r--includes/composer/vendor/om/icalparser/tests/event.description.phpt34
-rw-r--r--includes/composer/vendor/om/icalparser/tests/event.timezones.phpt39
-rw-r--r--includes/composer/vendor/om/icalparser/tests/event.url.phpt22
-rw-r--r--includes/composer/vendor/om/icalparser/tests/events.recurring.phpt260
-rw-r--r--includes/composer/vendor/om/icalparser/tests/events.sorting.phpt36
-rw-r--r--includes/composer/vendor/om/icalparser/tests/missing.timezone.phpt24
82 files changed, 0 insertions, 8564 deletions
diff --git a/includes/composer/vendor/autoload.php b/includes/composer/vendor/autoload.php
deleted file mode 100644
index 5b16029..0000000
--- a/includes/composer/vendor/autoload.php
+++ /dev/null
@@ -1,25 +0,0 @@
-<?php
-
-// autoload.php @generated by Composer
-
-if (PHP_VERSION_ID < 50600) {
- if (!headers_sent()) {
- header('HTTP/1.1 500 Internal Server Error');
- }
- $err = 'Composer 2.3.0 dropped support for autoloading on PHP <5.6 and you are running '.PHP_VERSION.', please upgrade PHP or use Composer 2.2 LTS via "composer self-update --2.2". Aborting.'.PHP_EOL;
- if (!ini_get('display_errors')) {
- if (PHP_SAPI === 'cli' || PHP_SAPI === 'phpdbg') {
- fwrite(STDERR, $err);
- } elseif (!headers_sent()) {
- echo $err;
- }
- }
- trigger_error(
- $err,
- E_USER_ERROR
- );
-}
-
-require_once __DIR__ . '/composer/autoload_real.php';
-
-return ComposerAutoloaderInit7bef9e3ab3ffae606875b2457b7bf1cb::getLoader();
diff --git a/includes/composer/vendor/composer/ClassLoader.php b/includes/composer/vendor/composer/ClassLoader.php
deleted file mode 100644
index a72151c..0000000
--- a/includes/composer/vendor/composer/ClassLoader.php
+++ /dev/null
@@ -1,585 +0,0 @@
-<?php
-
-/*
- * This file is part of Composer.
- *
- * (c) Nils Adermann <naderman@naderman.de>
- * Jordi Boggiano <j.boggiano@seld.be>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
-namespace Composer\Autoload;
-
-/**
- * ClassLoader implements a PSR-0, PSR-4 and classmap class loader.
- *
- * $loader = new \Composer\Autoload\ClassLoader();
- *
- * // register classes with namespaces
- * $loader->add('Symfony\Component', __DIR__.'/component');
- * $loader->add('Symfony', __DIR__.'/framework');
- *
- * // activate the autoloader
- * $loader->register();
- *
- * // to enable searching the include path (eg. for PEAR packages)
- * $loader->setUseIncludePath(true);
- *
- * In this example, if you try to use a class in the Symfony\Component
- * namespace or one of its children (Symfony\Component\Console for instance),
- * the autoloader will first look for the class under the component/
- * directory, and it will then fallback to the framework/ directory if not
- * found before giving up.
- *
- * This class is loosely based on the Symfony UniversalClassLoader.
- *
- * @author Fabien Potencier <fabien@symfony.com>
- * @author Jordi Boggiano <j.boggiano@seld.be>
- * @see https://www.php-fig.org/psr/psr-0/
- * @see https://www.php-fig.org/psr/psr-4/
- */
-class ClassLoader
-{
- /** @var \Closure(string):void */
- private static $includeFile;
-
- /** @var ?string */
- private $vendorDir;
-
- // PSR-4
- /**
- * @var array[]
- * @psalm-var array<string, array<string, int>>
- */
- private $prefixLengthsPsr4 = array();
- /**
- * @var array[]
- * @psalm-var array<string, array<int, string>>
- */
- private $prefixDirsPsr4 = array();
- /**
- * @var array[]
- * @psalm-var array<string, string>
- */
- private $fallbackDirsPsr4 = array();
-
- // PSR-0
- /**
- * @var array[]
- * @psalm-var array<string, array<string, string[]>>
- */
- private $prefixesPsr0 = array();
- /**
- * @var array[]
- * @psalm-var array<string, string>
- */
- private $fallbackDirsPsr0 = array();
-
- /** @var bool */
- private $useIncludePath = false;
-
- /**
- * @var string[]
- * @psalm-var array<string, string>
- */
- private $classMap = array();
-
- /** @var bool */
- private $classMapAuthoritative = false;
-
- /**
- * @var bool[]
- * @psalm-var array<string, bool>
- */
- private $missingClasses = array();
-
- /** @var ?string */
- private $apcuPrefix;
-
- /**
- * @var self[]
- */
- private static $registeredLoaders = array();
-
- /**
- * @param ?string $vendorDir
- */
- public function __construct($vendorDir = null)
- {
- $this->vendorDir = $vendorDir;
- self::initializeIncludeClosure();
- }
-
- /**
- * @return string[]
- */
- public function getPrefixes()
- {
- if (!empty($this->prefixesPsr0)) {
- return call_user_func_array('array_merge', array_values($this->prefixesPsr0));
- }
-
- return array();
- }
-
- /**
- * @return array[]
- * @psalm-return array<string, array<int, string>>
- */
- public function getPrefixesPsr4()
- {
- return $this->prefixDirsPsr4;
- }
-
- /**
- * @return array[]
- * @psalm-return array<string, string>
- */
- public function getFallbackDirs()
- {
- return $this->fallbackDirsPsr0;
- }
-
- /**
- * @return array[]
- * @psalm-return array<string, string>
- */
- public function getFallbackDirsPsr4()
- {
- return $this->fallbackDirsPsr4;
- }
-
- /**
- * @return string[] Array of classname => path
- * @psalm-return array<string, string>
- */
- public function getClassMap()
- {
- return $this->classMap;
- }
-
- /**
- * @param string[] $classMap Class to filename map
- * @psalm-param array<string, string> $classMap
- *
- * @return void
- */
- public function addClassMap(array $classMap)
- {
- if ($this->classMap) {
- $this->classMap = array_merge($this->classMap, $classMap);
- } else {
- $this->classMap = $classMap;
- }
- }
-
- /**
- * Registers a set of PSR-0 directories for a given prefix, either
- * appending or prepending to the ones previously set for this prefix.
- *
- * @param string $prefix The prefix
- * @param string[]|string $paths The PSR-0 root directories
- * @param bool $prepend Whether to prepend the directories
- *
- * @return void
- */
- public function add($prefix, $paths, $prepend = false)
- {
- if (!$prefix) {
- if ($prepend) {
- $this->fallbackDirsPsr0 = array_merge(
- (array) $paths,
- $this->fallbackDirsPsr0
- );
- } else {
- $this->fallbackDirsPsr0 = array_merge(
- $this->fallbackDirsPsr0,
- (array) $paths
- );
- }
-
- return;
- }
-
- $first = $prefix[0];
- if (!isset($this->prefixesPsr0[$first][$prefix])) {
- $this->prefixesPsr0[$first][$prefix] = (array) $paths;
-
- return;
- }
- if ($prepend) {
- $this->prefixesPsr0[$first][$prefix] = array_merge(
- (array) $paths,
- $this->prefixesPsr0[$first][$prefix]
- );
- } else {
- $this->prefixesPsr0[$first][$prefix] = array_merge(
- $this->prefixesPsr0[$first][$prefix],
- (array) $paths
- );
- }
- }
-
- /**
- * Registers a set of PSR-4 directories for a given namespace, either
- * appending or prepending to the ones previously set for this namespace.
- *
- * @param string $prefix The prefix/namespace, with trailing '\\'
- * @param string[]|string $paths The PSR-4 base directories
- * @param bool $prepend Whether to prepend the directories
- *
- * @throws \InvalidArgumentException
- *
- * @return void
- */
- public function addPsr4($prefix, $paths, $prepend = false)
- {
- if (!$prefix) {
- // Register directories for the root namespace.
- if ($prepend) {
- $this->fallbackDirsPsr4 = array_merge(
- (array) $paths,
- $this->fallbackDirsPsr4
- );
- } else {
- $this->fallbackDirsPsr4 = array_merge(
- $this->fallbackDirsPsr4,
- (array) $paths
- );
- }
- } elseif (!isset($this->prefixDirsPsr4[$prefix])) {
- // Register directories for a new namespace.
- $length = strlen($prefix);
- if ('\\' !== $prefix[$length - 1]) {
- throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator.");
- }
- $this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length;
- $this->prefixDirsPsr4[$prefix] = (array) $paths;
- } elseif ($prepend) {
- // Prepend directories for an already registered namespace.
- $this->prefixDirsPsr4[$prefix] = array_merge(
- (array) $paths,
- $this->prefixDirsPsr4[$prefix]
- );
- } else {
- // Append directories for an already registered namespace.
- $this->prefixDirsPsr4[$prefix] = array_merge(
- $this->prefixDirsPsr4[$prefix],
- (array) $paths
- );
- }
- }
-
- /**
- * Registers a set of PSR-0 directories for a given prefix,
- * replacing any others previously set for this prefix.
- *
- * @param string $prefix The prefix
- * @param string[]|string $paths The PSR-0 base directories
- *
- * @return void
- */
- public function set($prefix, $paths)
- {
- if (!$prefix) {
- $this->fallbackDirsPsr0 = (array) $paths;
- } else {
- $this->prefixesPsr0[$prefix[0]][$prefix] = (array) $paths;
- }
- }
-
- /**
- * Registers a set of PSR-4 directories for a given namespace,
- * replacing any others previously set for this namespace.
- *
- * @param string $prefix The prefix/namespace, with trailing '\\'
- * @param string[]|string $paths The PSR-4 base directories
- *
- * @throws \InvalidArgumentException
- *
- * @return void
- */
- public function setPsr4($prefix, $paths)
- {
- if (!$prefix) {
- $this->fallbackDirsPsr4 = (array) $paths;
- } else {
- $length = strlen($prefix);
- if ('\\' !== $prefix[$length - 1]) {
- throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator.");
- }
- $this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length;
- $this->prefixDirsPsr4[$prefix] = (array) $paths;
- }
- }
-
- /**
- * Turns on searching the include path for class files.
- *
- * @param bool $useIncludePath
- *
- * @return void
- */
- public function setUseIncludePath($useIncludePath)
- {
- $this->useIncludePath = $useIncludePath;
- }
-
- /**
- * Can be used to check if the autoloader uses the include path to check
- * for classes.
- *
- * @return bool
- */
- public function getUseIncludePath()
- {
- return $this->useIncludePath;
- }
-
- /**
- * Turns off searching the prefix and fallback directories for classes
- * that have not been registered with the class map.
- *
- * @param bool $classMapAuthoritative
- *
- * @return void
- */
- public function setClassMapAuthoritative($classMapAuthoritative)
- {
- $this->classMapAuthoritative = $classMapAuthoritative;
- }
-
- /**
- * Should class lookup fail if not found in the current class map?
- *
- * @return bool
- */
- public function isClassMapAuthoritative()
- {
- return $this->classMapAuthoritative;
- }
-
- /**
- * APCu prefix to use to cache found/not-found classes, if the extension is enabled.
- *
- * @param string|null $apcuPrefix
- *
- * @return void
- */
- public function setApcuPrefix($apcuPrefix)
- {
- $this->apcuPrefix = function_exists('apcu_fetch') && filter_var(ini_get('apc.enabled'), FILTER_VALIDATE_BOOLEAN) ? $apcuPrefix : null;
- }
-
- /**
- * The APCu prefix in use, or null if APCu caching is not enabled.
- *
- * @return string|null
- */
- public function getApcuPrefix()
- {
- return $this->apcuPrefix;
- }
-
- /**
- * Registers this instance as an autoloader.
- *
- * @param bool $prepend Whether to prepend the autoloader or not
- *
- * @return void
- */
- public function register($prepend = false)
- {
- spl_autoload_register(array($this, 'loadClass'), true, $prepend);
-
- if (null === $this->vendorDir) {
- return;
- }
-
- if ($prepend) {
- self::$registeredLoaders = array($this->vendorDir => $this) + self::$registeredLoaders;
- } else {
- unset(self::$registeredLoaders[$this->vendorDir]);
- self::$registeredLoaders[$this->vendorDir] = $this;
- }
- }
-
- /**
- * Unregisters this instance as an autoloader.
- *
- * @return void
- */
- public function unregister()
- {
- spl_autoload_unregister(array($this, 'loadClass'));
-
- if (null !== $this->vendorDir) {
- unset(self::$registeredLoaders[$this->vendorDir]);
- }
- }
-
- /**
- * Loads the given class or interface.
- *
- * @param string $class The name of the class
- * @return true|null True if loaded, null otherwise
- */
- public function loadClass($class)
- {
- if ($file = $this->findFile($class)) {
- $includeFile = self::$includeFile;
- $includeFile($file);
-
- return true;
- }
-
- return null;
- }
-
- /**
- * Finds the path to the file where the class is defined.
- *
- * @param string $class The name of the class
- *
- * @return string|false The path if found, false otherwise
- */
- public function findFile($class)
- {
- // class map lookup
- if (isset($this->classMap[$class])) {
- return $this->classMap[$class];
- }
- if ($this->classMapAuthoritative || isset($this->missingClasses[$class])) {
- return false;
- }
- if (null !== $this->apcuPrefix) {
- $file = apcu_fetch($this->apcuPrefix.$class, $hit);
- if ($hit) {
- return $file;
- }
- }
-
- $file = $this->findFileWithExtension($class, '.php');
-
- // Search for Hack files if we are running on HHVM
- if (false === $file && defined('HHVM_VERSION')) {
- $file = $this->findFileWithExtension($class, '.hh');
- }
-
- if (null !== $this->apcuPrefix) {
- apcu_add($this->apcuPrefix.$class, $file);
- }
-
- if (false === $file) {
- // Remember that this class does not exist.
- $this->missingClasses[$class] = true;
- }
-
- return $file;
- }
-
- /**
- * Returns the currently registered loaders indexed by their corresponding vendor directories.
- *
- * @return self[]
- */
- public static function getRegisteredLoaders()
- {
- return self::$registeredLoaders;
- }
-
- /**
- * @param string $class
- * @param string $ext
- * @return string|false
- */
- private function findFileWithExtension($class, $ext)
- {
- // PSR-4 lookup
- $logicalPathPsr4 = strtr($class, '\\', DIRECTORY_SEPARATOR) . $ext;
-
- $first = $class[0];
- if (isset($this->prefixLengthsPsr4[$first])) {
- $subPath = $class;
- while (false !== $lastPos = strrpos($subPath, '\\')) {
- $subPath = substr($subPath, 0, $lastPos);
- $search = $subPath . '\\';
- if (isset($this->prefixDirsPsr4[$search])) {
- $pathEnd = DIRECTORY_SEPARATOR . substr($logicalPathPsr4, $lastPos + 1);
- foreach ($this->prefixDirsPsr4[$search] as $dir) {
- if (file_exists($file = $dir . $pathEnd)) {
- return $file;
- }
- }
- }
- }
- }
-
- // PSR-4 fallback dirs
- foreach ($this->fallbackDirsPsr4 as $dir) {
- if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr4)) {
- return $file;
- }
- }
-
- // PSR-0 lookup
- if (false !== $pos = strrpos($class, '\\')) {
- // namespaced class name
- $logicalPathPsr0 = substr($logicalPathPsr4, 0, $pos + 1)
- . strtr(substr($logicalPathPsr4, $pos + 1), '_', DIRECTORY_SEPARATOR);
- } else {
- // PEAR-like class name
- $logicalPathPsr0 = strtr($class, '_', DIRECTORY_SEPARATOR) . $ext;
- }
-
- if (isset($this->prefixesPsr0[$first])) {
- foreach ($this->prefixesPsr0[$first] as $prefix => $dirs) {
- if (0 === strpos($class, $prefix)) {
- foreach ($dirs as $dir) {
- if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) {
- return $file;
- }
- }
- }
- }
- }
-
- // PSR-0 fallback dirs
- foreach ($this->fallbackDirsPsr0 as $dir) {
- if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) {
- return $file;
- }
- }
-
- // PSR-0 include paths.
- if ($this->useIncludePath && $file = stream_resolve_include_path($logicalPathPsr0)) {
- return $file;
- }
-
- return false;
- }
-
- /**
- * @return void
- */
- private static function initializeIncludeClosure()
- {
- if (self::$includeFile !== null) {
- return;
- }
-
- /**
- * Scope isolated include.
- *
- * Prevents access to $this/self from included files.
- *
- * @param string $file
- * @return void
- */
- self::$includeFile = \Closure::bind(static function($file) {
- include $file;
- }, null, null);
- }
-}
diff --git a/includes/composer/vendor/composer/InstalledVersions.php b/includes/composer/vendor/composer/InstalledVersions.php
deleted file mode 100644
index c6b54af..0000000
--- a/includes/composer/vendor/composer/InstalledVersions.php
+++ /dev/null
@@ -1,352 +0,0 @@
-<?php
-
-/*
- * This file is part of Composer.
- *
- * (c) Nils Adermann <naderman@naderman.de>
- * Jordi Boggiano <j.boggiano@seld.be>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
-namespace Composer;
-
-use Composer\Autoload\ClassLoader;
-use Composer\Semver\VersionParser;
-
-/**
- * This class is copied in every Composer installed project and available to all
- *
- * See also https://getcomposer.org/doc/07-runtime.md#installed-versions
- *
- * To require its presence, you can require `composer-runtime-api ^2.0`
- *
- * @final
- */
-class InstalledVersions
-{
- /**
- * @var mixed[]|null
- * @psalm-var array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}|array{}|null
- */
- private static $installed;
-
- /**
- * @var bool|null
- */
- private static $canGetVendors;
-
- /**
- * @var array[]
- * @psalm-var array<string, array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}>
- */
- private static $installedByVendor = array();
-
- /**
- * Returns a list of all package names which are present, either by being installed, replaced or provided
- *
- * @return string[]
- * @psalm-return list<string>
- */
- public static function getInstalledPackages()
- {
- $packages = array();
- foreach (self::getInstalled() as $installed) {
- $packages[] = array_keys($installed['versions']);
- }
-
- if (1 === \count($packages)) {
- return $packages[0];
- }
-
- return array_keys(array_flip(\call_user_func_array('array_merge', $packages)));
- }
-
- /**
- * Returns a list of all package names with a specific type e.g. 'library'
- *
- * @param string $type
- * @return string[]
- * @psalm-return list<string>
- */
- public static function getInstalledPackagesByType($type)
- {
- $packagesByType = array();
-
- foreach (self::getInstalled() as $installed) {
- foreach ($installed['versions'] as $name => $package) {
- if (isset($package['type']) && $package['type'] === $type) {
- $packagesByType[] = $name;
- }
- }
- }
-
- return $packagesByType;
- }
-
- /**
- * Checks whether the given package is installed
- *
- * This also returns true if the package name is provided or replaced by another package
- *
- * @param string $packageName
- * @param bool $includeDevRequirements
- * @return bool
- */
- public static function isInstalled($packageName, $includeDevRequirements = true)
- {
- foreach (self::getInstalled() as $installed) {
- if (isset($installed['versions'][$packageName])) {
- return $includeDevRequirements || empty($installed['versions'][$packageName]['dev_requirement']);
- }
- }
-
- return false;
- }
-
- /**
- * Checks whether the given package satisfies a version constraint
- *
- * e.g. If you want to know whether version 2.3+ of package foo/bar is installed, you would call:
- *
- * Composer\InstalledVersions::satisfies(new VersionParser, 'foo/bar', '^2.3')
- *
- * @param VersionParser $parser Install composer/semver to have access to this class and functionality
- * @param string $packageName
- * @param string|null $constraint A version constraint to check for, if you pass one you have to make sure composer/semver is required by your package
- * @return bool
- */
- public static function satisfies(VersionParser $parser, $packageName, $constraint)
- {
- $constraint = $parser->parseConstraints($constraint);
- $provided = $parser->parseConstraints(self::getVersionRanges($packageName));
-
- return $provided->matches($constraint);
- }
-
- /**
- * Returns a version constraint representing all the range(s) which are installed for a given package
- *
- * It is easier to use this via isInstalled() with the $constraint argument if you need to check
- * whether a given version of a package is installed, and not just whether it exists
- *
- * @param string $packageName
- * @return string Version constraint usable with composer/semver
- */
- public static function getVersionRanges($packageName)
- {
- foreach (self::getInstalled() as $installed) {
- if (!isset($installed['versions'][$packageName])) {
- continue;
- }
-
- $ranges = array();
- if (isset($installed['versions'][$packageName]['pretty_version'])) {
- $ranges[] = $installed['versions'][$packageName]['pretty_version'];
- }
- if (array_key_exists('aliases', $installed['versions'][$packageName])) {
- $ranges = array_merge($ranges, $installed['versions'][$packageName]['aliases']);
- }
- if (array_key_exists('replaced', $installed['versions'][$packageName])) {
- $ranges = array_merge($ranges, $installed['versions'][$packageName]['replaced']);
- }
- if (array_key_exists('provided', $installed['versions'][$packageName])) {
- $ranges = array_merge($ranges, $installed['versions'][$packageName]['provided']);
- }
-
- return implode(' || ', $ranges);
- }
-
- throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
- }
-
- /**
- * @param string $packageName
- * @return string|null If the package is being replaced or provided but is not really installed, null will be returned as version, use satisfies or getVersionRanges if you need to know if a given version is present
- */
- public static function getVersion($packageName)
- {
- foreach (self::getInstalled() as $installed) {
- if (!isset($installed['versions'][$packageName])) {
- continue;
- }
-
- if (!isset($installed['versions'][$packageName]['version'])) {
- return null;
- }
-
- return $installed['versions'][$packageName]['version'];
- }
-
- throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
- }
-
- /**
- * @param string $packageName
- * @return string|null If the package is being replaced or provided but is not really installed, null will be returned as version, use satisfies or getVersionRanges if you need to know if a given version is present
- */
- public static function getPrettyVersion($packageName)
- {
- foreach (self::getInstalled() as $installed) {
- if (!isset($installed['versions'][$packageName])) {
- continue;
- }
-
- if (!isset($installed['versions'][$packageName]['pretty_version'])) {
- return null;
- }
-
- return $installed['versions'][$packageName]['pretty_version'];
- }
-
- throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
- }
-
- /**
- * @param string $packageName
- * @return string|null If the package is being replaced or provided but is not really installed, null will be returned as reference
- */
- public static function getReference($packageName)
- {
- foreach (self::getInstalled() as $installed) {
- if (!isset($installed['versions'][$packageName])) {
- continue;
- }
-
- if (!isset($installed['versions'][$packageName]['reference'])) {
- return null;
- }
-
- return $installed['versions'][$packageName]['reference'];
- }
-
- throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
- }
-
- /**
- * @param string $packageName
- * @return string|null If the package is being replaced or provided but is not really installed, null will be returned as install path. Packages of type metapackages also have a null install path.
- */
- public static function getInstallPath($packageName)
- {
- foreach (self::getInstalled() as $installed) {
- if (!isset($installed['versions'][$packageName])) {
- continue;
- }
-
- return isset($installed['versions'][$packageName]['install_path']) ? $installed['versions'][$packageName]['install_path'] : null;
- }
-
- throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
- }
-
- /**
- * @return array
- * @psalm-return array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}
- */
- public static function getRootPackage()
- {
- $installed = self::getInstalled();
-
- return $installed[0]['root'];
- }
-
- /**
- * Returns the raw installed.php data for custom implementations
- *
- * @deprecated Use getAllRawData() instead which returns all datasets for all autoloaders present in the process. getRawData only returns the first dataset loaded, which may not be what you expect.
- * @return array[]
- * @psalm-return array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}
- */
- public static function getRawData()
- {
- @trigger_error('getRawData only returns the first dataset loaded, which may not be what you expect. Use getAllRawData() instead which returns all datasets for all autoloaders present in the process.', E_USER_DEPRECATED);
-
- if (null === self::$installed) {
- // only require the installed.php file if this file is loaded from its dumped location,
- // and not from its source location in the composer/composer package, see https://github.com/composer/composer/issues/9937
- if (substr(__DIR__, -8, 1) !== 'C') {
- self::$installed = include __DIR__ . '/installed.php';
- } else {
- self::$installed = array();
- }
- }
-
- return self::$installed;
- }
-
- /**
- * Returns the raw data of all installed.php which are currently loaded for custom implementations
- *
- * @return array[]
- * @psalm-return list<array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}>
- */
- public static function getAllRawData()
- {
- return self::getInstalled();
- }
-
- /**
- * Lets you reload the static array from another file
- *
- * This is only useful for complex integrations in which a project needs to use
- * this class but then also needs to execute another project's autoloader in process,
- * and wants to ensure both projects have access to their version of installed.php.
- *
- * A typical case would be PHPUnit, where it would need to make sure it reads all
- * the data it needs from this class, then call reload() with
- * `require $CWD/vendor/composer/installed.php` (or similar) as input to make sure
- * the project in which it runs can then also use this class safely, without
- * interference between PHPUnit's dependencies and the project's dependencies.
- *
- * @param array[] $data A vendor/composer/installed.php data set
- * @return void
- *
- * @psalm-param array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>} $data
- */
- public static function reload($data)
- {
- self::$installed = $data;
- self::$installedByVendor = array();
- }
-
- /**
- * @return array[]
- * @psalm-return list<array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}>
- */
- private static function getInstalled()
- {
- if (null === self::$canGetVendors) {
- self::$canGetVendors = method_exists('Composer\Autoload\ClassLoader', 'getRegisteredLoaders');
- }
-
- $installed = array();
-
- if (self::$canGetVendors) {
- foreach (ClassLoader::getRegisteredLoaders() as $vendorDir => $loader) {
- if (isset(self::$installedByVendor[$vendorDir])) {
- $installed[] = self::$installedByVendor[$vendorDir];
- } elseif (is_file($vendorDir.'/composer/installed.php')) {
- $installed[] = self::$installedByVendor[$vendorDir] = require $vendorDir.'/composer/installed.php';
- if (null === self::$installed && strtr($vendorDir.'/composer', '\\', '/') === strtr(__DIR__, '\\', '/')) {
- self::$installed = $installed[count($installed) - 1];
- }
- }
- }
- }
-
- if (null === self::$installed) {
- // only require the installed.php file if this file is loaded from its dumped location,
- // and not from its source location in the composer/composer package, see https://github.com/composer/composer/issues/9937
- if (substr(__DIR__, -8, 1) !== 'C') {
- self::$installed = require __DIR__ . '/installed.php';
- } else {
- self::$installed = array();
- }
- }
- $installed[] = self::$installed;
-
- return $installed;
- }
-}
diff --git a/includes/composer/vendor/composer/LICENSE b/includes/composer/vendor/composer/LICENSE
deleted file mode 100644
index f27399a..0000000
--- a/includes/composer/vendor/composer/LICENSE
+++ /dev/null
@@ -1,21 +0,0 @@
-
-Copyright (c) Nils Adermann, Jordi Boggiano
-
-Permission is hereby granted, free of charge, to any person obtaining a copy
-of this software and associated documentation files (the "Software"), to deal
-in the Software without restriction, including without limitation the rights
-to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
-copies of the Software, and to permit persons to whom the Software is furnished
-to do so, subject to the following conditions:
-
-The above copyright notice and this permission notice shall be included in all
-copies or substantial portions of the Software.
-
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
-IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
-FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
-AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
-LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
-THE SOFTWARE.
-
diff --git a/includes/composer/vendor/composer/autoload_classmap.php b/includes/composer/vendor/composer/autoload_classmap.php
deleted file mode 100644
index 6d7608b..0000000
--- a/includes/composer/vendor/composer/autoload_classmap.php
+++ /dev/null
@@ -1,14 +0,0 @@
-<?php
-
-// autoload_classmap.php @generated by Composer
-
-$vendorDir = dirname(__DIR__);
-$baseDir = dirname($vendorDir);
-
-return array(
- 'Composer\\InstalledVersions' => $vendorDir . '/composer/InstalledVersions.php',
- 'om\\EventsList' => $vendorDir . '/om/icalparser/src/EventsList.php',
- 'om\\Freq' => $vendorDir . '/om/icalparser/src/Freq.php',
- 'om\\IcalParser' => $vendorDir . '/om/icalparser/src/IcalParser.php',
- 'om\\Recurrence' => $vendorDir . '/om/icalparser/src/Recurrence.php',
-);
diff --git a/includes/composer/vendor/composer/autoload_namespaces.php b/includes/composer/vendor/composer/autoload_namespaces.php
deleted file mode 100644
index 15a2ff3..0000000
--- a/includes/composer/vendor/composer/autoload_namespaces.php
+++ /dev/null
@@ -1,9 +0,0 @@
-<?php
-
-// autoload_namespaces.php @generated by Composer
-
-$vendorDir = dirname(__DIR__);
-$baseDir = dirname($vendorDir);
-
-return array(
-);
diff --git a/includes/composer/vendor/composer/autoload_psr4.php b/includes/composer/vendor/composer/autoload_psr4.php
deleted file mode 100644
index 409d32b..0000000
--- a/includes/composer/vendor/composer/autoload_psr4.php
+++ /dev/null
@@ -1,10 +0,0 @@
-<?php
-
-// autoload_psr4.php @generated by Composer
-
-$vendorDir = dirname(__DIR__);
-$baseDir = dirname($vendorDir);
-
-return array(
- 'ColorThief\\' => array($vendorDir . '/ksubileau/color-thief-php/src/ColorThief'),
-);
diff --git a/includes/composer/vendor/composer/autoload_real.php b/includes/composer/vendor/composer/autoload_real.php
deleted file mode 100644
index e570961..0000000
--- a/includes/composer/vendor/composer/autoload_real.php
+++ /dev/null
@@ -1,38 +0,0 @@
-<?php
-
-// autoload_real.php @generated by Composer
-
-class ComposerAutoloaderInit7bef9e3ab3ffae606875b2457b7bf1cb
-{
- private static $loader;
-
- public static function loadClassLoader($class)
- {
- if ('Composer\Autoload\ClassLoader' === $class) {
- require __DIR__ . '/ClassLoader.php';
- }
- }
-
- /**
- * @return \Composer\Autoload\ClassLoader
- */
- public static function getLoader()
- {
- if (null !== self::$loader) {
- return self::$loader;
- }
-
- require __DIR__ . '/platform_check.php';
-
- spl_autoload_register(array('ComposerAutoloaderInit7bef9e3ab3ffae606875b2457b7bf1cb', 'loadClassLoader'), true, true);
- self::$loader = $loader = new \Composer\Autoload\ClassLoader(\dirname(__DIR__));
- spl_autoload_unregister(array('ComposerAutoloaderInit7bef9e3ab3ffae606875b2457b7bf1cb', 'loadClassLoader'));
-
- require __DIR__ . '/autoload_static.php';
- call_user_func(\Composer\Autoload\ComposerStaticInit7bef9e3ab3ffae606875b2457b7bf1cb::getInitializer($loader));
-
- $loader->register(true);
-
- return $loader;
- }
-}
diff --git a/includes/composer/vendor/composer/autoload_static.php b/includes/composer/vendor/composer/autoload_static.php
deleted file mode 100644
index 25a84e5..0000000
--- a/includes/composer/vendor/composer/autoload_static.php
+++ /dev/null
@@ -1,40 +0,0 @@
-<?php
-
-// autoload_static.php @generated by Composer
-
-namespace Composer\Autoload;
-
-class ComposerStaticInit7bef9e3ab3ffae606875b2457b7bf1cb
-{
- public static $prefixLengthsPsr4 = array (
- 'C' =>
- array (
- 'ColorThief\\' => 11,
- ),
- );
-
- public static $prefixDirsPsr4 = array (
- 'ColorThief\\' =>
- array (
- 0 => __DIR__ . '/..' . '/ksubileau/color-thief-php/src/ColorThief',
- ),
- );
-
- public static $classMap = array (
- 'Composer\\InstalledVersions' => __DIR__ . '/..' . '/composer/InstalledVersions.php',
- 'om\\EventsList' => __DIR__ . '/..' . '/om/icalparser/src/EventsList.php',
- 'om\\Freq' => __DIR__ . '/..' . '/om/icalparser/src/Freq.php',
- 'om\\IcalParser' => __DIR__ . '/..' . '/om/icalparser/src/IcalParser.php',
- 'om\\Recurrence' => __DIR__ . '/..' . '/om/icalparser/src/Recurrence.php',
- );
-
- public static function getInitializer(ClassLoader $loader)
- {
- return \Closure::bind(function () use ($loader) {
- $loader->prefixLengthsPsr4 = ComposerStaticInit7bef9e3ab3ffae606875b2457b7bf1cb::$prefixLengthsPsr4;
- $loader->prefixDirsPsr4 = ComposerStaticInit7bef9e3ab3ffae606875b2457b7bf1cb::$prefixDirsPsr4;
- $loader->classMap = ComposerStaticInit7bef9e3ab3ffae606875b2457b7bf1cb::$classMap;
-
- }, null, ClassLoader::class);
- }
-}
diff --git a/includes/composer/vendor/composer/installed.json b/includes/composer/vendor/composer/installed.json
deleted file mode 100644
index 51c1004..0000000
--- a/includes/composer/vendor/composer/installed.json
+++ /dev/null
@@ -1,123 +0,0 @@
-{
- "packages": [
- {
- "name": "ksubileau/color-thief-php",
- "version": "v2.0.1",
- "version_normalized": "2.0.1.0",
- "source": {
- "type": "git",
- "url": "https://github.com/ksubileau/color-thief-php.git",
- "reference": "a1378533433dae824c2e5b70359f8b6ae16b1deb"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/ksubileau/color-thief-php/zipball/a1378533433dae824c2e5b70359f8b6ae16b1deb",
- "reference": "a1378533433dae824c2e5b70359f8b6ae16b1deb",
- "shasum": ""
- },
- "require": {
- "ext-fileinfo": "*",
- "php": "^7.2|^8.0"
- },
- "require-dev": {
- "friendsofphp/php-cs-fixer": "^3.4",
- "phpstan/phpstan": "^1.2.0",
- "phpstan/phpstan-phpunit": "^1.0.0",
- "phpunit/phpunit": "^8.5"
- },
- "suggest": {
- "ext-gd": "to use the GD image adapter.",
- "ext-gmagick": "to use the Gmagick image adapter.",
- "ext-imagick": "to use the Imagick image adapter."
- },
- "time": "2022-11-12T10:09:40+00:00",
- "type": "library",
- "installation-source": "dist",
- "autoload": {
- "psr-4": {
- "ColorThief\\": "src/ColorThief"
- }
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Kevin Subileau",
- "homepage": "http://www.kevinsubileau.fr"
- }
- ],
- "description": "Grabs the dominant color or a representative color palette from an image.",
- "homepage": "http://www.kevinsubileau.fr/projets/color-thief-php",
- "keywords": [
- "color",
- "dominant",
- "palette",
- "php",
- "thief"
- ],
- "support": {
- "issues": "https://github.com/ksubileau/color-thief-php/issues",
- "source": "https://github.com/ksubileau/color-thief-php/tree/v2.0.1"
- },
- "install-path": "../ksubileau/color-thief-php"
- },
- {
- "name": "om/icalparser",
- "version": "v3.0.6",
- "version_normalized": "3.0.6.0",
- "source": {
- "type": "git",
- "url": "https://github.com/OzzyCzech/icalparser.git",
- "reference": "1481bc442a48cd1678291958b33efa22a628fb0b"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/OzzyCzech/icalparser/zipball/1481bc442a48cd1678291958b33efa22a628fb0b",
- "reference": "1481bc442a48cd1678291958b33efa22a628fb0b",
- "shasum": ""
- },
- "require": {
- "php": ">=8.0.0"
- },
- "require-dev": {
- "nette/tester": "^2.4"
- },
- "suggest": {
- "ext-dom": "for timezone tool"
- },
- "time": "2023-02-09T07:45:07+00:00",
- "type": "library",
- "installation-source": "dist",
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-3-Clause"
- ],
- "authors": [
- {
- "name": "Roman Ožana",
- "email": "roman@ozana.cz"
- }
- ],
- "description": "Simple iCal parser",
- "keywords": [
- "calendar",
- "ical",
- "parser"
- ],
- "support": {
- "issues": "https://github.com/OzzyCzech/icalparser/issues",
- "source": "https://github.com/OzzyCzech/icalparser/tree/v3.0.6"
- },
- "install-path": "../om/icalparser"
- }
- ],
- "dev": true,
- "dev-package-names": []
-}
diff --git a/includes/composer/vendor/composer/installed.php b/includes/composer/vendor/composer/installed.php
deleted file mode 100644
index a9241b9..0000000
--- a/includes/composer/vendor/composer/installed.php
+++ /dev/null
@@ -1,41 +0,0 @@
-<?php return array(
- 'root' => array(
- 'name' => '__root__',
- 'pretty_version' => 'dev-mane',
- 'version' => 'dev-mane',
- 'reference' => '7ccc2de87f9e25c715dc09b9aba4eb5c66f80424',
- 'type' => 'library',
- 'install_path' => __DIR__ . '/../../',
- 'aliases' => array(),
- 'dev' => true,
- ),
- 'versions' => array(
- '__root__' => array(
- 'pretty_version' => 'dev-mane',
- 'version' => 'dev-mane',
- 'reference' => '7ccc2de87f9e25c715dc09b9aba4eb5c66f80424',
- 'type' => 'library',
- 'install_path' => __DIR__ . '/../../',
- 'aliases' => array(),
- 'dev_requirement' => false,
- ),
- 'ksubileau/color-thief-php' => array(
- 'pretty_version' => 'v2.0.1',
- 'version' => '2.0.1.0',
- 'reference' => 'a1378533433dae824c2e5b70359f8b6ae16b1deb',
- 'type' => 'library',
- 'install_path' => __DIR__ . '/../ksubileau/color-thief-php',
- 'aliases' => array(),
- 'dev_requirement' => false,
- ),
- 'om/icalparser' => array(
- 'pretty_version' => 'v3.0.6',
- 'version' => '3.0.6.0',
- 'reference' => '1481bc442a48cd1678291958b33efa22a628fb0b',
- 'type' => 'library',
- 'install_path' => __DIR__ . '/../om/icalparser',
- 'aliases' => array(),
- 'dev_requirement' => false,
- ),
- ),
-);
diff --git a/includes/composer/vendor/composer/platform_check.php b/includes/composer/vendor/composer/platform_check.php
deleted file mode 100644
index adfb472..0000000
--- a/includes/composer/vendor/composer/platform_check.php
+++ /dev/null
@@ -1,26 +0,0 @@
-<?php
-
-// platform_check.php @generated by Composer
-
-$issues = array();
-
-if (!(PHP_VERSION_ID >= 80000)) {
- $issues[] = 'Your Composer dependencies require a PHP version ">= 8.0.0". You are running ' . PHP_VERSION . '.';
-}
-
-if ($issues) {
- if (!headers_sent()) {
- header('HTTP/1.1 500 Internal Server Error');
- }
- if (!ini_get('display_errors')) {
- if (PHP_SAPI === 'cli' || PHP_SAPI === 'phpdbg') {
- fwrite(STDERR, 'Composer detected issues in your platform:' . PHP_EOL.PHP_EOL . implode(PHP_EOL, $issues) . PHP_EOL.PHP_EOL);
- } elseif (!headers_sent()) {
- echo 'Composer detected issues in your platform:' . PHP_EOL.PHP_EOL . str_replace('You are running '.PHP_VERSION.'.', '', implode(PHP_EOL, $issues)) . PHP_EOL.PHP_EOL;
- }
- }
- trigger_error(
- 'Composer detected issues in your platform: ' . implode(' ', $issues),
- E_USER_ERROR
- );
-}
diff --git a/includes/composer/vendor/ksubileau/color-thief-php/LICENSE b/includes/composer/vendor/ksubileau/color-thief-php/LICENSE
deleted file mode 100644
index 3e13937..0000000
--- a/includes/composer/vendor/ksubileau/color-thief-php/LICENSE
+++ /dev/null
@@ -1,21 +0,0 @@
-The MIT License (MIT)
-
-Copyright (c) 2020 Kevin Subileau
-
-Permission is hereby granted, free of charge, to any person obtaining a copy
-of this software and associated documentation files (the "Software"), to deal
-in the Software without restriction, including without limitation the rights
-to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
-copies of the Software, and to permit persons to whom the Software is
-furnished to do so, subject to the following conditions:
-
-The above copyright notice and this permission notice shall be included in all
-copies or substantial portions of the Software.
-
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
-IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
-FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
-AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
-LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
-SOFTWARE.
diff --git a/includes/composer/vendor/ksubileau/color-thief-php/composer.json b/includes/composer/vendor/ksubileau/color-thief-php/composer.json
deleted file mode 100644
index 3b6d81a..0000000
--- a/includes/composer/vendor/ksubileau/color-thief-php/composer.json
+++ /dev/null
@@ -1,45 +0,0 @@
-{
- "name": "ksubileau/color-thief-php",
- "type": "library",
- "homepage" : "http://www.kevinsubileau.fr/projets/color-thief-php",
- "description": "Grabs the dominant color or a representative color palette from an image.",
- "keywords": ["color", "thief", "php", "dominant", "palette"],
- "license": "MIT",
-
- "authors": [
- {
- "name": "Kevin Subileau",
- "homepage": "http://www.kevinsubileau.fr"
- }
- ],
-
- "require": {
- "php": "^7.2|^8.0",
- "ext-fileinfo": "*"
- },
-
- "require-dev": {
- "phpunit/phpunit": "^8.5",
- "friendsofphp/php-cs-fixer": "^3.4",
- "phpstan/phpstan": "^1.2.0",
- "phpstan/phpstan-phpunit": "^1.0.0"
- },
-
- "suggest": {
- "ext-gd": "to use the GD image adapter.",
- "ext-imagick": "to use the Imagick image adapter.",
- "ext-gmagick": "to use the Gmagick image adapter."
- },
-
- "autoload": {
- "psr-4": {
- "ColorThief\\": "src/ColorThief"
- }
- },
-
- "autoload-dev": {
- "psr-4": {
- "ColorThief\\Tests\\": "tests/"
- }
- }
-}
diff --git a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Color.php b/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Color.php
deleted file mode 100644
index f0c7ef0..0000000
--- a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Color.php
+++ /dev/null
@@ -1,145 +0,0 @@
-<?php
-
-/*
- * This file is part of the Color Thief PHP project.
- *
- * (c) Kevin Subileau
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
-declare(strict_types=1);
-
-namespace ColorThief;
-
-use ColorThief\Exception\NotSupportedException;
-
-class Color
-{
- /**
- * RGB Red value of current color instance.
- *
- * @var int
- */
- private $red;
-
- /**
- * RGB Green value of current color instance.
- *
- * @var int
- */
- private $green;
-
- /**
- * RGB Blue value of current color instance.
- *
- * @var int
- */
- private $blue;
-
- /**
- * Creates new instance.
- */
- public function __construct(int $red = 0, int $green = 0, int $blue = 0)
- {
- $this->red = $red;
- $this->green = $green;
- $this->blue = $blue;
- }
-
- /**
- * Get red value.
- */
- public function getRed(): int
- {
- return $this->red;
- }
-
- /**
- * Get green value.
- */
- public function getGreen(): int
- {
- return $this->green;
- }
-
- /**
- * Get blue value.
- */
- public function getBlue(): int
- {
- return $this->blue;
- }
-
- /**
- * Calculates integer value of current color instance.
- */
- public function getInt(): int
- {
- return ($this->red << 16) + ($this->green << 8) + $this->blue;
- }
-
- /**
- * Calculates hexadecimal value of current color instance.
- */
- public function getHex(string $prefix = ''): string
- {
- return sprintf('%s%02x%02x%02x', $prefix, $this->red, $this->green, $this->blue);
- }
-
- /**
- * Calculates RGB in array format of current color instance.
- *
- * @phpstan-return ColorRGB
- */
- public function getArray(): array
- {
- return [$this->red, $this->green, $this->blue];
- }
-
- /**
- * Calculates RGB in string format of current color instance.
- */
- public function getRgb(): string
- {
- return sprintf('rgb(%d, %d, %d)', $this->red, $this->green, $this->blue);
- }
-
- /**
- * Formats current color instance into given format.
- *
- * @return string|int|array|self
- * @phpstan-return ColorRGB|string|int|self
- */
- public function format(string $type)
- {
- switch (strtolower($type)) {
- case 'rgb':
- return $this->getRgb();
-
- case 'hex':
- return $this->getHex('#');
-
- case 'int':
- return $this->getInt();
-
- case 'array':
- return $this->getArray();
-
- case 'obj':
- return $this;
-
- default:
- throw new NotSupportedException("Color format ({$type}) is not supported.");
- }
- }
-
- /**
- * Get color as string.
- */
- public function __toString(): string
- {
- return $this->getHex('#');
- }
-}
diff --git a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/ColorThief.php b/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/ColorThief.php
deleted file mode 100644
index 2cd658b..0000000
--- a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/ColorThief.php
+++ /dev/null
@@ -1,539 +0,0 @@
-<?php
-
-/*
- * This file is part of the Color Thief PHP project.
- *
- * (c) Kevin Subileau
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
-declare(strict_types=1);
-
-/*
- * Color Thief PHP
- *
- * Grabs the dominant color or a representative color palette from an image.
- *
- * This class requires the GD library to be installed on the server.
- *
- * It's a PHP port of the Color Thief Javascript library
- * (http://github.com/lokesh/color-thief), using the MMCQ
- * (modified median cut quantization) algorithm from
- * the Leptonica library (http://www.leptonica.com/).
- *
- * by Kevin Subileau - http://www.kevinsubileau.fr
- * Based on the work done by Lokesh Dhakar - http://www.lokeshdhakar.com
- * and Nick Rabinowitz
- *
- * Thanks
- * ------
- * Lokesh Dhakar - For creating the original project.
- * Nick Rabinowitz - For creating quantize.js.
- *
- */
-
-namespace ColorThief;
-
-use ColorThief\Exception\InvalidArgumentException;
-use ColorThief\Exception\NotSupportedException;
-use ColorThief\Exception\RuntimeException;
-use ColorThief\Image\Adapter\AdapterInterface;
-use ColorThief\Image\ImageLoader;
-use SplFixedArray;
-
-class ColorThief
-{
- public const SIGBITS = 5;
- public const RSHIFT = 3;
- public const MAX_ITERATIONS = 1000;
- public const FRACT_BY_POPULATIONS = 0.75;
- public const THRESHOLD_ALPHA = 62;
- public const THRESHOLD_WHITE = 250;
-
- /**
- * Get combined color index (3 colors as one integer) from RGB values (0-255) or RGB Histogram Buckets (0-31).
- */
- public static function getColorIndex(int $red, int $green, int $blue, int $sigBits = self::SIGBITS): int
- {
- return (($red >> (8 - $sigBits)) << (2 * $sigBits)) | (($green >> (8 - $sigBits)) << $sigBits) | ($blue >> (8 - $sigBits));
- }
-
- /**
- * Get RGB values (0-255) or RGB Histogram Buckets from a combined color index (3 colors as one integer).
- *
- * @phpstan-return ColorRGB
- */
- public static function getColorsFromIndex(int $index, int $sigBits = 8): array
- {
- $mask = (1 << $sigBits) - 1;
-
- $red = ($index >> (2 * $sigBits)) & $mask;
- $green = ($index >> $sigBits) & $mask;
- $blue = $index & $mask;
-
- return [$red, $green, $blue];
- }
-
- /**
- * Gets the dominant color from the image using the median cut algorithm to cluster similar colors.
- *
- * @param mixed $sourceImage Path/URL to the image, GD resource, Imagick/Gmagick instance, or image as binary string
- * @param int $quality 1 is the highest quality. There is a trade-off between quality and speed.
- * It determines how many pixels are skipped before the next one is sampled.
- * We rarely need to sample every single pixel in the image to get good results.
- * The bigger the number, the faster the palette generation but the greater the
- * likelihood that colors will be missed.
- * @param array|null $area It allows you to specify a rectangular area in the image in order to get
- * colors only for this area. It needs to be an associative array with the
- * following keys:
- * $area['x']: The x-coordinate of the top left corner of the area. Default to 0.
- * $area['y']: The y-coordinate of the top left corner of the area. Default to 0.
- * $area['w']: The width of the area. Default to image width minus x-coordinate.
- * $area['h']: The height of the area. Default to image height minus y-coordinate.
- * @param string $outputFormat By default, color is returned as an array of three integers representing
- * red, green, and blue values.
- * You can choose another output format by passing one of the following values:
- * 'rgb' : RGB string notation (ex: rgb(253, 42, 152)).
- * 'hex' : String of the hexadecimal representation (ex: #fd2a98).
- * 'int' : Integer color value (ex: 16591512).
- * 'array' : Default format (ex: [253, 42, 152]).
- * 'obj' : Instance of ColorThief\Color, for custom processing.
- * @param AdapterInterface|string|null $adapter Optional argument to choose a preferred image adapter to use for loading the image.
- * By default, the adapter is automatically chosen depending on the available extensions
- * and the type of $sourceImage (for example Imagick is used if $sourceImage is an Imagick instance).
- * You can pass one of the 'Imagick', 'Gmagick' or 'Gd' string to use the corresponding
- * underlying image extension, or you can pass an instance of any class implementing
- * the AdapterInterface interface to use a custom image loader.
- * @phpstan-param ?RectangularArea $area
- *
- * @phpstan-return ColorRGB|Color|int|string|null
- */
- public static function getColor($sourceImage, int $quality = 10, ?array $area = null, string $outputFormat = 'array', $adapter = null)
- {
- $palette = self::getPalette($sourceImage, 5, $quality, $area, $outputFormat, $adapter);
-
- return $palette ? $palette[0] : null;
- }
-
- /**
- * Gets a palette of dominant colors from the image using the median cut algorithm to cluster similar colors.
- *
- * @param mixed $sourceImage Path/URL to the image, GD resource, Imagick/Gmagick instance, or image as binary string
- * @param int $colorCount it determines the size of the palette; the number of colors returned
- * @param int $quality 1 is the highest quality. There is a trade-off between quality and speed.
- * It determines how many pixels are skipped before the next one is sampled.
- * We rarely need to sample every single pixel in the image to get good results.
- * The bigger the number, the faster the palette generation but the greater the
- * likelihood that colors will be missed.
- * @param array|null $area It allows you to specify a rectangular area in the image in order to get
- * colors only for this area. It needs to be an associative array with the
- * following keys:
- * $area['x']: The x-coordinate of the top left corner of the area. Default to 0.
- * $area['y']: The y-coordinate of the top left corner of the area. Default to 0.
- * $area['w']: The width of the area. Default to image width minus x-coordinate.
- * $area['h']: The height of the area. Default to image height minus y-coordinate.
- * @param string $outputFormat By default, colors are returned as an array of three integers representing
- * red, green, and blue values.
- * You can choose another output format by passing one of the following values:
- * 'rgb' : RGB string notation (ex: rgb(253, 42, 152)).
- * 'hex' : String of the hexadecimal representation (ex: #fd2a98).
- * 'int' : Integer color value (ex: 16591512).
- * 'array' : Default format (ex: [253, 42, 152]).
- * 'obj' : Instance of ColorThief\Color, for custom processing.
- * @param AdapterInterface|string|null $adapter Optional argument to choose a preferred image adapter to use for loading the image.
- * By default, the adapter is automatically chosen depending on the available extensions
- * and the type of $sourceImage (e.g. Imagick is used if $sourceImage is an Imagick instance).
- * You can pass one of the 'Imagick', 'Gmagick' or 'Gd' string to use the corresponding
- * underlying image extension, or you can pass an instance of any class implementing
- * the AdapterInterface interface to use a custom image loader.
- * @phpstan-param ?RectangularArea $area
- *
- * @return array
- * @phpstan-return ColorRGB[]|Color[]|int[]|string[]|null
- */
- public static function getPalette(
- $sourceImage,
- int $colorCount = 10,
- int $quality = 10,
- ?array $area = null,
- string $outputFormat = 'array',
- $adapter = null
- ): ?array {
- if ($colorCount < 2 || $colorCount > 256) {
- throw new InvalidArgumentException('The number of palette colors must be between 2 and 256 inclusive.');
- }
-
- if ($quality < 1) {
- throw new InvalidArgumentException('The quality argument must be an integer greater than one.');
- }
-
- $histo = [];
- $numPixelsAnalyzed = self::loadImage($sourceImage, $quality, $histo, $area, $adapter);
- if (0 === $numPixelsAnalyzed) {
- throw new NotSupportedException('Unable to compute the color palette of a blank or transparent image.');
- }
-
- // Send histogram to quantize function which clusters values
- // using median cut algorithm
- $palette = self::quantize($numPixelsAnalyzed, $colorCount, $histo);
-
- return array_map(function (Color $color) use ($outputFormat) {
- return $color->format($outputFormat);
- }, $palette);
- }
-
- /**
- * @param mixed $sourceImage Path/URL to the image, GD resource, Imagick instance, or image as binary string
- * @param int $quality Analyze every $quality pixels
- * @param array<int, int> $histo Histogram
- * @param AdapterInterface|string|null $adapter Image adapter to use for loading the image
- * @phpstan-param ?RectangularArea $area
- */
- private static function loadImage($sourceImage, int $quality, array &$histo, array $area = null, $adapter = null): int
- {
- $loader = new ImageLoader();
- if (null !== $adapter) {
- $loader->setPreferredAdapter($adapter);
- }
- $image = $loader->load($sourceImage);
- $startX = 0;
- $startY = 0;
- $width = $image->getWidth();
- $height = $image->getHeight();
-
- if ($area) {
- $startX = $area['x'] ?? 0;
- $startY = $area['y'] ?? 0;
- $width = $area['w'] ?? ($width - $startX);
- $height = $area['h'] ?? ($height - $startY);
-
- if ((($startX + $width) > $image->getWidth()) || (($startY + $height) > $image->getHeight())) {
- throw new InvalidArgumentException('Area is out of image bounds.');
- }
- }
-
- // Fill a SplArray with zeroes to initialize the 5-bit buckets and avoid having to check isset in the pixel loop.
- // There are 32768 buckets because each color is 5 bits (15 bits total for RGB values).
- $totalBuckets = (1 << (3 * self::SIGBITS));
- $histoSpl = new SplFixedArray($totalBuckets);
- for ($i = 0; $i < $totalBuckets; ++$i) {
- $histoSpl[$i] = 0;
- }
-
- $numUsefulPixels = 0;
- $pixelCount = $width * $height;
-
- for ($i = 0; $i < $pixelCount; $i += $quality) {
- $x = $startX + ($i % $width);
- $y = (int) ($startY + $i / $width);
- $color = $image->getPixelColor($x, $y);
-
- // Pixel is too transparent. Its alpha value is larger (more transparent) than THRESHOLD_ALPHA.
- // PHP's transparency range (0-127 opaque-transparent) is reverse that of Javascript (0-255 tranparent-opaque).
- if ($color->alpha > self::THRESHOLD_ALPHA) {
- continue;
- }
-
- // Pixel is too white to be useful. Its RGB values all exceed THRESHOLD_WHITE
- if ($color->red > self::THRESHOLD_WHITE && $color->green > self::THRESHOLD_WHITE && $color->blue > self::THRESHOLD_WHITE) {
- continue;
- }
-
- // Count this pixel in its histogram bucket.
- ++$numUsefulPixels;
- $bucketIndex = self::getColorIndex($color->red, $color->green, $color->blue);
- $histoSpl[$bucketIndex] = $histoSpl[$bucketIndex] + 1;
- }
-
- // Copy the histogram buckets that had pixels back to a normal array.
- $histo = [];
- foreach ($histoSpl as $bucketInt => $numPixels) {
- if ($numPixels > 0) {
- $histo[$bucketInt] = $numPixels;
- }
- }
-
- // Don't destroy a resource passed by the user !
- // TODO Add a method in ImageLoader to know if the image should be destroy
- // (or to know the detected image source type)
- if (\is_string($sourceImage)) {
- $image->destroy();
- }
-
- return $numUsefulPixels;
- }
-
- /**
- * @param array<int, int> $histo
- */
- private static function vboxFromHistogram(array $histo): VBox
- {
- $rgbMin = [\PHP_INT_MAX, \PHP_INT_MAX, \PHP_INT_MAX];
- $rgbMax = [-\PHP_INT_MAX, -\PHP_INT_MAX, -\PHP_INT_MAX];
-
- // find min/max
- foreach ($histo as $bucketIndex => $count) {
- $rgb = self::getColorsFromIndex($bucketIndex, self::SIGBITS);
-
- // For each color components
- for ($i = 0; $i < 3; ++$i) {
- if ($rgb[$i] < $rgbMin[$i]) {
- $rgbMin[$i] = $rgb[$i];
- }
- if ($rgb[$i] > $rgbMax[$i]) {
- $rgbMax[$i] = $rgb[$i];
- }
- }
- }
-
- return new VBox($rgbMin[0], $rgbMax[0], $rgbMin[1], $rgbMax[1], $rgbMin[2], $rgbMax[2], $histo);
- }
-
- /**
- * @param int[] $partialSum
- *
- * @return array{VBox, VBox}|null
- */
- private static function doCut(string $color, VBox $vBox, array $partialSum, int $total): ?array
- {
- $dim1 = $color.'1';
- $dim2 = $color.'2';
-
- for ($i = $vBox->$dim1; $i <= $vBox->$dim2; ++$i) {
- if ($partialSum[$i] > $total / 2) {
- $vBox1 = $vBox->copy();
- $vBox2 = $vBox->copy();
- $left = $i - $vBox->$dim1;
- $right = $vBox->$dim2 - $i;
-
- // Choose the cut plane within the greater of the (left, right) sides
- // of the bin in which the median pixel resides
- if ($left <= $right) {
- $d2 = min($vBox->$dim2 - 1, (int) ($i + $right / 2));
- } else { /* left > right */
- $d2 = max($vBox->$dim1, (int) ($i - 1 - $left / 2));
- }
-
- while (empty($partialSum[$d2])) {
- ++$d2;
- }
- // Avoid 0-count boxes
- while ($partialSum[$d2] >= $total && !empty($partialSum[$d2 - 1])) {
- --$d2;
- }
-
- // set dimensions
- $vBox1->$dim2 = $d2;
- $vBox2->$dim1 = $d2 + 1;
-
- return [$vBox1, $vBox2];
- }
- }
-
- return null;
- }
-
- /**
- * @param array<int, int> $histo
- *
- * @return VBox[]|null
- */
- private static function medianCutApply(array $histo, VBox $vBox): ?array
- {
- if (!$vBox->count()) {
- return null;
- }
-
- // If the vbox occupies just one element in color space, it can't be split
- if (1 == $vBox->count()) {
- return [
- $vBox->copy(),
- ];
- }
-
- // Select the longest axis for splitting
- $cutColor = $vBox->longestAxis();
-
- // Find the partial sum arrays along the selected axis.
- [$total, $partialSum] = self::sumColors($cutColor, $histo, $vBox);
-
- return self::doCut($cutColor, $vBox, $partialSum, $total);
- }
-
- /**
- * Find the partial sum arrays along the selected axis.
- *
- * @param string $axis r|g|b
- * @phpstan-param 'r'|'g'|'b' $axis
- *
- * @param array<int, int> $histo
- *
- * @return array{int, array<int, int>} [$total, $partialSum]
- */
- private static function sumColors(string $axis, array $histo, VBox $vBox): array
- {
- $total = 0;
- $partialSum = [];
-
- // The selected axis should be the first range
- $colorIterateOrder = array_diff(['r', 'g', 'b'], [$axis]);
- array_unshift($colorIterateOrder, $axis);
-
- // Retrieves iteration ranges
- [$firstRange, $secondRange, $thirdRange] = self::getVBoxColorRanges($vBox, $colorIterateOrder);
-
- foreach ($firstRange as $firstColor) {
- $sum = 0;
- foreach ($secondRange as $secondColor) {
- foreach ($thirdRange as $thirdColor) {
- // Rearrange color components
- $bucket = [
- $colorIterateOrder[0] => $firstColor,
- $colorIterateOrder[1] => $secondColor,
- $colorIterateOrder[2] => $thirdColor,
- ];
-
- // The getColorIndex function takes RGB values instead of buckets. The left shift converts our bucket into its RGB value.
- $bucketIndex = self::getColorIndex(
- $bucket['r'] << self::RSHIFT,
- $bucket['g'] << self::RSHIFT,
- $bucket['b'] << self::RSHIFT,
- self::SIGBITS
- );
-
- if (isset($histo[$bucketIndex])) {
- $sum += $histo[$bucketIndex];
- }
- }
- }
- $total += $sum;
- $partialSum[$firstColor] = $total;
- }
-
- return [$total, $partialSum];
- }
-
- /**
- * @phpstan-param array<'r'|'g'|'b'> $order
- *
- * @return int[][]
- * @phpstan-return array{int[], int[], int[]}
- */
- private static function getVBoxColorRanges(VBox $vBox, array $order): array
- {
- $ranges = [
- 'r' => range($vBox->r1, $vBox->r2),
- 'g' => range($vBox->g1, $vBox->g2),
- 'b' => range($vBox->b1, $vBox->b2),
- ];
-
- return [
- $ranges[$order[0]],
- $ranges[$order[1]],
- $ranges[$order[2]],
- ];
- }
-
- /**
- * Inner function to do the iteration.
- *
- * @param PQueue<VBox> $priorityQueue
- * @param array<int, int> $histo
- */
- private static function quantizeIter(PQueue &$priorityQueue, float $target, array $histo): void
- {
- $nColors = $priorityQueue->size();
- $nIterations = 0;
-
- while ($nIterations < self::MAX_ITERATIONS) {
- if ($nColors >= $target) {
- return;
- }
-
- if ($nIterations++ > self::MAX_ITERATIONS) {
- // echo "infinite loop; perhaps too few pixels!"."\n";
- return;
- }
-
- $vBox = $priorityQueue->pop();
- if (null === $vBox) {
- // Logic error: should not happen!
- throw new RuntimeException('Failed to pop VBox from an empty queue.');
- }
-
- if (!$vBox->count()) { /* just put it back */
- $priorityQueue->push($vBox);
- ++$nIterations;
- continue;
- }
- // do the cut
- $vBoxes = self::medianCutApply($histo, $vBox);
-
- if (!(\is_array($vBoxes) && isset($vBoxes[0]))) {
- // Expect an array of VBox
- throw new RuntimeException('Unexpected result from the medianCutApply function.');
- }
-
- $priorityQueue->push($vBoxes[0]);
-
- if (isset($vBoxes[1])) { /* vbox2 can be null */
- $priorityQueue->push($vBoxes[1]);
- ++$nColors;
- }
- }
- }
-
- /**
- * @param int $numPixels Number of image pixels analyzed
- * @param array<int, int> $histo Histogram
- *
- * @return Color[]
- */
- private static function quantize(int $numPixels, int $maxColors, array &$histo): array
- {
- // Short-Circuits
- if (0 === $numPixels) {
- throw new InvalidArgumentException('Zero usable pixels found in image.');
- }
- if ($maxColors < 2 || $maxColors > 256) {
- throw new InvalidArgumentException('The maxColors parameter must be between 2 and 256 inclusive.');
- }
- if (0 === \count($histo)) {
- throw new InvalidArgumentException('Image produced an empty histogram.');
- }
-
- // check that we aren't below maxcolors already
- //if (count($histo) <= $maxcolors) {
- // XXX: generate the new colors from the histo and return
- //}
-
- $vBox = self::vboxFromHistogram($histo);
-
- /** @var PQueue<VBox> $priorityQueue */
- $priorityQueue = new PQueue(function (VBox $a, VBox $b) {
- return $a->count() <=> $b->count();
- });
- $priorityQueue->push($vBox);
-
- // first set of colors, sorted by population
- self::quantizeIter($priorityQueue, self::FRACT_BY_POPULATIONS * $maxColors, $histo);
-
- // Re-sort by the product of pixel occupancy times the size in color space.
- $priorityQueue->setComparator(function (VBox $a, VBox $b) {
- return ($a->count() * $a->volume()) <=> ($b->count() * $b->volume());
- });
-
- // next set - generate the median cuts using the (npix * vol) sorting.
- self::quantizeIter($priorityQueue, $maxColors, $histo);
-
- // calculate the actual colors
- $colors = $priorityQueue->map(function (VBox $vbox) {
- return new Color(...$vbox->avg());
- });
- $colors = array_reverse($colors);
-
- return $colors;
- }
-}
diff --git a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/Exception.php b/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/Exception.php
deleted file mode 100644
index d843f61..0000000
--- a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/Exception.php
+++ /dev/null
@@ -1,21 +0,0 @@
-<?php
-
-/*
- * This file is part of the Color Thief PHP project.
- *
- * (c) Kevin Subileau
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
-declare(strict_types=1);
-
-namespace ColorThief\Exception;
-
-/**
- * Base exception marker interface for ColorThief.
- */
-interface Exception extends \Throwable
-{
-}
diff --git a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/InvalidArgumentException.php b/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/InvalidArgumentException.php
deleted file mode 100644
index 609daa6..0000000
--- a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/InvalidArgumentException.php
+++ /dev/null
@@ -1,22 +0,0 @@
-<?php
-
-/*
- * This file is part of the Color Thief PHP project.
- *
- * (c) Kevin Subileau
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
-declare(strict_types=1);
-
-namespace ColorThief\Exception;
-
-/**
- * Exception thrown if an argument is not of the expected type.
- */
-class InvalidArgumentException extends \InvalidArgumentException implements Exception
-{
- // nothing to override
-}
diff --git a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/NotReadableException.php b/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/NotReadableException.php
deleted file mode 100644
index 39f1051..0000000
--- a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/NotReadableException.php
+++ /dev/null
@@ -1,22 +0,0 @@
-<?php
-
-/*
- * This file is part of the Color Thief PHP project.
- *
- * (c) Kevin Subileau
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
-declare(strict_types=1);
-
-namespace ColorThief\Exception;
-
-/**
- * Exception thrown if an image source is not readable.
- */
-class NotReadableException extends \RuntimeException implements Exception
-{
- // nothing to override
-}
diff --git a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/NotSupportedException.php b/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/NotSupportedException.php
deleted file mode 100644
index b25e64c..0000000
--- a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/NotSupportedException.php
+++ /dev/null
@@ -1,22 +0,0 @@
-<?php
-
-/*
- * This file is part of the Color Thief PHP project.
- *
- * (c) Kevin Subileau
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
-declare(strict_types=1);
-
-namespace ColorThief\Exception;
-
-/**
- * Exception thrown when an operation is not supported.
- */
-class NotSupportedException extends \RuntimeException implements Exception
-{
- // nothing to override
-}
diff --git a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/RuntimeException.php b/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/RuntimeException.php
deleted file mode 100644
index ef9427c..0000000
--- a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Exception/RuntimeException.php
+++ /dev/null
@@ -1,19 +0,0 @@
-<?php
-
-/*
- * This file is part of the Color Thief PHP project.
- *
- * (c) Kevin Subileau
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
-declare(strict_types=1);
-
-namespace ColorThief\Exception;
-
-class RuntimeException extends \RuntimeException implements Exception
-{
- // nothing to override
-}
diff --git a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/AbstractAdapter.php b/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/AbstractAdapter.php
deleted file mode 100644
index 17378c9..0000000
--- a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/AbstractAdapter.php
+++ /dev/null
@@ -1,78 +0,0 @@
-<?php
-
-/*
- * This file is part of the Color Thief PHP project.
- *
- * (c) Kevin Subileau
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
-declare(strict_types=1);
-
-namespace ColorThief\Image\Adapter;
-
-use ColorThief\Exception\NotReadableException;
-use ColorThief\Exception\NotSupportedException;
-
-/**
- * Base adapter implementation to handle image manipulation.
- */
-abstract class AbstractAdapter implements AdapterInterface
-{
- /**
- * @var object|resource|null Image resource/object of current image adapter
- */
- protected $resource;
-
- /**
- * Creates new instance of the image adapter.
- */
- public function __construct()
- {
- if (!$this->isAvailable()) {
- throw new NotSupportedException('Image adapter is not available with this PHP installation. Required extension may be missing.');
- }
- }
-
- public function load($resource): AdapterInterface
- {
- $this->resource = $resource;
-
- return $this;
- }
-
- public function loadFromUrl(string $url): AdapterInterface
- {
- $options = [
- 'http' => [
- 'method' => 'GET',
- 'protocol_version' => 1.1, // force use HTTP 1.1 for service mesh environment with envoy
- 'header' => [
- 'Accept-language: en',
- 'User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:95.0) Gecko/20100101 Firefox/95.0',
- ],
- ],
- ];
-
- $context = stream_context_create($options);
-
- $data = @file_get_contents($url, false, $context);
- if (false === $data) {
- throw new NotReadableException("Unable to load image from url ({$url}).");
- }
-
- return $this->loadFromBinary($data);
- }
-
- public function destroy(): void
- {
- $this->resource = null;
- }
-
- public function getResource()
- {
- return $this->resource;
- }
-}
diff --git a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/AdapterInterface.php b/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/AdapterInterface.php
deleted file mode 100644
index 7c08229..0000000
--- a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/AdapterInterface.php
+++ /dev/null
@@ -1,74 +0,0 @@
-<?php
-
-/*
- * This file is part of the Color Thief PHP project.
- *
- * (c) Kevin Subileau
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
-declare(strict_types=1);
-
-namespace ColorThief\Image\Adapter;
-
-/**
- * Basic interface for all image adapters.
- */
-interface AdapterInterface
-{
- /**
- * Checks if the image adapter is available.
- */
- public static function isAvailable(): bool;
-
- /**
- * Loads an image from path in filesystem.
- */
- public function loadFromPath(string $file): self;
-
- /**
- * Loads an image from given URL.
- */
- public function loadFromUrl(string $url): self;
-
- /**
- * Loads an image from a binary string representation.
- */
- public function loadFromBinary(string $data): self;
-
- /**
- * Loads an image resource.
- *
- * @param resource|object $resource
- */
- public function load($resource): self;
-
- /**
- * Destroys the image.
- */
- public function destroy(): void;
-
- /**
- * Returns image height.
- */
- public function getHeight(): int;
-
- /**
- * Returns image width.
- */
- public function getWidth(): int;
-
- /**
- * Returns the color of the specified pixel.
- */
- public function getPixelColor(int $x, int $y): \stdClass;
-
- /**
- * Get the raw resource.
- *
- * @return resource|object|null
- */
- public function getResource();
-}
diff --git a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/GdAdapter.php b/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/GdAdapter.php
deleted file mode 100644
index e3845d9..0000000
--- a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/GdAdapter.php
+++ /dev/null
@@ -1,119 +0,0 @@
-<?php
-
-/*
- * This file is part of the Color Thief PHP project.
- *
- * (c) Kevin Subileau
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
-declare(strict_types=1);
-
-namespace ColorThief\Image\Adapter;
-
-use ColorThief\Exception\InvalidArgumentException;
-use ColorThief\Exception\NotReadableException;
-
-/**
- * @property resource|\GdImage|null $resource
- */
-class GdAdapter extends AbstractAdapter
-{
- public static function isAvailable(): bool
- {
- return extension_loaded('gd') && function_exists('gd_info');
- }
-
- public function load($resource): AdapterInterface
- {
- if (version_compare(\PHP_VERSION, '8.0.0') >= 0) {
- if (!($resource instanceof \GdImage)) {
- throw new InvalidArgumentException('Argument is not an instance of GdImage.');
- }
- } else {
- if (!\is_resource($resource) || 'gd' != get_resource_type($resource)) {
- throw new InvalidArgumentException('Argument is not a valid GD resource.');
- }
- }
-
- return parent::load($resource);
- }
-
- public function loadFromBinary(string $data): AdapterInterface
- {
- $resource = @imagecreatefromstring($data);
- if (false === $resource) {
- throw new NotReadableException('Unable to read image from binary data.');
- }
-
- return parent::load($resource);
- }
-
- public function loadFromPath(string $file): AdapterInterface
- {
- if (!is_readable($file)) {
- throw new NotReadableException("Unable to read image from path ({$file}).");
- }
-
- [, , $type] = @getimagesize($file);
-
- switch ($type) {
- case \IMAGETYPE_GIF:
- $resource = @imagecreatefromgif($file);
- break;
-
- case \IMAGETYPE_JPEG:
- $resource = @imagecreatefromjpeg($file);
- break;
-
- case \IMAGETYPE_PNG:
- $resource = @imagecreatefrompng($file);
- break;
-
- case \IMAGETYPE_WEBP:
- if (!function_exists('imagecreatefromwebp')) {
- throw new NotReadableException('Unsupported image type. GD/PHP installation does not support WebP format.');
- }
- $resource = @imagecreatefromwebp($file);
- break;
-
- default:
- throw new NotReadableException('Unsupported image type for GD image adapter.');
- }
-
- if (false === $resource) {
- throw new NotReadableException("Unable to decode image from file ({$file}).");
- }
-
- return parent::load($resource);
- }
-
- public function destroy(): void
- {
- if ($this->resource) {
- // For PHP 7.x only, noop starting from PHP 8.0
- imagedestroy($this->resource);
- }
- parent::destroy();
- }
-
- public function getHeight(): int
- {
- return imagesy($this->resource);
- }
-
- public function getWidth(): int
- {
- return imagesx($this->resource);
- }
-
- public function getPixelColor(int $x, int $y): \stdClass
- {
- $rgba = imagecolorat($this->resource, $x, $y);
- $color = imagecolorsforindex($this->resource, $rgba);
-
- return (object) $color;
- }
-}
diff --git a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/GmagickAdapter.php b/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/GmagickAdapter.php
deleted file mode 100644
index ca7063e..0000000
--- a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/GmagickAdapter.php
+++ /dev/null
@@ -1,105 +0,0 @@
-<?php
-
-/*
- * This file is part of the Color Thief PHP project.
- *
- * (c) Kevin Subileau
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
-declare(strict_types=1);
-
-namespace ColorThief\Image\Adapter;
-
-use ColorThief\Exception\InvalidArgumentException;
-use ColorThief\Exception\NotReadableException;
-use Gmagick;
-
-/**
- * @property ?Gmagick $resource
- */
-class GmagickAdapter extends AbstractAdapter
-{
- public static function isAvailable(): bool
- {
- return extension_loaded('gmagick') && class_exists('Gmagick');
- }
-
- public function load($resource): AdapterInterface
- {
- if (!($resource instanceof Gmagick)) {
- throw new InvalidArgumentException('Argument is not an instance of Gmagick.');
- }
-
- if (Gmagick::COLORSPACE_CMYK == $resource->getImageColorSpace()) {
- // Leave original object unmodified
- $resource = clone $resource;
- $resource->setImageColorspace(Gmagick::COLORSPACE_RGB);
- }
-
- return parent::load($resource);
- }
-
- public function loadFromBinary(string $data): AdapterInterface
- {
- $resource = new Gmagick();
- try {
- $resource->readImageBlob($data);
- } catch (\GmagickException $e) {
- throw new NotReadableException('Unable to read image from binary data.', 0, $e);
- }
-
- return $this->load($resource);
- }
-
- public function loadFromPath(string $file): AdapterInterface
- {
- $resource = null;
- try {
- $resource = new Gmagick($file);
- } catch (\GmagickException $e) {
- throw new NotReadableException("Unable to read image from path ({$file}).", 0, $e);
- }
-
- return $this->load($resource);
- }
-
- public function destroy(): void
- {
- if ($this->resource) {
- $this->resource->clear();
- $this->resource->destroy();
- }
- parent::destroy();
- }
-
- public function getHeight(): int
- {
- return $this->resource->getimageheight();
- }
-
- public function getWidth(): int
- {
- return $this->resource->getimagewidth();
- }
-
- public function getPixelColor(int $x, int $y): \stdClass
- {
- $cropped = clone $this->resource; // No need to modify the original object.
- $histogram = $cropped->cropImage(1, 1, $x, $y)->getImageHistogram();
- $pixel = array_shift($histogram);
-
- // Un-normalized values don't give a full range 0-1 alpha channel
- // So we ask for normalized values, and then we un-normalize it ourselves.
- $colorArray = $pixel->getColor(true, true);
- $color = new \stdClass();
- $color->red = (int) round($colorArray['r'] * 255);
- $color->green = (int) round($colorArray['g'] * 255);
- $color->blue = (int) round($colorArray['b'] * 255);
- $color->alpha = (int) round($pixel->getcolorvalue(\Gmagick::COLOR_OPACITY) * 127);
-
- return $color;
- }
-}
diff --git a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/ImagickAdapter.php b/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/ImagickAdapter.php
deleted file mode 100644
index 2ca15a9..0000000
--- a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/Adapter/ImagickAdapter.php
+++ /dev/null
@@ -1,116 +0,0 @@
-<?php
-
-/*
- * This file is part of the Color Thief PHP project.
- *
- * (c) Kevin Subileau
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
-declare(strict_types=1);
-
-namespace ColorThief\Image\Adapter;
-
-use ColorThief\Exception\InvalidArgumentException;
-use ColorThief\Exception\NotReadableException;
-use ColorThief\Exception\NotSupportedException;
-use Imagick;
-
-/**
- * @property ?Imagick $resource
- */
-class ImagickAdapter extends AbstractAdapter
-{
- public static function isAvailable(): bool
- {
- return extension_loaded('imagick') && class_exists('Imagick');
- }
-
- public function load($resource): AdapterInterface
- {
- if (!($resource instanceof Imagick)) {
- throw new InvalidArgumentException('Argument is not an instance of Imagick.');
- }
-
- if (Imagick::COLORSPACE_CMYK == $resource->getImageColorspace()) {
- // Leave original object unmodified
- $resource = clone $resource;
-
- $imagickVersion = phpversion('imagick');
- if ($imagickVersion && version_compare($imagickVersion, '3.0.0', '<')) {
- throw new NotSupportedException('Imagick extension version 3.0.0 or later is required for sampling CMYK images.');
- }
-
- // With ImageMagick version 6.7.7, CMYK images converted to RGB color space work as expected,
- // but for later versions (6.9.7 and 7.0.8 have been tested), conversion to SRGB seems to be required
- $imageMagickVersion = $resource->getVersion();
- if ($imageMagickVersion['versionNumber'] > 1655) {
- $resource->transformImageColorspace(Imagick::COLORSPACE_SRGB);
- } else {
- $resource->transformImageColorspace(Imagick::COLORSPACE_RGB);
- }
- }
-
- return parent::load($resource);
- }
-
- public function loadFromBinary(string $data): AdapterInterface
- {
- $resource = new Imagick();
- try {
- $resource->readImageBlob($data);
- } catch (\ImagickException $e) {
- throw new NotReadableException('Unable to read image from binary data.', 0, $e);
- }
-
- return $this->load($resource);
- }
-
- public function loadFromPath(string $file): AdapterInterface
- {
- try {
- $resource = new Imagick($file);
- } catch (\ImagickException $e) {
- throw new NotReadableException("Unable to read image from path ({$file}).", 0, $e);
- }
-
- return $this->load($resource);
- }
-
- public function destroy(): void
- {
- if ($this->resource) {
- $this->resource->clear();
- }
- parent::destroy();
- }
-
- public function getHeight(): int
- {
- return $this->resource->getImageHeight();
- }
-
- public function getWidth(): int
- {
- return $this->resource->getImageWidth();
- }
-
- public function getPixelColor(int $x, int $y): \stdClass
- {
- /** @var \ImagickPixel $pixel */
- $pixel = $this->resource->getImagePixelColor($x, $y);
-
- // Un-normalized values don't give a full range 0-1 alpha channel
- // So we ask for normalized values, and then we un-normalize it ourselves.
- $colorArray = $pixel->getColor(1);
- $color = new \stdClass();
- $color->red = (int) round($colorArray['r'] * 255);
- $color->green = (int) round($colorArray['g'] * 255);
- $color->blue = (int) round($colorArray['b'] * 255);
- $color->alpha = (int) (127 - round($colorArray['a'] * 127));
-
- return $color;
- }
-}
diff --git a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/ImageLoader.php b/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/ImageLoader.php
deleted file mode 100644
index 9e82784..0000000
--- a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/Image/ImageLoader.php
+++ /dev/null
@@ -1,195 +0,0 @@
-<?php
-
-/*
- * This file is part of the Color Thief PHP project.
- *
- * (c) Kevin Subileau
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
-declare(strict_types=1);
-
-namespace ColorThief\Image;
-
-use ColorThief\Exception\NotReadableException;
-use ColorThief\Exception\NotSupportedException;
-use ColorThief\Image\Adapter\AdapterInterface;
-
-class ImageLoader
-{
- /**
- * @var AdapterInterface|string|null
- */
- private $preferredAdapter = null;
-
- /**
- * Configure the preferred adapter to use to load images.
- *
- * @param string|AdapterInterface|null $adapter Name of the preferred adapter or adapter instance.
- * If null, the adapter is automatically chosen according to the
- * available extensions.
- */
- public function setPreferredAdapter($adapter): self
- {
- $this->preferredAdapter = $adapter;
-
- return $this;
- }
-
- /**
- * @param mixed $source Path/URL to the image, GD resource, Imagick/Gmagick instance, or image as binary string
- */
- public function load($source): AdapterInterface
- {
- $image = null;
-
- $preferredAdapter = $this->preferredAdapter;
- // Select appropriate adapter depending on source type if no preference given
- if (null === $preferredAdapter) {
- if ($this->isGdImage($source)) {
- $preferredAdapter = 'Gd';
- } elseif ($this->isImagick($source)) {
- $preferredAdapter = 'Imagick';
- } elseif ($this->isGmagick($source)) {
- $preferredAdapter = 'Gmagick';
- }
- }
-
- $image = $this->createAdapter($preferredAdapter);
-
- switch (true) {
- case $this->isGdImage($source):
- case $this->isImagick($source):
- case $this->isGmagick($source):
- return $image->load($source);
- case $this->isBinary($source):
- return $image->loadFromBinary($source);
- case $this->isUrl($source):
- return $image->loadFromUrl($source);
- case $this->isFilePath($source):
- return $image->loadFromPath($source);
- default:
- throw new NotReadableException('Image source does not exists or is not readable.');
- }
- }
-
- /**
- * Creates an adapter instance according to config settings.
- *
- * @param string|AdapterInterface|null $preferredAdapter
- */
- public function createAdapter($preferredAdapter = null): AdapterInterface
- {
- if (null === $preferredAdapter) {
- // Select first available adapter
- if (\ColorThief\Image\Adapter\ImagickAdapter::isAvailable()) {
- $preferredAdapter = 'Imagick';
- } elseif (\ColorThief\Image\Adapter\GmagickAdapter::isAvailable()) {
- $preferredAdapter = 'Gmagick';
- } elseif (\ColorThief\Image\Adapter\GdAdapter::isAvailable()) {
- $preferredAdapter = 'Gd';
- } else {
- throw new NotSupportedException('At least one of GD, Imagick or Gmagick extension must be installed. None of them was found.');
- }
- }
-
- if (is_string($preferredAdapter)) {
- $adapterName = ucfirst($preferredAdapter);
- $adapterClass = sprintf('\\ColorThief\\Image\\Adapter\\%sAdapter', $adapterName);
-
- if (!class_exists($adapterClass)) {
- throw new NotSupportedException("Image adapter ({$adapterName}) could not be instantiated.");
- }
-
- return new $adapterClass();
- }
-
- if ($preferredAdapter instanceof AdapterInterface) {
- return $preferredAdapter;
- }
-
- throw new NotSupportedException('Unknown image adapter type.');
- }
-
- /**
- * Determines if given source data is a GD image.
- *
- * @param mixed $data
- */
- public function isGdImage($data): bool
- {
- if (version_compare(\PHP_VERSION, '8.0.0') >= 0) {
- return $data instanceof \GdImage;
- }
-
- return \is_resource($data) && 'gd' == get_resource_type($data);
- }
-
- /**
- * Determines if given source data is an Imagick object.
- *
- * @param mixed $data
- */
- public function isImagick($data): bool
- {
- return is_a($data, 'Imagick');
- }
-
- /**
- * Determines if given source data is a Gmagick object.
- *
- * @param mixed $data
- */
- public function isGmagick($data): bool
- {
- return is_a($data, 'Gmagick');
- }
-
- /**
- * Determines if given source data is file path.
- *
- * @param mixed $data
- */
- public function isFilePath($data): bool
- {
- if (is_string($data)) {
- try {
- return is_file($data);
- } catch (\Exception $e) {
- return false;
- }
- }
-
- return false;
- }
-
- /**
- * Determines if given source data is url.
- *
- * @param mixed $data
- */
- public function isUrl($data): bool
- {
- return (bool) filter_var($data, FILTER_VALIDATE_URL);
- }
-
- /**
- * Determines if given source data is binary data.
- *
- * @param mixed $data
- */
- public function isBinary($data): bool
- {
- if (is_string($data)) {
- $finfo = finfo_open(FILEINFO_MIME_TYPE);
- $mime = finfo_buffer($finfo, $data);
- finfo_close($finfo);
-
- return 'text' != substr($mime, 0, 4) && 'application/x-empty' != $mime;
- }
-
- return false;
- }
-}
diff --git a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/PQueue.php b/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/PQueue.php
deleted file mode 100644
index 21981a6..0000000
--- a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/PQueue.php
+++ /dev/null
@@ -1,129 +0,0 @@
-<?php
-
-/*
- * This file is part of the Color Thief PHP project.
- *
- * (c) Kevin Subileau
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
-declare(strict_types=1);
-
-namespace ColorThief;
-
-/**
- * Simple priority queue.
- *
- * @phpstan-template T
- */
-class PQueue
-{
- /**
- * @var array
- * @phpstan-var array<T>
- */
- private $contents = [];
-
- /** @var bool */
- private $sorted = false;
-
- /**
- * @var callable
- * @phpstan-var callable(T, T): int
- */
- private $comparator = null;
-
- public function __construct(callable $comparator)
- {
- $this->setComparator($comparator);
- }
-
- private function sort(): void
- {
- usort($this->contents, $this->comparator);
- $this->sorted = true;
- }
-
- /**
- * @param mixed $object
- * @phpstan-param T $object
- */
- public function push($object): void
- {
- $this->contents[] = $object;
- $this->sorted = false;
- }
-
- /**
- * @return mixed
- * @phpstan-return T
- */
- public function peek(?int $index = null)
- {
- if (!$this->sorted) {
- $this->sort();
- }
-
- if (null === $index) {
- $index = $this->size() - 1;
- }
-
- return $this->contents[$index];
- }
-
- /**
- * @return mixed|null
- * @phpstan-return T|null
- */
- public function pop()
- {
- if (!$this->sorted) {
- $this->sort();
- }
-
- return array_pop($this->contents);
- }
-
- public function size(): int
- {
- return \count($this->contents);
- }
-
- /**
- * @phpstan-template R
- * @phpstan-param callable(T): R $function
- * @phpstan-return array<R>
- */
- public function map(callable $function, bool $sorted = true): array
- {
- if ($sorted && !$this->sorted) {
- $this->sort();
- }
-
- return array_map($function, $this->contents);
- }
-
- /**
- * @phpstan-param callable(T, T): int $function
- */
- public function setComparator(callable $function): void
- {
- $this->comparator = $function;
- $this->sorted = false;
- }
-
- /**
- * @return array<T>
- * @phpstan-return array<T>
- */
- public function getContent(bool $sorted = true)
- {
- if ($sorted && !$this->sorted) {
- $this->sort();
- }
-
- return $this->contents;
- }
-}
diff --git a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/VBox.php b/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/VBox.php
deleted file mode 100644
index d8746ee..0000000
--- a/includes/composer/vendor/ksubileau/color-thief-php/src/ColorThief/VBox.php
+++ /dev/null
@@ -1,219 +0,0 @@
-<?php
-
-/*
- * This file is part of the Color Thief PHP project.
- *
- * (c) Kevin Subileau
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
-declare(strict_types=1);
-
-namespace ColorThief;
-
-class VBox
-{
- /** @var int */
- public $r1;
- /** @var int */
- public $r2;
- /** @var int */
- public $g1;
- /** @var int */
- public $g2;
- /** @var int */
- public $b1;
- /** @var int */
- public $b2;
-
- /** @var array<int, int> */
- public $histo;
-
- /** @var int */
- private $volume;
- /** @var bool */
- private $volume_set = false;
-
- /** @var int */
- private $count;
- /** @var bool */
- private $count_set = false;
-
- /**
- * @var array
- * @phpstan-var ColorRGB
- */
- private $avg;
- /** @var bool */
- private $avg_set = false;
-
- /**
- * VBox constructor.
- *
- * @param array<int, int> $histo
- */
- public function __construct(int $r1, int $r2, int $g1, int $g2, int $b1, int $b2, array $histo)
- {
- $this->r1 = $r1;
- $this->r2 = $r2;
- $this->g1 = $g1;
- $this->g2 = $g2;
- $this->b1 = $b1;
- $this->b2 = $b2;
- $this->histo = $histo;
- }
-
- public function volume(bool $force = false): int
- {
- if (true !== $this->volume_set || $force) {
- $this->volume = (($this->r2 - $this->r1 + 1) * ($this->g2 - $this->g1 + 1) * ($this->b2 - $this->b1 + 1));
- $this->volume_set = true;
- }
-
- return $this->volume;
- }
-
- public function count(bool $force = false): int
- {
- if (true !== $this->count_set || $force) {
- $npix = 0;
-
- // Select the fastest way (i.e. with the fewest iterations) to count
- // the number of pixels contained in this vbox.
- if ($this->volume() > \count($this->histo)) {
- // Iterate over the histogram if the size of this histogram is lower than the vbox volume
- foreach ($this->histo as $bucketIndex => $count) {
- $rgbBuckets = ColorThief::getColorsFromIndex($bucketIndex, ColorThief::SIGBITS);
- if ($this->contains($rgbBuckets, 0)) {
- $npix += $count;
- }
- }
- } else {
- // Or iterate over points of the vbox if the size of the histogram is greater than the vbox volume
- for ($redBucket = $this->r1; $redBucket <= $this->r2; ++$redBucket) {
- for ($greenBucket = $this->g1; $greenBucket <= $this->g2; ++$greenBucket) {
- for ($blueBucket = $this->b1; $blueBucket <= $this->b2; ++$blueBucket) {
- // The getColorIndex function takes RGB values instead of buckets. The left shift converts our bucket into its RGB value.
- $bucketIndex = ColorThief::getColorIndex(
- $redBucket << ColorThief::RSHIFT,
- $greenBucket << ColorThief::RSHIFT,
- $blueBucket << ColorThief::RSHIFT,
- ColorThief::SIGBITS
- );
- if (isset($this->histo[$bucketIndex])) {
- $npix += $this->histo[$bucketIndex];
- }
- }
- }
- }
- }
- $this->count = $npix;
- $this->count_set = true;
- }
-
- return $this->count;
- }
-
- public function copy(): self
- {
- return new self($this->r1, $this->r2, $this->g1, $this->g2, $this->b1, $this->b2, $this->histo);
- }
-
- /**
- * Calculates the average color represented by this VBox.
- *
- * @phpstan-return ColorRGB
- */
- public function avg(bool $force = false): array
- {
- if (true !== $this->avg_set || $force) {
- $ntot = 0;
- $mult = 1 << ColorThief::RSHIFT;
- $rsum = 0;
- $gsum = 0;
- $bsum = 0;
-
- for ($redBucket = $this->r1; $redBucket <= $this->r2; ++$redBucket) {
- for ($greenBucket = $this->g1; $greenBucket <= $this->g2; ++$greenBucket) {
- for ($blueBucket = $this->b1; $blueBucket <= $this->b2; ++$blueBucket) {
- // getColorIndex takes RGB values instead of buckets, so left shift so we get a bucketIndex
- $bucketIndex = ColorThief::getColorIndex(
- $redBucket << ColorThief::RSHIFT,
- $greenBucket << ColorThief::RSHIFT,
- $blueBucket << ColorThief::RSHIFT,
- ColorThief::SIGBITS
- );
-
- // The bucket values need to be multiplied by $mult to get the RGB values.
- // Can't use a left shift here, as we're working with a floating point number to put the value at the bucket's midpoint.
- $hval = $this->histo[$bucketIndex] ?? 0;
- $ntot += $hval;
- $rsum += ($hval * ($redBucket + 0.5) * $mult);
- $gsum += ($hval * ($greenBucket + 0.5) * $mult);
- $bsum += ($hval * ($blueBucket + 0.5) * $mult);
- }
- }
- }
-
- if ($ntot) {
- $this->avg = [
- (int) ($rsum / $ntot),
- (int) ($gsum / $ntot),
- (int) ($bsum / $ntot),
- ];
- } else {
- // echo 'empty box'."\n";
- $this->avg = [
- (int) ($mult * ($this->r1 + $this->r2 + 1) / 2),
- (int) ($mult * ($this->g1 + $this->g2 + 1) / 2),
- (int) ($mult * ($this->b1 + $this->b2 + 1) / 2),
- ];
-
- // Ensure all channel values are leather or equal 255 (Issue #24)
- $this->avg = array_map(function ($val) {
- return min($val, 255);
- }, $this->avg);
- }
-
- $this->avg_set = true;
- }
-
- return $this->avg;
- }
-
- /**
- * @phpstan-param ColorRGB $rgbValue
- */
- public function contains(array $rgbValue, int $rshift = ColorThief::RSHIFT): bool
- {
- // Get the buckets from the RGB values.
- $redBucket = $rgbValue[0] >> $rshift;
- $greenBucket = $rgbValue[1] >> $rshift;
- $blueBucket = $rgbValue[2] >> $rshift;
-
- return
- $redBucket >= $this->r1 &&
- $redBucket <= $this->r2 &&
- $greenBucket >= $this->g1 &&
- $greenBucket <= $this->g2 &&
- $blueBucket >= $this->b1 &&
- $blueBucket <= $this->b2;
- }
-
- /**
- * Determines the longest axis.
- *
- * @phpstan-return 'r'|'g'|'b'
- */
- public function longestAxis(): string
- {
- // Color-Width for RGB
- $red = $this->r2 - $this->r1;
- $green = $this->g2 - $this->g1;
- $blue = $this->b2 - $this->b1;
-
- return $red >= $green && $red >= $blue ? 'r' : ($green >= $red && $green >= $blue ? 'g' : 'b');
- }
-}
diff --git a/includes/composer/vendor/om/icalparser/.github/workflows/php.yml b/includes/composer/vendor/om/icalparser/.github/workflows/php.yml
deleted file mode 100644
index e502b81..0000000
--- a/includes/composer/vendor/om/icalparser/.github/workflows/php.yml
+++ /dev/null
@@ -1,40 +0,0 @@
-name: PHP Tests
-
-on: [ push, pull_request ]
-
-jobs:
-
- build:
- strategy:
- matrix:
- operating-system: [ ubuntu-latest ]
- php-versions: [ '8.0', '8.1', '8.2' ]
- experimental: [ false ]
- include:
- - php-versions: '8.3'
- operating-system: ubuntu-latest
- experimental: true
- fail-fast: false
- runs-on: ${{ matrix.operating-system }}
- continue-on-error: ${{ matrix.experimental }}
- steps:
- - uses: actions/checkout@v3
-
- - name: Setup PHP
- uses: shivammathur/setup-php@v2
- with:
- php-version: ${{ matrix.php-versions }}
-
- - name: Validate composer.json and composer.lock
- run: composer validate
-
- - name: Install dependencies
- if: "${{ matrix.experimental == false }}"
- run: composer install --prefer-dist --no-progress --no-suggest
-
- - name: Install dependencies, ignore php requirements
- if: "${{ matrix.experimental == true }}"
- run: composer install --prefer-dist --no-progress --no-suggest --ignore-platform-reqs
-
- - name: Run test suite
- run: composer run-script test
diff --git a/includes/composer/vendor/om/icalparser/.github/workflows/typo.yml b/includes/composer/vendor/om/icalparser/.github/workflows/typo.yml
deleted file mode 100644
index 97d55a2..0000000
--- a/includes/composer/vendor/om/icalparser/.github/workflows/typo.yml
+++ /dev/null
@@ -1,14 +0,0 @@
-name: Typo Tests
-on: [ pull_request ]
-
-jobs:
- misspell:
- name: Check for typos / misspells
- runs-on: ubuntu-latest
- steps:
- - uses: actions/checkout@v3
-
- - name: Run misspell with reviewdog
- uses: reviewdog/action-misspell@v1
- with:
- github_token: ${{ secrets.github_token }}
diff --git a/includes/composer/vendor/om/icalparser/.gitignore b/includes/composer/vendor/om/icalparser/.gitignore
deleted file mode 100644
index 4a59cd1..0000000
--- a/includes/composer/vendor/om/icalparser/.gitignore
+++ /dev/null
@@ -1,4 +0,0 @@
-.idea
-composer.lock
-/vendor/
-tests/output/ \ No newline at end of file
diff --git a/includes/composer/vendor/om/icalparser/LICENSE b/includes/composer/vendor/om/icalparser/LICENSE
deleted file mode 100644
index ce7d41d..0000000
--- a/includes/composer/vendor/om/icalparser/LICENSE
+++ /dev/null
@@ -1,24 +0,0 @@
-Copyright (c) 2014-2022, Roman Ožana
-All rights reserved.
-
-Redistribution and use in source and binary forms, with or without
-modification, are permitted provided that the following conditions are met:
- * Redistributions of source code must retain the above copyright
- notice, this list of conditions and the following disclaimer.
- * Redistributions in binary form must reproduce the above copyright
- notice, this list of conditions and the following disclaimer in the
- documentation and/or other materials provided with the distribution.
- * Neither the name of the <organization> nor the
- names of its contributors may be used to endorse or promote products
- derived from this software without specific prior written permission.
-
-THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
-ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
-WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
-DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
-DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
-(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
-LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
-ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
-SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
diff --git a/includes/composer/vendor/om/icalparser/bin/timezones.php b/includes/composer/vendor/om/icalparser/bin/timezones.php
deleted file mode 100644
index 3bf3708..0000000
--- a/includes/composer/vendor/om/icalparser/bin/timezones.php
+++ /dev/null
@@ -1,20 +0,0 @@
-<?php
-
-/**
- * This file generates a map from windows timezones to tz database timezones
- *
- * @author Clement Wong <cw@clement.hk>
- * @license http://www.opensource.org/licenses/mit-license.php MIT License
- */
-$windows_timezones = [];
-$windowstimezonexml = new DOMDocument();
-$windowstimezonexml->load('https://raw.githubusercontent.com/unicode-org/cldr/master/common/supplemental/windowsZones.xml');
-$zones = $windowstimezonexml->getElementsByTagName('mapZone');
-foreach ($zones as $zone) {
- if ($zone->getAttribute('territory') === '001') {
- $windows_timezones[$zone->getAttribute('other')] = $zone->getAttribute('type');
- }
-}
-
-file_put_contents(__DIR__ . '/../src/WindowsTimezones.php', "<?php\n\$windows_timezones = " . var_export($windows_timezones, true) . ';');
-
diff --git a/includes/composer/vendor/om/icalparser/composer.json b/includes/composer/vendor/om/icalparser/composer.json
deleted file mode 100644
index 736fc7a..0000000
--- a/includes/composer/vendor/om/icalparser/composer.json
+++ /dev/null
@@ -1,33 +0,0 @@
-{
- "name": "om/icalparser",
- "license": "BSD-3-Clause",
- "description": "Simple iCal parser",
- "keywords": [
- "iCal",
- "calendar",
- "parser"
- ],
- "authors": [
- {
- "name": "Roman Ožana",
- "email": "roman@ozana.cz"
- }
- ],
- "require": {
- "php": ">=8.0.0"
- },
- "suggest": {
- "ext-dom": "for timezone tool"
- },
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "scripts": {
- "test": "tester tests -s -p php"
- },
- "require-dev": {
- "nette/tester": "^2.4"
- }
-}
diff --git a/includes/composer/vendor/om/icalparser/example/index.php b/includes/composer/vendor/om/icalparser/example/index.php
deleted file mode 100644
index 70c5598..0000000
--- a/includes/composer/vendor/om/icalparser/example/index.php
+++ /dev/null
@@ -1,33 +0,0 @@
-<!DOCTYPE html>
-<html lang="cs-CZ">
-<head>
- <meta charset="utf-8">
- <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
- <title>Ical Parser example</title>
- <link href="https://cdn.jsdelivr.net/npm/bootstrap/dist/css/bootstrap.min.css">
-</head>
-<body>
-<div class="container">
- <h1>Czech holidays</h1>
- <table class="table table-bordered">
- <thead>
- <tr>
- <th class="text-end">Date</th>
- <th>Summary</th>
- </tr>
- </thead>
- <tbody>
- <?php
- require_once __DIR__ . '/../vendor/autoload.php';
- $cal = new \om\IcalParser();
- $results = $cal->parseFile('https://www.google.com/calendar/ical/cs.czech%23holiday%40group.v.calendar.google.com/public/basic.ics');
- foreach ($cal->getEvents()->sorted() as $event) {
- printf('<tr><th class="text-end">%s</th><td>%s</td></tr>', $event['DTSTART']->format('j.n.Y'), $event['SUMMARY']);
- }
- ?>
- </tbody>
- </table>
-</div>
-</body>
-</html>
diff --git a/includes/composer/vendor/om/icalparser/readme.md b/includes/composer/vendor/om/icalparser/readme.md
deleted file mode 100644
index 6666c10..0000000
--- a/includes/composer/vendor/om/icalparser/readme.md
+++ /dev/null
@@ -1,79 +0,0 @@
-# PHP iCal Parser
-
-[![PHP Tests](https://github.com/OzzyCzech/icalparser/actions/workflows/php.yml/badge.svg)](https://github.com/OzzyCzech/icalparser/actions/workflows/php.yml)
-[![Latest Stable Version](https://poser.pugx.org/om/icalparser/v/stable)](https://packagist.org/packages/om/icalparser)
-[![Total Downloads](https://poser.pugx.org/om/icalparser/downloads)](https://packagist.org/packages/om/icalparser)
-[![License](https://poser.pugx.org/om/icalparser/license)](https://packagist.org/packages/om/icalparser)
-[![PHP Version Require](http://poser.pugx.org/om/icalparser/require/php)](https://packagist.org/packages/om/icalparser)
-
-Internet Calendaring Parser [rfc2445](https://www.ietf.org/rfc/rfc2445.txt) or iCal parser is simple PHP class for parsing format into array.
-
-[!["Buy Me A Coffee"](https://www.buymeacoffee.com/assets/img/custom_images/orange_img.png)](https://www.buymeacoffee.com/ozzyczech)
-
-## How to install
-
-The recommended way to is via Composer:
-
-```shell script
-composer require om/icalparser
-```
-
-## Usage and example
-
-```php
-<?php
-use om\IcalParser;
-require_once '../vendor/autoload.php';
-
-$cal = new IcalParser();
-$results = $cal->parseFile(
- 'https://www.google.com/calendar/ical/cs.czech%23holiday%40group.v.calendar.google.com/public/basic.ics'
-);
-
-foreach ($cal->getEvents()->sorted() as $event) {
- printf('%s - %s' . PHP_EOL, $event['DTSTART']->format('j.n.Y'), $event['SUMMARY']);
-
-}
-```
-
-Each property of each event is available using the property name (in capital letters) as a key.
-There are some special cases:
-
-- multiple attendees with individual parameters: use `ATTENDEES` as key to get all attendees in the following scheme:
-```php
-[
- [
- 'ROLE' => 'REQ-PARTICIPANT',
- 'PARTSTAT' => 'NEEDS-ACTION',
- 'CN' => 'John Doe',
- 'VALUE' => 'mailto:john.doe@example.org'
- ],
- [
- 'ROLE' => 'REQ-PARTICIPANT',
- 'PARTSTAT' => 'NEEDS-ACTION',
- 'CN' => 'Test Example',
- 'VALUE' => 'mailto:test@example.org'
- ]
-]
-```
-- organizer's name: the *CN* parameter of the organizer property can be retrieved using the key `ORGANIZER-CN`
-
-You can run example with [PHP Built-in web server](https://www.php.net/manual/en/features.commandline.webserver.php) as follow:
-
-```shell
-php -S localhost:8000 -t example
-```
-
-## Requirements
-
-- PHP 8.0+
-
-## Run tests
-
-iCal parser using [Nette Tester](https://github.com/nette/tester). The tests can be invoked via [composer](https://getcomposer.org/).
-
-```shell script
-composer update
-composer test
-```
-
diff --git a/includes/composer/vendor/om/icalparser/src/EventsList.php b/includes/composer/vendor/om/icalparser/src/EventsList.php
deleted file mode 100644
index 241eb8c..0000000
--- a/includes/composer/vendor/om/icalparser/src/EventsList.php
+++ /dev/null
@@ -1,56 +0,0 @@
-<?php
-
-namespace om;
-
-use ArrayObject;
-
-/**
- * Copyright (c) 2004-2022 Roman Ožana (https://ozana.cz)
- *
- * @license BSD-3-Clause
- * @author Roman Ožana <roman@ozana.cz>
- */
-class EventsList extends ArrayObject {
-
- /**
- * Return array of Events
- *
- * @return array
- */
- public function getArrayCopy(): array {
- return array_values(parent::getArrayCopy());
- }
-
- /**
- * Return sorted EventList (the newest dates are first)
- *
- * @return $this
- */
- public function sorted(): EventsList {
- $this->uasort(static function ($a, $b): int {
- if ($a['DTSTART'] === $b['DTSTART']) {
- return 0;
- }
- return ($a['DTSTART'] < $b['DTSTART']) ? -1 : 1;
- });
-
- return $this;
- }
-
- /**
- * Return reversed sorted EventList (the oldest dates are first)
- *
- * @return $this
- */
- public function reversed(): EventsList {
- $this->uasort(static function ($a, $b): int {
- if ($a['DTSTART'] === $b['DTSTART']) {
- return 0;
- }
- return ($a['DTSTART'] > $b['DTSTART']) ? -1 : 1;
- });
-
- return $this;
- }
-
-}
diff --git a/includes/composer/vendor/om/icalparser/src/Freq.php b/includes/composer/vendor/om/icalparser/src/Freq.php
deleted file mode 100644
index 15cf626..0000000
--- a/includes/composer/vendor/om/icalparser/src/Freq.php
+++ /dev/null
@@ -1,634 +0,0 @@
-<?php
-
-namespace om;
-
-use DateTime;
-use DateTimeZone;
-use Exception;
-
-/**
- * Class taken from https://github.com/coopTilleuls/intouch-iCalendar.git (Freq.php)
- *
- * @author PC Drew <pc@schoolblocks.com>
- */
-
-/**
- * A class to store Frequency-rules in. Will allow a easy way to find the
- * last and next occurrence of the rule.
- *
- * No - this is so not pretty. But.. ehh.. You do it better, and I will
- * gladly accept patches.
- *
- * Created by trail-and-error on the examples given in the RFC.
- *
- * TODO: Update to a better way of doing calculating the different options.
- * Instead of only keeping track of the best of the current dates found
- * it should instead keep a array of all the calculated dates within the
- * period.
- * This should fix the issues with multi-rule + multi-rule interference,
- * and make it possible to implement the SETPOS rule.
- * By pushing the next period onto the stack as the last option will
- * (hopefully) remove the need for the awful simpleMode
- *
- * @author Morten Fangel (C) 2008
- * @author Michael Kahn (C) 2013
- * @license http://creativecommons.org/licenses/by-sa/2.5/dk/deed.en_GB CC-BY-SA-DK
- */
-class Freq {
-
- /** @var bool */
- static bool $debug = false;
-
- protected array $weekdays = [
- 'MO' => 'monday',
- 'TU' => 'tuesday',
- 'WE' => 'wednesday',
- 'TH' => 'thursday',
- 'FR' => 'friday',
- 'SA' => 'saturday',
- 'SU' => 'sunday',
- ];
- protected array $knownRules = [
- 'month',
- 'weekno',
- 'day',
- 'monthday',
- 'yearday',
- 'hour',
- 'minute',
- ]; //others : 'setpos', 'second'
-
- protected array $ruleModifiers = ['wkst'];
- protected bool $simpleMode = true;
-
- protected array $rules = ['freq' => 'yearly', 'interval' => 1];
- protected int $start = 0;
- protected string $freq = '';
-
- protected array $excluded; //EXDATE
- protected array $added; //RDATE
-
- protected array $cache; // getAllOccurrences()
-
- /**
- * Constructs a new Frequency-rule
- *
- * @param array|string $rule
- * @param int $start Unix-timestamp (important : Need to be the start of Event)
- * @param array $excluded of int (timestamps), see EXDATE documentation
- * @param array $added of int (timestamps), see RDATE documentation
- * @throws Exception
- */
- public function __construct(array|string $rule, int $start, array $excluded = [], array $added = []) {
- $this->start = $start;
- $this->excluded = [];
-
- $rules = [];
- foreach ($rule as $k => $v) {
- $this->rules[strtolower($k)] = $v;
- }
-
- if (isset($this->rules['until']) && is_string($this->rules['until'])) {
- $this->rules['until'] = strtotime($this->rules['until']);
- } elseif ($this->rules['until'] instanceof DateTime) {
- $this->rules['until'] = $this->rules['until']->getTimestamp();
- }
- $this->freq = strtolower($this->rules['freq']);
-
- foreach ($this->knownRules as $rule) {
- if (isset($this->rules['by' . $rule])) {
- if ($this->isPrerule($rule, $this->freq)) {
- $this->simpleMode = false;
- }
- }
- }
-
- if (!$this->simpleMode) {
- if (!(isset($this->rules['byday']) || isset($this->rules['bymonthday']) || isset($this->rules['byyearday']))) {
- $this->rules['bymonthday'] = date('d', $this->start);
- }
- }
-
- //set until, and cache
- if (isset($this->rules['count'])) {
-
- $cache[$ts] = $ts = $this->start;
- for ($n = 1; $n < $this->rules['count']; $n++) {
- $ts = $this->findNext($ts);
- $cache[$ts] = $ts;
- }
- $this->rules['until'] = $ts;
-
- //EXDATE
- if (!empty($excluded)) {
- foreach ($excluded as $ts) {
- unset($cache[$ts]);
- }
- }
- //RDATE
- if (!empty($added)) {
- $cache = array_unique(array_merge(array_values($cache), $added));
- asort($cache);
- }
-
- $this->cache = array_values($cache);
- }
-
- $this->excluded = $excluded;
- $this->added = $added;
- }
-
- private function isPrerule(string $rule, string $freq): bool {
- if ($rule === 'year') {
- return false;
- }
- if ($rule === 'month' && $freq === 'yearly') {
- return true;
- }
- if ($rule === 'monthday' && in_array($freq, ['yearly', 'monthly']) && !isset($this->rules['byday'])) {
- return true;
- }
- // TODO: is it faster to do monthday first, and ignore day if monthday exists? - prolly by a factor of 4..
- if ($rule === 'yearday' && $freq === 'yearly') {
- return true;
- }
- if ($rule === 'weekno' && $freq === 'yearly') {
- return true;
- }
- if ($rule === 'day' && in_array($freq, ['yearly', 'monthly', 'weekly'])) {
- return true;
- }
- if ($rule === 'hour' && in_array($freq, ['yearly', 'monthly', 'weekly', 'daily'])) {
- return true;
- }
- if ($rule === 'minute') {
- return true;
- }
-
- return false;
- }
-
- /**
- * Calculates the next time after the given offset that the rule
- * will apply.
- *
- * The approach to finding the next is as follows:
- * First we establish a timeframe to find timestamps in. This is
- * between $offset and the end of the period that $offset is in.
- *
- * We then loop though all the rules (that is a Prerule in the
- * current freq.), and finds the smallest timestamp inside the
- * timeframe.
- *
- * If we find something, we check if the date is a valid recurrence
- * (with validDate). If it is, we return it. Otherwise we try to
- * find a new date inside the same timeframe (but using the new-
- * found date as offset)
- *
- * If no new timestamps were found in the period, we try in the
- * next period
- *
- * @param int $offset
- * @return int|bool
- * @throws Exception
- */
- public function findNext(int $offset): bool|int {
- if (!empty($this->cache)) {
- foreach ($this->cache as $ts) {
- if ($ts > $offset) {
- return $ts;
- }
- }
- }
-
- //make sure the offset is valid
- if ($offset === false || (isset($this->rules['until']) && $offset > $this->rules['until'])) {
- if (static::$debug) printf("STOP: %s\n", date('r', $offset));
- return false;
- }
-
- $found = true;
-
- //set the timestamp of the offset (ignoring hours and minutes unless we want them to be
- //part of the calculations.
- if (static::$debug) printf("O: %s\n", date('r', $offset));
- $hour = (in_array($this->freq, ['hourly', 'minutely']) && $offset > $this->start) ? date('H', $offset) : date(
- 'H', $this->start
- );
- $minute = (($this->freq === 'minutely' || isset($this->rules['byminute'])) && $offset > $this->start) ? date(
- 'i', $offset
- ) : date('i', $this->start);
- $t = mktime($hour, $minute, date('s', $this->start), date('m', $offset), date('d', $offset), date('Y', $offset));
- if (static::$debug) printf("START: %s\n", date('r', $t));
-
- if ($this->simpleMode) {
- if ($offset < $t) {
- $ts = $t;
- if ($ts && in_array($ts, $this->excluded, true)) {
- $ts = $this->findNext($ts);
- }
- } else {
- $ts = $this->findStartingPoint($t, $this->rules['interval'], false);
- if (!$this->validDate($ts)) {
- $ts = $this->findNext($ts);
- }
- }
-
- return $ts;
- }
-
- //EOP needs to have the same TIME as START ($t)
- $tO = new DateTime('@' . $t, new DateTimeZone('UTC'));
-
- $eop = $this->findEndOfPeriod($offset);
- $eopO = new DateTime('@' . $eop, new DateTimeZone('UTC'));
- $eopO->setTime($tO->format('H'), $tO->format('i'), $tO->format('s'));
- $eop = $eopO->getTimestamp();
- unset($eopO, $tO);
-
- if (static::$debug) {
- echo 'EOP: ' . date('r', $eop) . "\n";
- }
- foreach ($this->knownRules as $rule) {
- if ($found && isset($this->rules['by' . $rule])) {
- if ($this->isPrerule($rule, $this->freq)) {
- $subRules = explode(',', $this->rules['by' . $rule]);
- $_t = null;
- foreach ($subRules as $subRule) {
- $imm = call_user_func_array([$this, "ruleBy$rule"], [$subRule, $t]);
- if ($imm === false) {
- break;
- }
- if (static::$debug) {
- printf("%s: %s A: %d\n", strtoupper($rule), date('r', $imm), intval($imm > $offset && $imm < $eop));
- }
- if ($imm > $offset && $imm <= $eop && ($_t == null || $imm < $_t)) {
- $_t = $imm;
- }
- }
- if ($_t !== null) {
- $t = $_t;
- } else {
- $found = $this->validDate($t);
- }
- }
- }
- }
-
- if ($offset < $this->start && $this->start < $t) {
- $ts = $this->start;
- } elseif ($found && ($t != $offset)) {
- if ($this->validDate($t)) {
- if (static::$debug) echo 'OK' . "\n";
- $ts = $t;
- } else {
- if (static::$debug) echo 'Invalid' . "\n";
- $ts = $this->findNext($t);
- }
- } else {
- if (static::$debug) echo 'Not found' . "\n";
- $ts = $this->findNext($this->findStartingPoint($offset, $this->rules['interval']));
- }
- if ($ts && in_array($ts, $this->excluded, true)) {
- return $this->findNext($ts);
- }
-
- return $ts;
- }
-
- /**
- * Finds the starting point for the next rule. It goes $interval
- * 'freq' forward in time since the given offset
- *
- * @param int $offset
- * @param int $interval
- * @param boolean $truncate
- * @return int
- */
- private function findStartingPoint(int $offset, int $interval, bool $truncate = true): int {
- $_freq = ($this->freq === 'daily') ? 'day__' : $this->freq;
- $t = '+' . $interval . ' ' . substr($_freq, 0, -2) . 's';
- if ($_freq === 'monthly' && $truncate) {
- if ($interval > 1) {
- $offset = strtotime('+' . ($interval - 1) . ' months ', $offset); // FIXME return type int|false
- }
- $t = '+' . (date('t', $offset) - date('d', $offset) + 1) . ' days';
- }
-
- $sp = strtotime($t, $offset);
-
- if ($truncate) {
- $sp = $this->truncateToPeriod($sp, $this->freq);
- }
-
- return $sp;
- }
-
- /**
- * Resets the timestamp to the beginning of the
- * period specified by freq
- *
- * Yes - the fall-through is on purpose!
- *
- * @param int $time
- * @param string $freq
- * @return int
- */
- private function truncateToPeriod(int $time, string $freq): int {
- $date = getdate($time);
- switch ($freq) {
- case 'yearly':
- $date['mon'] = 1;
- case 'monthly':
- $date['mday'] = 1;
- case 'daily':
- $date['hours'] = 0;
- case 'hourly':
- $date['minutes'] = 0;
- case 'minutely':
- $date['seconds'] = 0;
- break;
- case 'weekly':
- if (date('N', $time) == 1) { // FIXME wrong compare, date return string|false
- $date['hours'] = 0;
- $date['minutes'] = 0;
- $date['seconds'] = 0;
- } else {
- $date = getdate(strtotime('last monday 0:00', $time));
- }
- break;
- }
- return mktime($date['hours'], $date['minutes'], $date['seconds'], $date['mon'], $date['mday'], $date['year']);
- }
-
- private function validDate($t): bool {
- if (isset($this->rules['until']) && $t > $this->rules['until']) {
- return false;
- }
-
- if (in_array($t, $this->excluded, true)) {
- return false;
- }
-
- if (isset($this->rules['bymonth'])) {
- $months = explode(',', $this->rules['bymonth']);
- if (!in_array(date('m', $t), $months, true)) {
- return false;
- }
- }
- if (isset($this->rules['byday'])) {
- $days = explode(',', $this->rules['byday']);
- foreach ($days as $i => $k) {
- $days[$i] = $this->weekdays[preg_replace('/[^A-Z]/', '', $k)];
- }
- if (!in_array(strtolower(date('l', $t)), $days, true)) {
- return false;
- }
- }
- if (isset($this->rules['byweekno'])) {
- $weeks = explode(',', $this->rules['byweekno']);
- if (!in_array(date('W', $t), $weeks, true)) {
- return false;
- }
- }
- if (isset($this->rules['bymonthday'])) {
- $weekdays = explode(',', $this->rules['bymonthday']);
- foreach ($weekdays as $i => $k) {
- if ($k < 0) {
- $weekdays[$i] = date('t', $t) + $k + 1;
- }
- }
- if (!in_array(date('d', $t), $weekdays, true)) {
- return false;
- }
- }
- if (isset($this->rules['byhour'])) {
- $hours = explode(',', $this->rules['byhour']);
- if (!in_array(date('H', $t), $hours, true)) {
- return false;
- }
- }
-
- return true;
- }
-
- /**
- * Finds the earliest timestamp possible outside this period.
- *
- * @param int $offset
- * @return int
- */
- public function findEndOfPeriod(int $offset = 0): int {
- return $this->findStartingPoint($offset, 1, false);
- }
-
- /**
- * Returns the previous (most recent) occurrence of the rule from the
- * given offset
- *
- * @param int $offset
- * @return int
- * @throws Exception
- */
- public function previousOccurrence(int $offset): bool|int {
- if (!empty($this->cache)) {
- $t2 = $this->start;
- foreach ($this->cache as $ts) {
- if ($ts >= $offset) {
- return $t2;
- }
- $t2 = $ts;
- }
- } else {
- $ts = $this->start;
- while (($t2 = $this->findNext($ts)) < $offset) {
- if (!$t2) {
- break;
- }
- $ts = $t2;
- }
- }
-
- return $ts;
- }
-
- /**
- * Returns the next occurrence of this rule after the given offset
- *
- * @param int $offset
- * @return int
- * @throws Exception
- */
- public function nextOccurrence(int $offset): bool|int {
- if ($offset < $this->start) {
- return $this->firstOccurrence();
- }
- return $this->findNext($offset);
- }
-
- /**
- * Finds the first occurrence of the rule.
- *
- * @return bool|int timestamp
- * @throws \Exception
- */
- public function firstOccurrence(): bool|int {
- $t = $this->start;
- if (in_array($t, $this->excluded)) {
- $t = $this->findNext($t);
- }
-
- return $t;
- }
-
- /**
- * Finds the absolute last occurrence of the rule from the given offset.
- * Builds also the cache, if not set before...
- *
- * @return int timestamp
- * @throws Exception
- */
- public function lastOccurrence(): int {
- //build cache if not done
- $this->getAllOccurrences();
- //return last timestamp in cache
- return end($this->cache);
- }
-
- /**
- * Returns all timestamps array(), build the cache if not made before
- *
- * @return array
- * @throws Exception
- */
- public function getAllOccurrences(): array {
- if (empty($this->cache)) {
- $cache = [];
-
- //build cache
- $next = $this->firstOccurrence();
- while ($next) {
- $cache[] = $next;
- $next = $this->findNext($next);
- }
- if (!empty($this->added)) {
- $cache = array_unique(array_merge($cache, $this->added));
- asort($cache);
- }
- $this->cache = $cache;
- }
-
- return $this->cache;
- }
-
- /**
- * Applies the BYDAY rule to the given timestamp
- *
- * @param string $rule
- * @param int $t
- * @return int
- */
- private function ruleByDay(string $rule, int $t): int {
- $dir = ($rule[0] === '-') ? -1 : 1;
- $dir_t = ($dir === 1) ? 'next' : 'last';
-
- $d = $this->weekdays[substr($rule, -2)];
- $s = $dir_t . ' ' . $d . ' ' . date('H:i:s', $t);
-
- if ($rule == substr($rule, -2)) {
- if (date('l', $t) == ucfirst($d)) {
- $s = 'today ' . date('H:i:s', $t);
- }
-
- $_t = strtotime($s, $t);
-
- if ($_t == $t && in_array($this->freq, ['weekly', 'monthly', 'yearly'])) {
- // Yes. This is not a great idea.. but hey, it works.. for now
- $s = 'next ' . $d . ' ' . date('H:i:s', $t);
- $_t = strtotime($s, $_t);
- }
-
- return $_t;
- } else {
- $_f = $this->freq;
- if (isset($this->rules['bymonth']) && $this->freq === 'yearly') {
- $this->freq = 'monthly';
- }
- if ($dir === -1) {
- $_t = $this->findEndOfPeriod($t);
- } else {
- $_t = $this->truncateToPeriod($t, $this->freq);
- }
- $this->freq = $_f;
-
- $c = preg_replace('/[^0-9]/', '', $rule);
- $c = ($c == '') ? 1 : $c;
-
- $n = $_t;
- while ($c > 0) {
- if ($dir === 1 && $c == 1 && date('l', $t) == ucfirst($d)) {
- $s = 'today ' . date('H:i:s', $t);
- }
- $n = strtotime($s, $n);
- $c--;
- }
-
- return $n;
- }
- }
-
- private function ruleByMonth($rule, int $t): bool|int {
- $_t = mktime(date('H', $t), date('i', $t), date('s', $t), $rule, date('d', $t), date('Y', $t));
- if ($t == $_t && isset($this->rules['byday'])) {
- // TODO: this should check if one of the by*day's exists, and have a multi-day value
- return false;
- } else {
- return $_t;
- }
- }
-
- private function ruleByMonthday($rule, int $t): bool|int {
- if ($rule < 0) {
- $rule = date('t', $t) + $rule + 1;
- }
-
- return mktime(date('H', $t), date('i', $t), date('s', $t), date('m', $t), $rule, date('Y', $t));
- }
-
- private function ruleByYearday($rule, int $t): bool|int {
- if ($rule < 0) {
- $_t = $this->findEndOfPeriod();
- $d = '-';
- } else {
- $_t = $this->truncateToPeriod($t, $this->freq);
- $d = '+';
- }
- $s = $d . abs($rule - 1) . ' days ' . date('H:i:s', $t);
-
- return strtotime($s, $_t);
- }
-
- private function ruleByWeekno($rule, int $t): bool|int {
- if ($rule < 0) {
- $_t = $this->findEndOfPeriod();
- $d = '-';
- } else {
- $_t = $this->truncateToPeriod($t, $this->freq);
- $d = '+';
- }
-
- $sub = (date('W', $_t) == 1) ? 2 : 1;
- $s = $d . abs($rule - $sub) . ' weeks ' . date('H:i:s', $t);
- $_t = strtotime($s, $_t);
-
- return $_t;
- }
-
- private function ruleByHour($rule, int $t): bool|int {
- return mktime($rule, date('i', $t), date('s', $t), date('m', $t), date('d', $t), date('Y', $t));
- }
-
- private function ruleByMinute($rule, int $t): bool|int {
- return mktime(date('h', $t), $rule, date('s', $t), date('m', $t), date('d', $t), date('Y', $t));
- }
-}
diff --git a/includes/composer/vendor/om/icalparser/src/IcalParser.php b/includes/composer/vendor/om/icalparser/src/IcalParser.php
deleted file mode 100644
index 282deef..0000000
--- a/includes/composer/vendor/om/icalparser/src/IcalParser.php
+++ /dev/null
@@ -1,502 +0,0 @@
-<?php
-
-namespace om;
-
-use ArrayObject;
-use DateInterval;
-use DateTime;
-use DateTimeZone;
-use Exception;
-use InvalidArgumentException;
-use RuntimeException;
-
-/**
- * Copyright (c) 2004-2022 Roman Ožana (https://ozana.cz)
- *
- * @license BSD-3-Clause
- * @author Roman Ožana <roman@ozana.cz>
- */
-class IcalParser {
-
- /** @var ?DateTimeZone */
- public ?DateTimeZone $timezone = null;
-
- /** @var array|null */
- public ?array $data = null;
-
- /** @var array */
- protected array $counters = [];
-
- /** @var array */
- private array $windowsTimezones;
-
- public function __construct() {
- $this->windowsTimezones = require __DIR__ . '/WindowsTimezones.php'; // load Windows timezones from separate file
- }
-
- /**
- * @param string $file
- * @param callable|null $callback
- * @return array|null
- * @throws Exception
- */
- public function parseFile(string $file, callable $callback = null): ?array {
- if (!$handle = fopen($file, 'rb')) {
- throw new RuntimeException('Can\'t open file' . $file . ' for reading.');
- }
- fclose($handle);
-
- return $this->parseString(file_get_contents($file), $callback);
- }
-
- /**
- * @param string $string
- * @param callable|null $callback
- * @param boolean $add if true the parsed string is added to existing data
- * @return array|null
- * @throws Exception
- */
- public function parseString(string $string, callable $callback = null, bool $add = false): ?array {
- if ($add === false) {
- // delete old data
- $this->data = [];
- $this->counters = [];
- }
-
- if (!str_contains($string, 'BEGIN:VCALENDAR')) {
- throw new InvalidArgumentException('Invalid ICAL data format');
- }
-
- $section = 'VCALENDAR';
-
- // Replace \r\n with \n
- $string = str_replace("\r\n", "\n", $string);
-
- // Unfold multi-line strings
- $string = str_replace("\n ", '', $string);
-
- foreach (explode("\n", $string) as $row) {
-
- switch ($row) {
- case 'BEGIN:DAYLIGHT':
- case 'BEGIN:VALARM':
- case 'BEGIN:VTIMEZONE':
- case 'BEGIN:VFREEBUSY':
- case 'BEGIN:VJOURNAL':
- case 'BEGIN:STANDARD':
- case 'BEGIN:VTODO':
- case 'BEGIN:VEVENT':
- $section = substr($row, 6);
- $this->counters[$section] = isset($this->counters[$section]) ? $this->counters[$section] + 1 : 0;
- continue 2; // while
- case 'END:VEVENT':
- $section = substr($row, 4);
- $currCounter = $this->counters[$section];
- $event = $this->data[$section][$currCounter];
- if (!empty($event['RECURRENCE-ID'])) {
- $this->data['_RECURRENCE_IDS'][$event['RECURRENCE-ID']] = $event;
- }
-
- continue 2; // while
- case 'END:DAYLIGHT':
- case 'END:VALARM':
- case 'END:VTIMEZONE':
- case 'END:VFREEBUSY':
- case 'END:VJOURNAL':
- case 'END:STANDARD':
- case 'END:VTODO':
- continue 2; // while
-
- case 'END:VCALENDAR':
- $veventSection = 'VEVENT';
- if (!empty($this->data[$veventSection])) {
- foreach ($this->data[$veventSection] as $currCounter => $event) {
- if (!empty($event['RRULE']) || !empty($event['RDATE'])) {
- $recurrences = $this->parseRecurrences($event);
- if (!empty($recurrences)) {
- $this->data[$veventSection][$currCounter]['RECURRENCES'] = $recurrences;
- }
-
- if (!empty($event['UID'])) {
- $this->data["_RECURRENCE_COUNTERS_BY_UID"][$event['UID']] = $currCounter;
- }
- }
- }
- }
- continue 2; // while
- }
-
- [$key, $middle, $value] = $this->parseRow($row);
-
- if ($callback) {
- // call user function for processing line
- call_user_func($callback, $row, $key, $middle, $value, $section, $this->counters[$section]);
- } else {
- if ($section === 'VCALENDAR') {
- $this->data[$key] = $value;
- } else {
-
- // use an array since there can be multiple entries for this key. This does not
- // break the current implementation--it leaves the original key alone and adds
- // a new one specifically for the array of values.
-
- if ($newKey = $this->isMultipleKey($key)) {
- $this->data[$section][$this->counters[$section]][$newKey][] = $value;
- }
-
- // CATEGORIES can be multiple also but there is special case that there are comma separated categories
-
- if ($this->isMultipleKeyWithCommaSeparation($key)) {
-
- if (str_contains($value, ',')) {
- $values = array_map('trim', preg_split('/(?<![^\\\\]\\\\),/', $value));
- } else {
- $values = [$value];
- }
-
- foreach ($values as $value) {
- $this->data[$section][$this->counters[$section]][$key][] = $value;
- }
-
- } else {
- if (in_array($key, ['ORGANIZER'])) {
- foreach ($middle as $midKey => $midVal) {
- $this->data[$section][$this->counters[$section]][$key . '-' . $midKey] = $midVal;
- }
- }
- if (in_array($key, ['ATTENDEE', 'ORGANIZER'])) {
- $value = $value['VALUE']; // backwards compatibility (leaves ATTENDEE entry as it was)
- }
- $this->data[$section][$this->counters[$section]][$key] = $value;
- }
-
- }
-
- }
- }
-
- return ($callback) ? null : $this->data;
- }
-
- /**
- * @param $event
- * @return array
- * @throws Exception
- */
- public function parseRecurrences($event): array {
- $recurring = new Recurrence($event['RRULE']);
- $exclusions = [];
- $additions = [];
-
- if (!empty($event['EXDATES'])) {
- foreach ($event['EXDATES'] as $exDate) {
- if (is_array($exDate)) {
- foreach ($exDate as $singleExDate) {
- $exclusions[] = $singleExDate->getTimestamp();
- }
- } else {
- $exclusions[] = $exDate->getTimestamp();
- }
- }
- }
-
- if (!empty($event['RDATES'])) {
- foreach ($event['RDATES'] as $rDate) {
- if (is_array($rDate)) {
- foreach ($rDate as $singleRDate) {
- $additions[] = $singleRDate->getTimestamp();
- }
- } else {
- $additions[] = $rDate->getTimestamp();
- }
- }
- }
-
- $until = $recurring->getUntil();
- if ($until === false) {
- //forever... limit to 3 years from now
- $end = new DateTime('now');
- $end->add(new DateInterval('P3Y')); // + 3 years
- $recurring->setUntil($end);
- $until = $recurring->getUntil();
- }
-
- date_default_timezone_set($event['DTSTART']->getTimezone()->getName());
- $frequency = new Freq($recurring->rrule, $event['DTSTART']->getTimestamp(), $exclusions, $additions);
- $recurrenceTimestamps = $frequency->getAllOccurrences();
-
- // This should be fixed in the Freq class, but it's too messy to make sense of
- // This guard only works on WEEKLY, because the others have no fixed time interval
- // There may still be a bug with the others
- if (isset($event['RRULE']['INTERVAL']) && $recurring->getFreq() === "WEEKLY") {
- $replacementList = [];
-
- foreach($recurrenceTimestamps as $timestamp) {
- $tmp = new DateTime('now', $event['DTSTART']->getTimezone());
- $tmp->setTimestamp($timestamp);
-
- $dayCount = $event['DTSTART']->diff($tmp)->format('%a');
-
- if ($dayCount % ($event['RRULE']['INTERVAL'] * 7) == 0) {
- $replacementList[] = $timestamp;
- }
- }
-
- $recurrenceTimestamps = $replacementList;
- }
-
- $recurrences = [];
- foreach ($recurrenceTimestamps as $recurrenceTimestamp) {
- $tmp = new DateTime('now', $event['DTSTART']->getTimezone());
- $tmp->setTimestamp($recurrenceTimestamp);
-
- $recurrenceIDDate = $tmp->format('Ymd');
- $recurrenceIDDateTime = $tmp->format('Ymd\THis');
- if (empty($this->data['_RECURRENCE_IDS'][$recurrenceIDDate]) &&
- empty($this->data['_RECURRENCE_IDS'][$recurrenceIDDateTime])) {
- $gmtCheck = new DateTime('now', new DateTimeZone('UTC'));
- $gmtCheck->setTimestamp($recurrenceTimestamp);
- $recurrenceIDDateTimeZ = $gmtCheck->format('Ymd\THis\Z');
- if (empty($this->data['_RECURRENCE_IDS'][$recurrenceIDDateTimeZ])) {
- $recurrences[] = $tmp;
- }
- }
- }
-
- return $recurrences;
- }
-
- private function parseRow($row): array {
- preg_match('#^([\w-]+);?([\w-]+="[^"]*"|.*?):(.*)$#i', $row, $matches);
-
- $key = false;
- $middle = null;
- $value = null;
-
- if ($matches) {
- $key = $matches[1];
- $middle = $matches[2];
- $value = $matches[3];
- $timezone = null;
-
- if ($key === 'X-WR-TIMEZONE' || $key === 'TZID') {
- if (preg_match('#(\w+/\w+)$#i', $value, $matches)) {
- $value = $matches[1];
- }
- $value = $this->toTimezone($value);
- $this->timezone = new DateTimeZone($value);
- }
-
- // have some middle part ?
- if ($middle && preg_match_all('#(?<key>[^=;]+)=(?<value>[^;]+)#', $middle, $matches, PREG_SET_ORDER)) {
- $middle = [];
- foreach ($matches as $match) {
- if ($match['key'] === 'TZID') {
- $match['value'] = trim($match['value'], "'\"");
- $match['value'] = $this->toTimezone($match['value']);
- try {
- $middle[$match['key']] = $timezone = new DateTimeZone($match['value']);
- } catch (Exception $e) {
- $middle[$match['key']] = $match['value'];
- }
- } elseif ($match['key'] === 'ENCODING') {
- if ($match['value'] === 'QUOTED-PRINTABLE') {
- $value = quoted_printable_decode($value);
- }
- } else {
- $middle[$match['key']] = $match['value'];
- }
- }
- }
- }
-
- // process simple dates with timezone
- if (in_array($key, ['DTSTAMP', 'LAST-MODIFIED', 'CREATED', 'DTSTART', 'DTEND'], true)) {
- try {
- $value = new DateTime($value, ($timezone ?: $this->timezone));
- } catch (Exception $e) {
- $value = null;
- }
- } elseif (in_array($key, ['EXDATE', 'RDATE'])) {
- $values = [];
- foreach (explode(',', $value) as $singleValue) {
- try {
- $values[] = new DateTime($singleValue, ($timezone ?: $this->timezone));
- } catch (Exception $e) {
- // pass
- }
- }
- if (count($values) === 1) {
- $value = $values[0];
- } else {
- $value = $values;
- }
- }
-
- if ($key === 'RRULE' && preg_match_all('#(?<key>[^=;]+)=(?<value>[^;]+)#', $value, $matches, PREG_SET_ORDER)) {
- $middle = null;
- $value = [];
- foreach ($matches as $match) {
- if (in_array($match['key'], ['UNTIL'])) {
- try {
- $value[$match['key']] = new DateTime($match['value'], ($timezone ?: $this->timezone));
- } catch (Exception $e) {
- $value[$match['key']] = $match['value'];
- }
- } else {
- $value[$match['key']] = $match['value'];
- }
- }
- }
-
- //implement 4.3.11 Text ESCAPED-CHAR
- $text_properties = [
- 'CALSCALE', 'METHOD', 'PRODID', 'VERSION', 'CATEGORIES', 'CLASS', 'COMMENT', 'DESCRIPTION',
- 'LOCATION', 'RESOURCES', 'STATUS', 'SUMMARY', 'TRANSP', 'TZID', 'TZNAME', 'CONTACT',
- 'RELATED-TO', 'UID', 'ACTION', 'REQUEST-STATUS', 'URL',
- ];
- if (in_array($key, $text_properties, true) || str_starts_with($key, 'X-')) {
- if (is_array($value)) {
- foreach ($value as &$var) {
- $var = strtr($var, ['\\\\' => '\\', '\\N' => "\n", '\\n' => "\n", '\\;' => ';', '\\,' => ',']);
- }
- } else {
- $value = strtr($value, ['\\\\' => '\\', '\\N' => "\n", '\\n' => "\n", '\\;' => ';', '\\,' => ',']);
- }
- }
-
- if (in_array($key, ['ATTENDEE', 'ORGANIZER'])) {
- $value = array_merge(is_array($middle) ? $middle : ['middle' => $middle], ['VALUE' => $value]);
- }
-
- return [$key, $middle, $value];
- }
-
- /**
- * Process timezone and return correct one...
- *
- * @param string $zone
- * @return mixed|null
- */
- private function toTimezone(string $zone): mixed {
- return $this->windowsTimezones[$zone] ?? $zone;
- }
-
- public function isMultipleKey(string $key): ?string {
- return (['ATTACH' => 'ATTACHMENTS', 'EXDATE' => 'EXDATES', 'RDATE' => 'RDATES', 'ATTENDEE' => 'ATTENDEES'])[$key] ?? null;
- }
-
- /**
- * @param $key
- * @return string|null
- */
- public function isMultipleKeyWithCommaSeparation($key): ?string {
- return (['X-CATEGORIES' => 'X-CATEGORIES', 'CATEGORIES' => 'CATEGORIES'])[$key] ?? null;
- }
-
- public function getAlarms(): array {
- return $this->data['VALARM'] ?? [];
- }
-
- public function getTimezone(): array {
- return $this->getTimezones();
- }
-
- public function getTimezones(): array {
- return $this->data['VTIMEZONE'] ?? [];
- }
-
- /**
- * Return sorted event list as ArrayObject
- *
- * @deprecated use IcalParser::getEvents()->sorted() instead
- */
- public function getSortedEvents(): ArrayObject {
- return $this->getEvents()->sorted();
- }
-
- public function getEvents(): EventsList {
- $events = new EventsList();
- if (isset($this->data['VEVENT'])) {
- foreach ($this->data['VEVENT'] as $iValue) {
- $event = $iValue;
-
- if (empty($event['RECURRENCES'])) {
- if (!empty($event['RECURRENCE-ID']) && !empty($event['UID']) && isset($event['SEQUENCE'])) {
- $modifiedEventUID = $event['UID'];
- $modifiedEventRecurID = $event['RECURRENCE-ID'];
- $modifiedEventSeq = (int) $event['SEQUENCE'];
-
- if (isset($this->data['_RECURRENCE_COUNTERS_BY_UID'][$modifiedEventUID])) {
- $counter = $this->data['_RECURRENCE_COUNTERS_BY_UID'][$modifiedEventUID];
-
- $originalEvent = $this->data['VEVENT'][$counter];
- if (isset($originalEvent['SEQUENCE'])) {
- $originalEventSeq = (int) $originalEvent['SEQUENCE'];
- $originalEventFormattedStartDate = $originalEvent['DTSTART']->format('Ymd\THis');
- if ($modifiedEventRecurID === $originalEventFormattedStartDate && $modifiedEventSeq > $originalEventSeq) {
- // this modifies the original event
- $modifiedEvent = array_replace_recursive($originalEvent, $event);
- $this->data['VEVENT'][$counter] = $modifiedEvent;
- foreach ($events as $z => $event) {
- if ($events[$z]['UID'] === $originalEvent['UID'] &&
- $events[$z]['SEQUENCE'] === $originalEvent['SEQUENCE']) {
- // replace the original event with the modified event
- $events[$z] = $modifiedEvent;
- break;
- }
- }
- $event = null; // don't add this to the $events[] array again
- } elseif (!empty($originalEvent['RECURRENCES'])) {
- for ($j = 0; $j < count($originalEvent['RECURRENCES']); $j++) {
- $recurDate = $originalEvent['RECURRENCES'][$j];
- $formattedStartDate = $recurDate->format('Ymd\THis');
- if ($formattedStartDate === $modifiedEventRecurID) {
- unset($this->data['VEVENT'][$counter]['RECURRENCES'][$j]);
- $this->data['VEVENT'][$counter]['RECURRENCES'] = array_values($this->data['VEVENT'][$counter]['RECURRENCES']);
- break;
- }
- }
- }
- }
- }
- }
-
- if (!empty($event)) {
- $events->append($event);
- }
- } else {
- $recurrences = $event['RECURRENCES'];
- $event['RECURRING'] = true;
- $event['DTEND'] = !empty($event['DTEND']) ? $event['DTEND'] : $event['DTSTART'];
- $eventInterval = $event['DTSTART']->diff($event['DTEND']);
-
- $firstEvent = true;
- foreach ($recurrences as $j => $recurDate) {
- $newEvent = $event;
- if (!$firstEvent) {
- unset($newEvent['RECURRENCES']);
- $newEvent['DTSTART'] = $recurDate;
- $newEvent['DTEND'] = clone($recurDate);
- $newEvent['DTEND']->add($eventInterval);
- }
-
- $newEvent['RECURRENCE_INSTANCE'] = $j;
- $events->append($newEvent);
- $firstEvent = false;
- }
- }
- }
- }
- return $events;
- }
-
- /**
- * @return \ArrayObject
- * @deprecated use IcalParser::getEvents->reversed();
- */
- public function getReverseSortedEvents(): ArrayObject {
- return $this->getEvents()->reversed();
- }
-
-}
diff --git a/includes/composer/vendor/om/icalparser/src/Recurrence.php b/includes/composer/vendor/om/icalparser/src/Recurrence.php
deleted file mode 100644
index 7010257..0000000
--- a/includes/composer/vendor/om/icalparser/src/Recurrence.php
+++ /dev/null
@@ -1,234 +0,0 @@
-<?php
-
-namespace om;
-
-use DateTime;
-use Exception;
-
-/**
- * Class taken from https://github.com/coopTilleuls/intouch-iCalendar.git (Recurrence.php)
- *
- * A wrapper for recurrence rules in iCalendar. Parses the given line and puts the
- * recurrence rules in the correct field of this object.
- *
- * See http://tools.ietf.org/html/rfc2445 for more information. Page 39 and onward contains more
- * information on the recurrence rules themselves. Page 116 and onward contains
- * some great examples which were often used for testing.
- *
- * @author Steven Oxley
- * @author Michael Kahn (C) 2013
- * @license http://creativecommons.org/licenses/by-sa/2.5/dk/deed.en_GB CC-BY-SA-DK
- */
-class Recurrence {
-
- public array $rrule;
- protected mixed $freq;
- protected mixed $until;
- protected mixed $count;
- protected mixed $interval;
- protected mixed $bysecond;
- protected mixed $byminute;
- protected mixed $byhour;
- protected mixed $byday;
- protected mixed $bymonthday;
- protected mixed $byyearday;
- protected mixed $byweekno;
- protected mixed $bymonth;
- protected mixed $bysetpos;
- protected mixed $wkst;
- /**
- * A list of the properties that can have comma-separated lists for values.
- *
- * @var array
- */
- protected array $listProperties = [
- 'bysecond', 'byminute', 'byhour', 'byday', 'bymonthday',
- 'byyearday', 'byweekno', 'bymonth', 'bysetpos',
- ];
-
- /**
- * Creates a recurrence object with a passed in line. Parses the line.
- *
- * @param array $rrule an om\icalparser row array which will be parsed to get the
- * desired information.
- */
- public function __construct(array $rrule) {
- $this->parseRrule($rrule);
- }
-
- /**
- * Parses an 'RRULE' array and sets the member variables of this object.
- * Expects a string that looks like this: 'FREQ=WEEKLY;INTERVAL=2;BYDAY=SU,TU,WE'
- *
- * @param array $rrule
- */
- protected function parseRrule(array $rrule): void {
- $this->rrule = $rrule;
- //loop through the properties in the line and set their associated
- //member variables
- foreach ($this->rrule as $propertyName => $propertyValue) {
- //need the lower-case name for setting the member variable
- $propertyName = strtolower($propertyName);
- //split up the list of values into an array (if it's a list)
- if (in_array($propertyName, $this->listProperties, true)) {
- $propertyValue = explode(',', $propertyValue);
- }
- $this->$propertyName = $propertyValue;
- }
- }
-
- /**
- * Returns the frequency - corresponds to FREQ in RFC 2445.
- *
- * @return mixed string if the member has been set, false otherwise
- */
- public function getFreq(): mixed {
- return $this->getMember('freq');
- }
-
- /**
- * Retrieves the desired member variable and returns it (if it's set)
- *
- * @param string $member name of the member variable
- * @return mixed the variable value (if set), false otherwise
- */
- protected function getMember(string $member): mixed {
- return $this->$member ?? false;
- }
-
- /**
- * Returns when the event will go until - corresponds to UNTIL in RFC 2445.
- *
- * @return mixed string if the member has been set, false otherwise
- */
- public function getUntil(): mixed {
- return $this->getMember('until');
- }
-
- /**
- * Set the $until member
- *
- * @param mixed $ts timestamp (int) / Valid DateTime format (string)
- * @throws Exception
- */
- public function setUntil(mixed $ts): void {
- if ($ts instanceof DateTime) {
- $dt = $ts;
- } elseif (is_int($ts)) {
- $dt = new DateTime('@' . $ts);
- } else {
- $dt = new DateTime($ts);
- }
- $this->until = $dt->format('Ymd\THisO');
- $this->rrule['until'] = $this->until;
- }
-
- /**
- * Returns the count of the times the event will occur (should only appear if 'until'
- * does not appear) - corresponds to COUNT in RFC 2445.
- *
- * @return mixed string if the member has been set, false otherwise
- */
- public function getCount(): mixed {
- return $this->getMember('count');
- }
-
- /**
- * Returns the interval - corresponds to INTERVAL in RFC 2445.
- *
- * @return mixed string if the member has been set, false otherwise
- */
- public function getInterval(): mixed {
- return $this->getMember('interval');
- }
-
- /**
- * Returns the bysecond part of the event - corresponds to BYSECOND in RFC 2445.
- *
- * @return mixed string if the member has been set, false otherwise
- */
- public function getBySecond(): mixed {
- return $this->getMember('bysecond');
- }
-
- /**
- * Returns the byminute information for the event - corresponds to BYMINUTE in RFC 2445.
- *
- * @return mixed string if the member has been set, false otherwise
- */
- public function getByMinute(): mixed {
- return $this->getMember('byminute');
- }
-
- /**
- * Corresponds to BYHOUR in RFC 2445.
- *
- * @return mixed string if the member has been set, false otherwise
- */
- public function getByHour(): mixed {
- return $this->getMember('byhour');
- }
-
- /**
- *Corresponds to BYDAY in RFC 2445.
- *
- * @return mixed string if the member has been set, false otherwise
- */
- public function getByDay(): mixed {
- return $this->getMember('byday');
- }
-
- /**
- * Corresponds to BYMONTHDAY in RFC 2445.
- *
- * @return mixed string if the member has been set, false otherwise
- */
- public function getByMonthDay(): mixed {
- return $this->getMember('bymonthday');
- }
-
- /**
- * Corresponds to BYYEARDAY in RFC 2445.
- *
- * @return mixed string if the member has been set, false otherwise
- */
- public function getByYearDay(): mixed {
- return $this->getMember('byyearday');
- }
-
- /**
- * Corresponds to BYWEEKNO in RFC 2445.
- *
- * @return mixed string if the member has been set, false otherwise
- */
- public function getByWeekNo(): mixed {
- return $this->getMember('byweekno');
- }
-
- /**
- * Corresponds to BYMONTH in RFC 2445.
- *
- * @return mixed string if the member has been set, false otherwise
- */
- public function getByMonth(): mixed {
- return $this->getMember('bymonth');
- }
-
- /**
- * Corresponds to BYSETPOS in RFC 2445.
- *
- * @return mixed string if the member has been set, false otherwise
- */
- public function getBySetPos(): mixed {
- return $this->getMember('bysetpos');
- }
-
- /**
- * Corresponds to WKST in RFC 2445.
- *
- * @return mixed string if the member has been set, false otherwise
- */
- public function getWkst(): mixed {
- return $this->getMember('wkst');
- }
-}
diff --git a/includes/composer/vendor/om/icalparser/src/WindowsTimezones.php b/includes/composer/vendor/om/icalparser/src/WindowsTimezones.php
deleted file mode 100644
index 9bfa391..0000000
--- a/includes/composer/vendor/om/icalparser/src/WindowsTimezones.php
+++ /dev/null
@@ -1,214 +0,0 @@
-<?php
-
-/**
- * List of Windows Timezones
- */
-return [
- 'Dateline Standard Time' => 'Etc/GMT+12',
- '(UTC-12:00) International Date Line West' => 'Etc/GMT+12',
- 'UTC-11' => 'Etc/GMT+11',
- '(UTC-11:00) Coordinated Universal Time -11' => 'Etc/GMT+11',
- 'Hawaiian Standard Time' => 'Pacific/Honolulu',
- '(UTC-10:00) Hawaii' => 'Pacific/Honolulu',
- 'Alaskan Standard Time' => 'America/Anchorage',
- '(UTC-09:00) Alaska' => 'America/Anchorage',
- 'Pacific Standard Time (Mexico)' => 'America/Santa_Isabel',
- '(UTC-08:00) Baja California' => 'America/Santa_Isabel',
- 'Pacific Standard Time' => 'America/Los_Angeles',
- 'Pacific Time' => 'America/Los_Angeles',
- '(UTC-08:00) Pacific Time (US and Canada)' => 'America/Los_Angeles',
- '(UTC-08:00) Pacific Time (US & Canada)' => 'America/Los_Angeles',
- 'US Mountain Standard Time' => 'America/Phoenix',
- '(UTC-07:00) Arizona' => 'America/Phoenix',
- 'Mountain Standard Time (Mexico)' => 'America/Chihuahua',
- '(UTC-07:00) Chihuahua, La Paz, Mazatlan' => 'America/Chihuahua',
- 'Mountain Standard Time' => 'America/Denver',
- 'Mountain Time' => 'America/Denver',
- '(UTC-07:00) Mountain Time (US and Canada)' => 'America/Denver',
- '(UTC-07:00) Mountain Time (US & Canada)' => 'America/Denver',
- 'Central America Standard Time' => 'America/Guatemala',
- '(UTC-06:00) Central America' => 'America/Guatemala',
- 'Central Standard Time' => 'America/Chicago',
- 'Central Time' => 'America/Chicago',
- '(UTC-06:00) Central Time (US and Canada)' => 'America/Chicago',
- '(UTC-06:00) Central Time (US & Canada)' => 'America/Chicago',
- 'Central Standard Time (Mexico)' => 'America/Mexico_City',
- '(UTC-06:00) Guadalajara, Mexico City, Monterrey' => 'America/Mexico_City',
- 'Canada Central Standard Time' => 'America/Regina',
- '(UTC-06:00) Saskatchewan' => 'America/Regina',
- 'SA Pacific Standard Time' => 'America/Bogota',
- '(UTC-05:00) Bogota, Lima, Quito' => 'America/Bogota',
- 'Eastern Standard Time' => 'America/New_York',
- 'Eastern Time' => 'America/New_York',
- '(UTC-05:00) Eastern Time (US and Canada)' => 'America/New_York',
- '(UTC-05:00) Eastern Time (US & Canada)' => 'America/New_York',
- 'US Eastern Standard Time' => 'America/Indianapolis',
- '(UTC-05:00) Indiana (East)' => 'America/Indianapolis',
- 'Venezuela Standard Time' => 'America/Caracas',
- '(UTC-04:30) Caracas' => 'America/Caracas',
- 'Paraguay Standard Time' => 'America/Asuncion',
- '(UTC-04:00) Asuncion' => 'America/Asuncion',
- 'Atlantic Standard Time' => 'America/Halifax',
- '(UTC-04:00) Atlantic Time (Canada)' => 'America/Halifax',
- 'Central Brazilian Standard Time' => 'America/Cuiaba',
- '(UTC-04:00) Cuiaba' => 'America/Cuiaba',
- 'SA Western Standard Time' => 'America/La_Paz',
- '(UTC-04:00) Georgetown, La Paz, Manaus, San Juan' => 'America/La_Paz',
- 'Pacific SA Standard Time' => 'America/Santiago',
- '(UTC-04:00) Santiago' => 'America/Santiago',
- 'Newfoundland Standard Time' => 'America/St_Johns',
- '(UTC-03:30) Newfoundland' => 'America/St_Johns',
- 'E. South America Standard Time' => 'America/Sao_Paulo',
- '(UTC-03:00) Brasilia' => 'America/Sao_Paulo',
- 'Argentina Standard Time' => 'America/Buenos_Aires',
- '(UTC-03:00) Buenos Aires' => 'America/Buenos_Aires',
- 'SA Eastern Standard Time' => 'America/Cayenne',
- '(UTC-03:00) Cayenne, Fortaleza' => 'America/Cayenne',
- 'Greenland Standard Time' => 'America/Godthab',
- '(UTC-03:00) Greenland' => 'America/Godthab',
- 'Montevideo Standard Time' => 'America/Montevideo',
- '(UTC-03:00) Montevideo' => 'America/Montevideo',
- 'Bahia Standard Time' => 'America/Bahia',
- 'UTC-02' => 'Etc/GMT+2',
- '(UTC-02:00) Coordinated Universal Time -02' => 'Etc/GMT+2',
- 'Azores Standard Time' => 'Atlantic/Azores',
- '(UTC-01:00) Azores' => 'Atlantic/Azores',
- 'Cape Verde Standard Time' => 'Atlantic/Cape_Verde',
- '(UTC-01:00) Cabo Verde Is.' => 'Atlantic/Cape_Verde',
- 'Morocco Standard Time' => 'Africa/Casablanca',
- '(UTC) Casablanca' => 'Africa/Casablanca',
- 'UTC' => 'Etc/GMT',
- 'Microsoft/Utc' => 'Etc/GMT',
- 'GMT Standard Time' => 'Europe/London',
- '(UTC) Dublin, Edinburgh, Lisbon, London' => 'Europe/London',
- 'Greenwich Standard Time' => 'Atlantic/Reykjavik',
- '(UTC) Monrovia, Reykjavik' => 'Atlantic/Reykjavik',
- 'W. Europe Standard Time' => 'Europe/Berlin',
- '(UTC+01:00) Amsterdam, Berlin, Bern, Rome, Stockholm, Vienna' => 'Europe/Berlin',
- '(UTC+01:00) Amsterdam\, Berlin\, Bern\, Rome\, Stockholm\, Vienna' => 'Europe/Berlin',
- '(UTC+01:00) Amsterdam\, Berlin\, Bern\, Rom\, Stockholm\, Wien' => 'Europe/Berlin',
- 'Central Europe Standard Time' => 'Europe/Budapest',
- '(UTC+01:00) Belgrade, Bratislava, Budapest, Ljubljana, Prague' => 'Europe/Budapest',
- 'Romance Standard Time' => 'Europe/Paris',
- '(UTC+01:00) Brussels, Copenhagen, Madrid, Paris' => 'Europe/Paris',
- 'Central European Standard Time' => 'Europe/Warsaw',
- '(UTC+01:00) Sarajevo, Skopje, Warsaw, Zagreb' => 'Europe/Warsaw',
- 'W. Central Africa Standard Time' => 'Africa/Lagos',
- '(UTC+01:00) West Central Africa' => 'Africa/Lagos',
- 'Namibia Standard Time' => 'Africa/Windhoek',
- '(UTC+01:00) Windhoek' => 'Africa/Windhoek',
- 'GTB Standard Time' => 'Europe/Bucharest',
- '(UTC+02:00) Athens, Bucharest' => 'Europe/Bucharest',
- 'Middle East Standard Time' => 'Asia/Beirut',
- '(UTC+02:00) Beirut' => 'Asia/Beirut',
- 'Egypt Standard Time' => 'Africa/Cairo',
- '(UTC+02:00) Cairo' => 'Africa/Cairo',
- 'Syria Standard Time' => 'Asia/Damascus',
- '(UTC+02:00) Damascus' => 'Asia/Damascus',
- 'South Africa Standard Time' => 'Africa/Johannesburg',
- '(UTC+02:00) Harare, Pretoria' => 'Africa/Johannesburg',
- 'FLE Standard Time' => 'Europe/Kiev',
- '(UTC+02:00) Helsinki, Kyiv, Riga, Sofia, Tallinn, Vilnius' => 'Europe/Kiev',
- 'Turkey Standard Time' => 'Europe/Istanbul',
- '(UTC+02:00) Istanbul' => 'Europe/Istanbul',
- 'Israel Standard Time' => 'Asia/Jerusalem',
- '(UTC+02:00) Jerusalem' => 'Asia/Jerusalem',
- 'Libya Standard Time' => 'Africa/Tripoli',
- 'Jordan Standard Time' => 'Asia/Amman',
- '(UTC+02:00) Amman' => 'Asia/Amman',
- 'Arabic Standard Time' => 'Asia/Baghdad',
- '(UTC+03:00) Baghdad' => 'Asia/Baghdad',
- 'Kaliningrad Standard Time' => 'Europe/Kaliningrad',
- '(UTC+03:00) Kaliningrad' => 'Europe/Kaliningrad',
- 'Arab Standard Time' => 'Asia/Riyadh',
- '(UTC+03:00) Kuwait, Riyadh' => 'Asia/Riyadh',
- 'E. Africa Standard Time' => 'Africa/Nairobi',
- '(UTC+03:00) Nairobi' => 'Africa/Nairobi',
- 'Iran Standard Time' => 'Asia/Tehran',
- '(UTC+03:30) Tehran' => 'Asia/Tehran',
- 'Arabian Standard Time' => 'Asia/Dubai',
- '(UTC+04:00) Abu Dhabi, Muscat' => 'Asia/Dubai',
- 'Azerbaijan Standard Time' => 'Asia/Baku',
- '(UTC+04:00) Baku' => 'Asia/Baku',
- 'Russian Standard Time' => 'Europe/Moscow',
- '(UTC+04:00) Moscow, St. Petersburg, Volgograd' => 'Europe/Moscow',
- 'Mauritius Standard Time' => 'Indian/Mauritius',
- '(UTC+04:00) Port Louis' => 'Indian/Mauritius',
- 'Georgian Standard Time' => 'Asia/Tbilisi',
- '(UTC+04:00) Tbilisi' => 'Asia/Tbilisi',
- 'Caucasus Standard Time' => 'Asia/Yerevan',
- '(UTC+04:00) Yerevan' => 'Asia/Yerevan',
- 'Afghanistan Standard Time' => 'Asia/Kabul',
- '(UTC+04:30) Kabul' => 'Asia/Kabul',
- 'West Asia Standard Time' => 'Asia/Tashkent',
- '(UTC+05:00) Tashkent' => 'Asia/Tashkent',
- 'Pakistan Standard Time' => 'Asia/Karachi',
- '(UTC+05:00) Islamabad, Karachi' => 'Asia/Karachi',
- 'India Standard Time' => 'Asia/Calcutta',
- '(UTC+05:30) Chennai, Kolkata, Mumbai, New Delhi' => 'Asia/Calcutta',
- 'Sri Lanka Standard Time' => 'Asia/Colombo',
- '(UTC+05:30) Sri Jayawardenepura' => 'Asia/Colombo',
- 'Nepal Standard Time' => 'Asia/Katmandu',
- '(UTC+05:45) Kathmandu' => 'Asia/Katmandu',
- 'Central Asia Standard Time' => 'Asia/Almaty',
- '(UTC+06:00) Astana' => 'Asia/Almaty',
- 'Bangladesh Standard Time' => 'Asia/Dhaka',
- '(UTC+06:00) Dhaka' => 'Asia/Dhaka',
- 'Ekaterinburg Standard Time' => 'Asia/Yekaterinburg',
- '(UTC+06:00) Ekaterinburg' => 'Asia/Yekaterinburg',
- 'Myanmar Standard Time' => 'Asia/Rangoon',
- '(UTC+06:30) Yangon (Rangoon)' => 'Asia/Rangoon',
- 'SE Asia Standard Time' => 'Asia/Bangkok',
- '(UTC+07:00) Bangkok, Hanoi, Jakarta' => 'Asia/Bangkok',
- 'N. Central Asia Standard Time' => 'Asia/Novosibirsk',
- '(UTC+07:00) Novosibirsk' => 'Asia/Novosibirsk',
- 'China Standard Time' => 'Asia/Shanghai',
- '(UTC+08:00) Beijing, Chongqing, Hong Kong, Urumqi' => 'Asia/Shanghai',
- 'North Asia Standard Time' => 'Asia/Krasnoyarsk',
- '(UTC+08:00) Krasnoyarsk' => 'Asia/Krasnoyarsk',
- 'Singapore Standard Time' => 'Asia/Singapore',
- '(UTC+08:00) Kuala Lumpur, Singapore' => 'Asia/Singapore',
- 'W. Australia Standard Time' => 'Australia/Perth',
- '(UTC+08:00) Perth' => 'Australia/Perth',
- 'Taipei Standard Time' => 'Asia/Taipei',
- '(UTC+08:00) Taipei' => 'Asia/Taipei',
- 'Ulaanbaatar Standard Time' => 'Asia/Ulaanbaatar',
- '(UTC+08:00) Ulaanbaatar' => 'Asia/Ulaanbaatar',
- 'North Asia East Standard Time' => 'Asia/Irkutsk',
- '(UTC+09:00) Irkutsk' => 'Asia/Irkutsk',
- 'Tokyo Standard Time' => 'Asia/Tokyo',
- '(UTC+09:00) Osaka, Sapporo, Tokyo' => 'Asia/Tokyo',
- 'Korea Standard Time' => 'Asia/Seoul',
- '(UTC+09:00) Seoul' => 'Asia/Seoul',
- 'Cen. Australia Standard Time' => 'Australia/Adelaide',
- '(UTC+09:30) Adelaide' => 'Australia/Adelaide',
- 'AUS Central Standard Time' => 'Australia/Darwin',
- '(UTC+09:30) Darwin' => 'Australia/Darwin',
- 'E. Australia Standard Time' => 'Australia/Brisbane',
- '(UTC+10:00) Brisbane' => 'Australia/Brisbane',
- 'AUS Eastern Standard Time' => 'Australia/Sydney',
- '(UTC+10:00) Canberra, Melbourne, Sydney' => 'Australia/Sydney',
- 'West Pacific Standard Time' => 'Pacific/Port_Moresby',
- '(UTC+10:00) Guam, Port Moresby' => 'Pacific/Port_Moresby',
- 'Tasmania Standard Time' => 'Australia/Hobart',
- '(UTC+10:00) Hobart' => 'Australia/Hobart',
- 'Yakutsk Standard Time' => 'Asia/Yakutsk',
- '(UTC+10:00) Yakutsk' => 'Asia/Yakutsk',
- 'Central Pacific Standard Time' => 'Pacific/Guadalcanal',
- '(UTC+11:00) Solomon Is., New Caledonia' => 'Pacific/Guadalcanal',
- 'Vladivostok Standard Time' => 'Asia/Vladivostok',
- '(UTC+11:00) Vladivostok' => 'Asia/Vladivostok',
- 'New Zealand Standard Time' => 'Pacific/Auckland',
- '(UTC+12:00) Auckland, Wellington' => 'Pacific/Auckland',
- 'UTC+12' => 'Etc/GMT-12',
- '(UTC+12:00) Coordinated Universal Time +12' => 'Etc/GMT-12',
- 'Fiji Standard Time' => 'Pacific/Fiji',
- '(UTC+12:00) Fiji' => 'Pacific/Fiji',
- 'Magadan Standard Time' => 'Asia/Magadan',
- '(UTC+12:00) Magadan' => 'Asia/Magadan',
- 'Tonga Standard Time' => 'Pacific/Tongatapu',
- '(UTC+13:00) Nuku\'alofa' => 'Pacific/Tongatapu',
- 'Samoa Standard Time' => 'Pacific/Apia',
- '(UTC-11:00)Samoa' => 'Pacific/Apia',
- 'W. Europe Standard Time 1' => 'Europe/Berlin',
-];
diff --git a/includes/composer/vendor/om/icalparser/tests/bootstrap.php b/includes/composer/vendor/om/icalparser/tests/bootstrap.php
deleted file mode 100644
index 7e6b798..0000000
--- a/includes/composer/vendor/om/icalparser/tests/bootstrap.php
+++ /dev/null
@@ -1,21 +0,0 @@
-<?php
-
-namespace tests;
-
-/**
- * Copyright (c) 2004-2022 Roman Ožana (https://ozana.cz)
- *
- * @license BSD-3-Clause
- * @author Roman Ožana <roman@ozana.cz>
- */
-
-require_once __DIR__ . '/../vendor/autoload.php';
-
-use Closure;
-use Tester\Environment;
-
-function test($description, Closure $fn): void {
- printf("• %s%s%s", $description, PHP_EOL, $fn());
-}
-
-Environment::setup();
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/38_weekly_recurring_event_missing_day.ics b/includes/composer/vendor/om/icalparser/tests/cal/38_weekly_recurring_event_missing_day.ics
deleted file mode 100644
index 26326c3..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/38_weekly_recurring_event_missing_day.ics
+++ /dev/null
@@ -1,59 +0,0 @@
-BEGIN:VCALENDAR
-PRODID:-//Google Inc//Google Calendar 70.9054//EN
-VERSION:2.0
-CALSCALE:GREGORIAN
-METHOD:PUBLISH
-X-WR-CALNAME:Office Opening Hours
-X-WR-TIMEZONE:Europe/London
-BEGIN:VTIMEZONE
-TZID:Europe/London
-X-LIC-LOCATION:Europe/London
-BEGIN:DAYLIGHT
-TZOFFSETFROM:+0000
-TZOFFSETTO:+0100
-TZNAME:BST
-DTSTART:19700329T010000
-RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=-1SU
-END:DAYLIGHT
-BEGIN:STANDARD
-TZOFFSETFROM:+0100
-TZOFFSETTO:+0000
-TZNAME:GMT
-DTSTART:19701025T020000
-RRULE:FREQ=YEARLY;BYMONTH=10;BYDAY=-1SU
-END:STANDARD
-END:VTIMEZONE
-BEGIN:VEVENT
-DTSTART;TZID=Europe/London:20190401T090000
-DTEND;TZID=Europe/London:20190401T170000
-RRULE:FREQ=WEEKLY;WKST=SU;BYDAY=MO,TU,WE,TH,FR
-DTSTAMP:20190402T174536Z
-UID:1nibcosj8r05bjoia671im7ulg@google.com
-CREATED:20190401T144832Z
-DESCRIPTION:
-LAST-MODIFIED:20190401T145024Z
-LOCATION:
-SEQUENCE:0
-STATUS:CONFIRMED
-SUMMARY:Office Opening Hours
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;TZID=Europe/London:20190225T090000
-DTEND;TZID=Europe/London:20190225T170000
-RRULE:FREQ=WEEKLY;WKST=SU;UNTIL=20190329T235959Z;BYDAY=MO,TU,WE,TH,FR
-DTSTAMP:20190402T174536Z
-UID:7e581hcu1ub3nm0bb6c4o29suj@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;CN=Office
- Opening Hours;X-NUM-GUESTS=0:mailto:poweredpasture.com_la2jmsbphe5h11351kk
- scnnqtg@group.calendar.google.com
-CREATED:20190227T164630Z
-DESCRIPTION:
-LAST-MODIFIED:20190401T144725Z
-LOCATION:
-SEQUENCE:0
-STATUS:CONFIRMED
-SUMMARY:Office Opening Hours
-TRANSP:OPAQUE
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/FrenchHolidays.ics b/includes/composer/vendor/om/icalparser/tests/cal/FrenchHolidays.ics
deleted file mode 100644
index efb0143..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/FrenchHolidays.ics
+++ /dev/null
@@ -1,382 +0,0 @@
-BEGIN:VCALENDAR
-VERSION:2.0
-PRODID:-//Mozilla.org/NONSGML Mozilla Calendar V1.1//EN
-BEGIN:VTIMEZONE
-TZID:/mozilla.org/20070129_1/Europe/Paris
-X-LIC-LOCATION:Europe/Paris
-BEGIN:DAYLIGHT
-TZOFFSETFROM:+0100
-TZOFFSETTO:+0200
-TZNAME:CEST
-DTSTART:19700329T020000
-RRULE:FREQ=YEARLY;INTERVAL=1;BYDAY=-1SU;BYMONTH=3
-END:DAYLIGHT
-BEGIN:STANDARD
-TZOFFSETFROM:+0200
-TZOFFSETTO:+0100
-TZNAME:CET
-DTSTART:19701025T030000
-RRULE:FREQ=YEARLY;INTERVAL=1;BYDAY=-1SU;BYMONTH=10
-END:STANDARD
-END:VTIMEZONE
-BEGIN:VEVENT
-CREATED:20070606T141629Z
-LAST-MODIFIED:20070606T154611Z
-DTSTAMP:20070607T120859Z
-UID:5d1ae55f-3910-4de9-8b65-d652768fb2f2
-SUMMARY:Lundi de Pâques
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20070409
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20070410
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070606T161310Z
-LAST-MODIFIED:20070606T161327Z
-DTSTAMP:20070607T120859Z
-UID:9e19b119-f077-4ae9-934e-cb62322ca81f
-SUMMARY:Ascension
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20080501
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20080502
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070605T163903Z
-LAST-MODIFIED:20070606T161656Z
-DTSTAMP:20070607T120859Z
-UID:c6a930d6-4ed5-45d8-bb3d-d3587a32b8aa
-SUMMARY:Jour de l'an
-CLASS:PUBLIC
-RRULE:FREQ=YEARLY;INTERVAL=1
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20070101
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20070102
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070606T141739Z
-LAST-MODIFIED:20070606T161721Z
-DTSTAMP:20070607T120859Z
-UID:f439c81b-fd09-4b40-a629-3a9663dd29ff
-SUMMARY:Fête du Travail
-CLASS:PUBLIC
-RRULE:FREQ=YEARLY;INTERVAL=1
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20070501
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20070502
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070606T141853Z
-LAST-MODIFIED:20070606T161731Z
-DTSTAMP:20070607T120859Z
-UID:b1c0e1ed-a09f-4fc2-aab1-170d3f661f13
-SUMMARY:Armistice 1945
-RRULE:FREQ=YEARLY;INTERVAL=1
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20070508
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20070509
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070606T141932Z
-LAST-MODIFIED:20070606T161741Z
-DTSTAMP:20070607T120859Z
-UID:5468e1a0-9dda-4fd2-88c0-dc3e727c1183
-SUMMARY:Ascension
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20070517
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20070518
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070606T154927Z
-LAST-MODIFIED:20070606T161748Z
-DTSTAMP:20070607T120859Z
-UID:67a89bb6-9ad4-461b-951c-c4c8482d8618
-SUMMARY:Lundi de Pentecôte
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20070528
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20070529
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070606T142033Z
-LAST-MODIFIED:20070606T161758Z
-DTSTAMP:20070607T120859Z
-UID:00eb3adc-c059-47c8-a1c0-4ca7048051b9
-SUMMARY:Fête Nationale
-RRULE:FREQ=YEARLY;INTERVAL=1
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20070714
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20070715
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070606T142112Z
-LAST-MODIFIED:20070606T162012Z
-DTSTAMP:20070607T120859Z
-UID:854e5499-9276-4a96-9be3-bcbaa7caafcf
-SUMMARY:Assomption
-RRULE:FREQ=YEARLY;INTERVAL=1
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20070815
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20070816
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070606T142147Z
-LAST-MODIFIED:20070606T162034Z
-DTSTAMP:20070607T120859Z
-UID:725c8c16-c37a-49f0-9d2e-dc976d6c3ea5
-SUMMARY:Toussaint
-RRULE:FREQ=YEARLY;INTERVAL=1
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20071101
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20071102
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070606T142211Z
-LAST-MODIFIED:20070606T162044Z
-DTSTAMP:20070607T120859Z
-UID:5218f724-6b66-434d-a8c5-138dfed64e07
-SUMMARY:Armistice 1918
-RRULE:FREQ=YEARLY;INTERVAL=1
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20071111
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20071112
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070606T142243Z
-LAST-MODIFIED:20070606T162054Z
-DTSTAMP:20070607T120859Z
-UID:18617cde-2d15-46c6-900f-b3341a7b7f98
-SUMMARY:Noël
-RRULE:FREQ=YEARLY;INTERVAL=1
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20071225
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20071226
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070606T150648Z
-LAST-MODIFIED:20070606T162128Z
-DTSTAMP:20070607T120859Z
-UID:19d50a52-f5a9-4d70-8fd7-a2caa97f6959
-SUMMARY:Lundi de Pâques
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20080324
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20080325
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T105427Z
-LAST-MODIFIED:20070607T105450Z
-DTSTAMP:20070607T120859Z
-UID:18c90b99-edfa-4418-9bc7-992a07384967
-SUMMARY:Lundi de Pâques
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20090413
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20090414
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T105613Z
-LAST-MODIFIED:20070607T105630Z
-DTSTAMP:20070607T120859Z
-UID:b989d129-8f2f-42be-a027-183f6d81eb40
-SUMMARY:Ascension
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20090521
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20090522
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T105907Z
-LAST-MODIFIED:20070607T105928Z
-DTSTAMP:20070607T120859Z
-UID:7c6fe35c-44a5-450b-aea6-dd2baef78f06
-SUMMARY:Lundi de Pentecôte
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20090601
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20090602
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T110046Z
-LAST-MODIFIED:20070607T110100Z
-DTSTAMP:20070607T120859Z
-UID:98c1c381-8632-45ce-9b11-10757face7c4
-SUMMARY:Lundi de Pâques
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20100405
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20100406
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T110121Z
-LAST-MODIFIED:20070607T110135Z
-DTSTAMP:20070607T120859Z
-UID:aaeb1ba5-60f0-4e49-a25a-c0ff949acdd9
-SUMMARY:Ascension
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20100513
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20100514
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T110144Z
-LAST-MODIFIED:20070607T110201Z
-DTSTAMP:20070607T120859Z
-UID:1f68f978-969e-4791-a7e3-cb3011134a34
-SUMMARY:Lundi de Pentecôte
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20100524
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20100525
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T112820Z
-LAST-MODIFIED:20070607T112836Z
-DTSTAMP:20070607T120859Z
-UID:fa0d4b5b-8eeb-4b98-b35c-b6a547b96953
-SUMMARY:Ascension
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20110602
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20110603
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T112846Z
-LAST-MODIFIED:20070607T112906Z
-DTSTAMP:20070607T120859Z
-UID:5be6194a-9fbd-45da-8e3c-568cac66b997
-SUMMARY:Lundi de Pentecôte
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20110613
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20110614
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T112958Z
-LAST-MODIFIED:20070607T113016Z
-DTSTAMP:20070607T120859Z
-UID:4162d242-5468-4007-8814-10286b9589a0
-SUMMARY:Lundi de Pâques
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20120409
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20120410
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T113034Z
-LAST-MODIFIED:20070607T113048Z
-DTSTAMP:20070607T120859Z
-UID:6d368a35-6b6d-4ec1-9f48-97c53b25502e
-SUMMARY:Ascension
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20120517
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20120518
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T113055Z
-LAST-MODIFIED:20070607T113114Z
-DTSTAMP:20070607T120859Z
-UID:e8913a3d-3e84-447d-afb4-f0b082948449
-SUMMARY:Lundi de Pentecôte
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20120528
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20120529
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T113205Z
-LAST-MODIFIED:20070607T113229Z
-DTSTAMP:20070607T120859Z
-UID:ebc79872-a185-4641-bc22-1092d5139efb
-SUMMARY:Lundi de Pâques
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20130401
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20130402
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T113245Z
-LAST-MODIFIED:20070607T113257Z
-DTSTAMP:20070607T120859Z
-UID:9714bd39-429b-433c-ab5c-5fd6a67e658e
-SUMMARY:Ascension
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20130509
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20130510
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T113305Z
-LAST-MODIFIED:20070607T113325Z
-DTSTAMP:20070607T120859Z
-UID:79f5f02f-e92d-417f-9637-9e2a88840583
-SUMMARY:Lundi de Pentecôte
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20130520
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20130521
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T113408Z
-LAST-MODIFIED:20070607T113426Z
-DTSTAMP:20070607T120859Z
-UID:172dcce6-6f95-4c1f-ada9-e8bf2a7e8245
-SUMMARY:Lundi de Pâques
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20140421
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20140422
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T113439Z
-LAST-MODIFIED:20070607T113452Z
-DTSTAMP:20070607T120859Z
-UID:6625ed89-bf9f-478a-9796-c3dc203ab5e6
-SUMMARY:Ascension
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20140529
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20140530
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T113504Z
-LAST-MODIFIED:20070607T113523Z
-DTSTAMP:20070607T120859Z
-UID:7abad826-ab68-447f-81b2-1e04a4c2ef88
-SUMMARY:Lundi de Pentecôte
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20140609
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20140610
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T113606Z
-LAST-MODIFIED:20070607T113622Z
-DTSTAMP:20070607T120859Z
-UID:cf42813f-4a74-422b-aa19-90dcefccc92d
-SUMMARY:Lundi de Pâques
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20150406
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20150407
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T113643Z
-LAST-MODIFIED:20070607T113657Z
-DTSTAMP:20070607T120859Z
-UID:e7d30f2b-d546-4b7e-8780-0754a46e6970
-SUMMARY:Ascension
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20150514
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20150515
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T113706Z
-LAST-MODIFIED:20070607T113726Z
-DTSTAMP:20070607T120859Z
-UID:a8ccc771-4e8b-4594-ae30-33e9ce384ac9
-SUMMARY:Lundi de Pentecôte
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20150525
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20150526
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070606T162350Z
-LAST-MODIFIED:20070607T115133Z
-DTSTAMP:20070607T120859Z
-UID:419f1bff-a820-4d07-bf4e-1a6ec139e3df
-SUMMARY:Lundi de Pentecôte
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20080512
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20080513
-CATEGORIES:Jours fériés
-END:VEVENT
-BEGIN:VEVENT
-CREATED:20070607T112742Z
-LAST-MODIFIED:20070607T115439Z
-DTSTAMP:20070607T120859Z
-UID:570d9fe7-cdc9-4fdf-9794-909edf520383
-SUMMARY:Lundi de Pâques
-DTSTART;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20110425
-DTEND;VALUE=DATE;TZID=/mozilla.org/20070129_1/Europe/Paris:20110426
-CATEGORIES:Jours fériés
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/basic.ics b/includes/composer/vendor/om/icalparser/tests/cal/basic.ics
deleted file mode 100644
index 0c58974..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/basic.ics
+++ /dev/null
@@ -1,616 +0,0 @@
-BEGIN:VCALENDAR
-PRODID:-//Google Inc//Google Calendar 70.9054//EN
-VERSION:2.0
-CALSCALE:GREGORIAN
-METHOD:PUBLISH
-X-WR-TIMEZONE:UTC
-X-WR-CALDESC:České svátky
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20131224
-DTEND;VALUE=DATE:20131225
-DTSTAMP:20140202T201100Z
-UID:h@9bae7e86083abdfdff45712c19ef81bc41f44111@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Štedrý den
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20141224
-DTEND;VALUE=DATE:20141225
-DTSTAMP:20140202T201100Z
-UID:h@26c4829203feb7deebebdf226285322a079b9b7c@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Štedrý den
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20151224
-DTEND;VALUE=DATE:20151225
-DTSTAMP:20140202T201100Z
-UID:h@1c3d67eb7865010f0ee809055f7c465124091d1b@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Štedrý den
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20150406
-DTEND;VALUE=DATE:20150407
-DTSTAMP:20140202T201100Z
-UID:h@e5a21162ed9d250ee5f689058366a09f10cf4ccb@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Velikonoční pondělí
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20140421
-DTEND;VALUE=DATE:20140422
-DTSTAMP:20140202T201100Z
-UID:h@9595a34a188b5376d452c829499a8f8354ec6049@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Velikonoční pondělí
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20150501
-DTEND;VALUE=DATE:20150502
-DTSTAMP:20140202T201100Z
-UID:h@7470a1d77684e63d5aa048babb939885ad1066c5@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Svátek práce
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20140501
-DTEND;VALUE=DATE:20140502
-DTSTAMP:20140202T201100Z
-UID:h@59ea753d474913d8c7ab474eaba701f8ec5c2ba1@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Svátek práce
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20130501
-DTEND;VALUE=DATE:20130502
-DTSTAMP:20140202T201100Z
-UID:h@19480e43102b11f061a7fc231692a6504e6f55de@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Svátek práce
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20140101
-DTEND;VALUE=DATE:20140102
-DTSTAMP:20140202T201100Z
-UID:h@cdcc3450b77b919b7e5c1d0186439b81fe315723@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Nový rok
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20130101
-DTEND;VALUE=DATE:20130102
-DTSTAMP:20140202T201100Z
-UID:h@93d93af5add7e8e8542f9d2be9bf9b189adc7088@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Nový rok
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20150101
-DTEND;VALUE=DATE:20150102
-DTSTAMP:20140202T201100Z
-UID:h@3be21c366071b22c3322e48e898803d89a2873c8@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Nový rok
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20140928
-DTEND;VALUE=DATE:20140929
-DTSTAMP:20140202T201100Z
-UID:h@910a92f331886c719cdab7cae0f8d56387788789@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den české státnosti
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20130928
-DTEND;VALUE=DATE:20130929
-DTSTAMP:20140202T201100Z
-UID:h@4bdee7defc8620b327b23400a9da3be5d0721a10@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den české státnosti
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20150928
-DTEND;VALUE=DATE:20150929
-DTSTAMP:20140202T201100Z
-UID:h@0534aebb7a00356b125529a447b38be655046ca9@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den české státnosti
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20150508
-DTEND;VALUE=DATE:20150509
-DTSTAMP:20140202T201100Z
-UID:h@f234114d721bac5776f1683f23a58ed2ffd53c84@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den vítězství
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20130508
-DTEND;VALUE=DATE:20130509
-DTSTAMP:20140202T201100Z
-UID:h@5b971aece3bf450de53261bafe25898080af2454@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den vítězství
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20140508
-DTEND;VALUE=DATE:20140509
-DTSTAMP:20140202T201100Z
-UID:h@574f6e8b741d1eb0e80ed4caea1441858393ff58@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den vítězství
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20131028
-DTEND;VALUE=DATE:20131029
-DTSTAMP:20140202T201100Z
-UID:h@be894303693f374fad9017da7ac6391c23eca0f6@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den vzniku samostatného československého státu
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20151028
-DTEND;VALUE=DATE:20151029
-DTSTAMP:20140202T201100Z
-UID:h@7e708d1f45342cd36f819e1f0d3d9f9b7eacc02f@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den vzniku samostatného československého státu
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20141028
-DTEND;VALUE=DATE:20141029
-DTSTAMP:20140202T201100Z
-UID:h@4dcdf85aaa09aea21fd49914085b47cdb44ccf0f@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den vzniku samostatného československého státu
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20150706
-DTEND;VALUE=DATE:20150707
-DTSTAMP:20140202T201100Z
-UID:h@d2253851fcafd5063bdbece5367507e338b5eea0@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den upálení mistra Jana Husa
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20140706
-DTEND;VALUE=DATE:20140707
-DTSTAMP:20140202T201100Z
-UID:h@2f980e6bc7f0445430367c33d3e4a27441196199@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den upálení mistra Jana Husa
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20130706
-DTEND;VALUE=DATE:20130707
-DTSTAMP:20140202T201100Z
-UID:h@09c62186abafba1bac59818bde105765a7a02121@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den upálení mistra Jana Husa
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20150705
-DTEND;VALUE=DATE:20150706
-DTSTAMP:20140202T201100Z
-UID:h@df873adcd2b61ea7c1b13761d7561b9fe6faae5c@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den slovanských věrozvěstů Cyrila a Metoděje
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20140705
-DTEND;VALUE=DATE:20140706
-DTSTAMP:20140202T201100Z
-UID:h@cc790a245031c0186f1d6d9ab8560db87c86269d@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den slovanských věrozvěstů Cyrila a Metoděje
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20130705
-DTEND;VALUE=DATE:20130706
-DTSTAMP:20140202T201100Z
-UID:h@4b4d8fc982e6734d799afdd5de90041a009e56b5@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den slovanských věrozvěstů Cyrila a Metoděje
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20150101
-DTEND;VALUE=DATE:20150102
-DTSTAMP:20140202T201100Z
-UID:h@e35dfa2052d4cf25d186e005626c66b794792d35@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den obnovy samostatného českého státu
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20130101
-DTEND;VALUE=DATE:20130102
-DTSTAMP:20140202T201100Z
-UID:h@e13a9a864c4beec0b4f1055fb4e1bb14076b5a9b@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den obnovy samostatného českého státu
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20140101
-DTEND;VALUE=DATE:20140102
-DTSTAMP:20140202T201100Z
-UID:h@a87543a1136d4a980a8037471eb49ea00f087c81@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den obnovy samostatného českého státu
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20141117
-DTEND;VALUE=DATE:20141118
-DTSTAMP:20140202T201100Z
-UID:h@94e14807e30f52a82572a2cd28a51c89a033d09f@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den boje za svobodu a demokracii
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20131117
-DTEND;VALUE=DATE:20131118
-DTSTAMP:20140202T201100Z
-UID:h@873a2a1499e25477876926c6729dc214b2f1f0f9@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den boje za svobodu a demokracii
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20151117
-DTEND;VALUE=DATE:20151118
-DTSTAMP:20140202T201100Z
-UID:h@599f0d6373565c265b3491b084a2c6198b0b00b9@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Den boje za svobodu a demokracii
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20151226
-DTEND;VALUE=DATE:20151227
-DTSTAMP:20140202T201100Z
-UID:h@e65fdbb6f9703e75e775c9f407f55663c80d4764@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:2. svátek vánoční
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20141226
-DTEND;VALUE=DATE:20141227
-DTSTAMP:20140202T201100Z
-UID:h@807088064c072183b2fa351251155bff44f09787@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:2. svátek vánoční
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20131226
-DTEND;VALUE=DATE:20131227
-DTSTAMP:20140202T201100Z
-UID:h@6165f686632ab29cdd7bdb46a4c3578a48045428@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:2. svátek vánoční
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20141225
-DTEND;VALUE=DATE:20141226
-DTSTAMP:20140202T201100Z
-UID:h@e2f049ac27b03ada54a27294becbcd1cc2680d9a@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:1. svátek vánoční
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20131225
-DTEND;VALUE=DATE:20131226
-DTSTAMP:20140202T201100Z
-UID:h@7f26c52a3d0e69b81f2fc35490224899490c0014@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:1. svátek vánoční
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20151225
-DTEND;VALUE=DATE:20151226
-DTSTAMP:20140202T201100Z
-UID:h@3ddadf7953340f067a4e3b07a4621f9343ff1518@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;X-NUM-GUE
- STS=0:mailto:cdpisorqclhmg8r8dtm6ip31f506esjfelo2sthecdgmopbechgn4bj7dtnmer
- 355phmur8%40virtual
-CLASS:PUBLIC
-CREATED:20140202T183416Z
-LAST-MODIFIED:20140202T183416Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:1. svátek vánoční
-TRANSP:OPAQUE
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/blank_description.ics b/includes/composer/vendor/om/icalparser/tests/cal/blank_description.ics
deleted file mode 100755
index 568d7e0..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/blank_description.ics
+++ /dev/null
@@ -1,51 +0,0 @@
-BEGIN:VCALENDAR
-PRODID:-//Google Inc//Google Calendar 70.9054//EN
-VERSION:2.0
-CALSCALE:GREGORIAN
-X-WR-CALNAME:calmozilla1@gmail.com
-X-WR-TIMEZONE:America/Los_Angeles
-BEGIN:VTIMEZONE
-TZID:America/Los_Angeles
-X-LIC-LOCATION:America/Los_Angeles
-BEGIN:DAYLIGHT
-TZOFFSETFROM:-0800
-TZOFFSETTO:-0700
-TZNAME:PDT
-DTSTART:19700308T020000
-RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=2SU
-END:DAYLIGHT
-BEGIN:STANDARD
-TZOFFSETFROM:-0700
-TZOFFSETTO:-0800
-TZNAME:PST
-DTSTART:19701101T020000
-RRULE:FREQ=YEARLY;BYMONTH=11;BYDAY=1SU
-END:STANDARD
-END:VTIMEZONE
-BEGIN:VEVENT
-DTSTART;TZID=America/Los_Angeles:20120630T060000
-DTEND;TZID=America/Los_Angeles:20120630T070000
-DTSTAMP:20120724T212411Z
-UID:dn4vrfmfn5p05roahsopg57h48@google.com
-CREATED:20120724T212411Z
-DESCRIPTION:
-LAST-MODIFIED:20120724T212411Z
-LOCATION:
-SEQUENCE:0
-STATUS:CONFIRMED
-SUMMARY:Really long event name thing
-TRANSP:OPAQUE
-BEGIN:VALARM
-ACTION:EMAIL
-DESCRIPTION:This is an event reminder
-SUMMARY:Alarm notification
-ATTENDEE:mailto:calmozilla1@gmail.com
-TRIGGER:-P0DT0H30M0S
-END:VALARM
-BEGIN:VALARM
-ACTION:DISPLAY
-DESCRIPTION:This is an event reminder
-TRIGGER:-P0DT0H30M0S
-END:VALARM
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/blank_line_end.ics b/includes/composer/vendor/om/icalparser/tests/cal/blank_line_end.ics
deleted file mode 100755
index 2c397c2..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/blank_line_end.ics
+++ /dev/null
@@ -1,4 +0,0 @@
-BEGIN:VCALENDAR
-END:VCALENDAR
-
-
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/blank_line_mid.ics b/includes/composer/vendor/om/icalparser/tests/cal/blank_line_mid.ics
deleted file mode 100755
index 5e54e2e..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/blank_line_mid.ics
+++ /dev/null
@@ -1,4 +0,0 @@
-BEGIN:VCALENDAR
-COMMENT:This blank line is invalid
-
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/daily_recur.ics b/includes/composer/vendor/om/icalparser/tests/cal/daily_recur.ics
deleted file mode 100755
index 9983098..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/daily_recur.ics
+++ /dev/null
@@ -1,52 +0,0 @@
-BEGIN:VCALENDAR
-PRODID:-//Google Inc//Google Calendar 70.9054//EN
-VERSION:2.0
-CALSCALE:GREGORIAN
-X-WR-CALNAME:calmozilla1@gmail.com
-X-WR-TIMEZONE:America/Los_Angeles
-BEGIN:VTIMEZONE
-TZID:America/Los_Angeles
-X-LIC-LOCATION:America/Los_Angeles
-BEGIN:DAYLIGHT
-TZOFFSETFROM:-0800
-TZOFFSETTO:-0700
-TZNAME:PDT
-DTSTART:19700308T020000
-RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=2SU
-END:DAYLIGHT
-BEGIN:STANDARD
-TZOFFSETFROM:-0700
-TZOFFSETTO:-0800
-TZNAME:PST
-DTSTART:19701101T020000
-RRULE:FREQ=YEARLY;BYMONTH=11;BYDAY=1SU
-END:STANDARD
-END:VTIMEZONE
-BEGIN:VEVENT
-DTSTART;TZID=America/Los_Angeles:20120801T050000
-DTEND;TZID=America/Los_Angeles:20120801T060000
-RRULE:FREQ=DAILY
-DTSTAMP:20120803T221236Z
-UID:tgh9qho17b07pk2n2ji3gluans@google.com
-CREATED:20120803T221236Z
-DESCRIPTION:
-LAST-MODIFIED:20120803T221236Z
-LOCATION:
-SEQUENCE:0
-STATUS:CONFIRMED
-SUMMARY:Every day recurring
-TRANSP:OPAQUE
-BEGIN:VALARM
-ACTION:EMAIL
-DESCRIPTION:This is an event reminder
-SUMMARY:Alarm notification
-ATTENDEE:mailto:calmozilla1@gmail.com
-TRIGGER:-P0DT0H30M0S
-END:VALARM
-BEGIN:VALARM
-ACTION:DISPLAY
-DESCRIPTION:This is an event reminder
-TRIGGER:-P0DT0H30M0S
-END:VALARM
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/daily_recur2.ics b/includes/composer/vendor/om/icalparser/tests/cal/daily_recur2.ics
deleted file mode 100755
index 346f54e..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/daily_recur2.ics
+++ /dev/null
@@ -1,41 +0,0 @@
-BEGIN:VCALENDAR
-PRODID:-//Google Inc//Google Calendar 70.9054//EN
-VERSION:2.0
-CALSCALE:GREGORIAN
-X-WR-CALNAME:calmozilla1@gmail.com
-X-WR-TIMEZONE:America/Los_Angeles
-BEGIN:VTIMEZONE
-TZID:America/Los_Angeles
-X-LIC-LOCATION:America/Los_Angeles
-BEGIN:DAYLIGHT
-TZOFFSETFROM:-0800
-TZOFFSETTO:-0700
-TZNAME:PDT
-DTSTART:19700308T020000
-RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=2SU
-END:DAYLIGHT
-BEGIN:STANDARD
-TZOFFSETFROM:-0700
-TZOFFSETTO:-0800
-TZNAME:PST
-DTSTART:19701101T020000
-RRULE:FREQ=YEARLY;BYMONTH=11;BYDAY=1SU
-END:STANDARD
-END:VTIMEZONE
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170821
-DTEND;VALUE=DATE:20170822
-RRULE:FREQ=WEEKLY;UNTIL=20170911;BYDAY=MO
-DTSTAMP:20170818T191547Z
-UID:37mfdqtlcrrvbil9b3n7vicb1t@google.com
-CLASS:PUBLIC
-CREATED:20170818T175332Z
-DESCRIPTION:
-LAST-MODIFIED:20170818T175332Z
-LOCATION:
-SEQUENCE:0
-STATUS:CONFIRMED
-SUMMARY:Late Start\, SMS
-TRANSP:TRANSPARENT
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/day_long_recur_yearly.ics b/includes/composer/vendor/om/icalparser/tests/cal/day_long_recur_yearly.ics
deleted file mode 100755
index 0c0aeb5..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/day_long_recur_yearly.ics
+++ /dev/null
@@ -1,52 +0,0 @@
-BEGIN:VCALENDAR
-PRODID:-//Google Inc//Google Calendar 70.9054//EN
-VERSION:2.0
-CALSCALE:GREGORIAN
-X-WR-CALNAME:calmozilla1@gmail.com
-X-WR-TIMEZONE:America/Los_Angeles
-BEGIN:VTIMEZONE
-TZID:America/Los_Angeles
-X-LIC-LOCATION:America/Los_Angeles
-BEGIN:DAYLIGHT
-TZOFFSETFROM:-0800
-TZOFFSETTO:-0700
-TZNAME:PDT
-DTSTART:19700308T020000
-RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=2SU
-END:DAYLIGHT
-BEGIN:STANDARD
-TZOFFSETFROM:-0700
-TZOFFSETTO:-0800
-TZNAME:PST
-DTSTART:19701101T020000
-RRULE:FREQ=YEARLY;BYMONTH=11;BYDAY=1SU
-END:STANDARD
-END:VTIMEZONE
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20120803
-DTEND;VALUE=DATE:20120804
-RRULE:FREQ=WEEKLY;BYDAY=MO,TU,WE,TH,FR
-DTSTAMP:20120803T221306Z
-UID:4pfh824gvims850j0gar361t04@google.com
-CREATED:20120803T221306Z
-DESCRIPTION:
-LAST-MODIFIED:20120803T221306Z
-LOCATION:
-SEQUENCE:0
-STATUS:CONFIRMED
-SUMMARY:Day Long Event
-TRANSP:TRANSPARENT
-BEGIN:VALARM
-ACTION:EMAIL
-DESCRIPTION:This is an event reminder
-SUMMARY:Alarm notification
-ATTENDEE:mailto:calmozilla1@gmail.com
-TRIGGER;VALUE=DATE-TIME:20120802T233000Z
-END:VALARM
-BEGIN:VALARM
-ACTION:DISPLAY
-DESCRIPTION:This is an event reminder
-TRIGGER;VALUE=DATE-TIME:20120802T233000Z
-END:VALARM
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/forced_types.ics b/includes/composer/vendor/om/icalparser/tests/cal/forced_types.ics
deleted file mode 100755
index f213f01..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/forced_types.ics
+++ /dev/null
@@ -1,50 +0,0 @@
-BEGIN:VCALENDAR
-PRODID:-//Google Inc//Google Calendar 70.9054//EN
-VERSION:2.0
-CALSCALE:GREGORIAN
-X-WR-CALNAME:calmozilla1@gmail.com
-X-WR-TIMEZONE:America/Los_Angeles
-BEGIN:VTIMEZONE
-TZID:America/Los_Angeles
-X-LIC-LOCATION:America/Los_Angeles
-BEGIN:DAYLIGHT
-TZOFFSETFROM:-0800
-TZOFFSETTO:-0700
-TZNAME:PDT
-DTSTART:19700308T020000
-RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=2SU
-END:DAYLIGHT
-BEGIN:STANDARD
-TZOFFSETFROM:-0700
-TZOFFSETTO:-0800
-TZNAME:PST
-DTSTART:19701101T020000
-RRULE:FREQ=YEARLY;BYMONTH=11;BYDAY=1SU
-END:STANDARD
-END:VTIMEZONE
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20120904
-DTEND;VALUE=DATE:20120905
-DTSTAMP:20120905T084734Z
-UID:redgrb1l0aju5edm6h0s102eu4@google.com
-CREATED:20120905T084734Z
-DESCRIPTION:
-LAST-MODIFIED:20120905T084734Z
-LOCATION:
-SEQUENCE:0
-STATUS:CONFIRMED
-SUMMARY:Event
-TRANSP:TRANSPARENT
-BEGIN:VALARM
-ACTION:EMAIL
-DESCRIPTION:This is an event reminder
-SUMMARY:Alarm notification
-ATTENDEE:mailto:calmozilla1@gmail.com
-TRIGGER;VALUE=DATE-TIME:20120903T233000Z
-END:VALARM
-BEGIN:VALARM
-ACTION:DISPLAY
-DESCRIPTION:This is an event reminder
-END:VALARM
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/google_birthday.ics b/includes/composer/vendor/om/icalparser/tests/cal/google_birthday.ics
deleted file mode 100755
index f9b7c9d..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/google_birthday.ics
+++ /dev/null
@@ -1,90 +0,0 @@
-BEGIN:VCALENDAR
-PRODID:-//Google Inc//Google Calendar 70.9054//EN
-VERSION:2.0
-CALSCALE:GREGORIAN
-X-WR-CALNAME:Contacts' birthdays and events
-X-WR-TIMEZONE:America/Los_Angeles
-X-WR-CALDESC:Your contacts' birthdays and anniversaries
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20141210
-DTEND;VALUE=DATE:20141211
-RRULE:FREQ=DAILY;INTERVAL=1;COUNT=1
-RDATE:20131210Z
-RDATE:20121210Z
-DTSTAMP:20121207T183041Z
-UID:2014_BIRTHDAY_79d389868f96182e@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;CN=Contac
- ts;X-NUM-GUESTS=0:mailto:4dhmurjkc5hn8sq0ctp6utbg5pr2sor1dhimsp31e8n6errfct
- m6abj3dtmg@virtual
-CLASS:PUBLIC
-CREATED:20121207T183041Z
-LAST-MODIFIED:20121207T183041Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:PErson #2's birthday
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20121210
-DTEND;VALUE=DATE:20121211
-DTSTAMP:20121207T183041Z
-UID:BIRTHDAY_79d389868f96182e@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;CN=Contac
- ts;X-NUM-GUESTS=0:mailto:4dhmurjkc5hn8sq0ctp6utbg5pr2sor1dhimsp31e8n6errfct
- m6abj3dtmg@virtual
-X-GOOGLE-CALENDAR-CONTENT-ICON:https://calendar.google.com/googlecalendar/i
- mages/cake.gif
-X-GOOGLE-CALENDAR-CONTENT-DISPLAY:chip
-RECURRENCE-ID;VALUE=DATE:20121210
-CLASS:PUBLIC
-CREATED:20121207T183041Z
-DESCRIPTION:Today is PErson #2's birthday!
-LAST-MODIFIED:20121207T183041Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:PErson #2's birthday
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20131210
-DTEND;VALUE=DATE:20131211
-DTSTAMP:20121207T183041Z
-UID:BIRTHDAY_79d389868f96182e@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;CN=Contac
- ts;X-NUM-GUESTS=0:mailto:4dhmurjkc5hn8sq0ctp6utbg5pr2sor1dhimsp31e8n6errfct
- m6abj3dtmg@virtual
-X-GOOGLE-CALENDAR-CONTENT-ICON:https://calendar.google.com/googlecalendar/i
- mages/cake.gif
-X-GOOGLE-CALENDAR-CONTENT-DISPLAY:chip
-RECURRENCE-ID;VALUE=DATE:20131210
-CLASS:PUBLIC
-CREATED:20121207T183041Z
-DESCRIPTION:Today is PErson #2's birthday!
-LAST-MODIFIED:20121207T183041Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:PErson #2's birthday
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20141210
-DTEND;VALUE=DATE:20141211
-DTSTAMP:20121207T183041Z
-UID:BIRTHDAY_79d389868f96182e@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;CN=Contac
- ts;X-NUM-GUESTS=0:mailto:4dhmurjkc5hn8sq0ctp6utbg5pr2sor1dhimsp31e8n6errfct
- m6abj3dtmg@virtual
-X-GOOGLE-CALENDAR-CONTENT-ICON:https://calendar.google.com/googlecalendar/i
- mages/cake.gif
-X-GOOGLE-CALENDAR-CONTENT-DISPLAY:chip
-RECURRENCE-ID;VALUE=DATE:20141210
-CLASS:PUBLIC
-CREATED:20121207T183041Z
-DESCRIPTION:Today is PErson #2's birthday!
-LAST-MODIFIED:20121207T183041Z
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:PErson #2's birthday
-TRANSP:OPAQUE
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/minimal.ics b/includes/composer/vendor/om/icalparser/tests/cal/minimal.ics
deleted file mode 100755
index b97d2ac..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/minimal.ics
+++ /dev/null
@@ -1,39 +0,0 @@
-BEGIN:VCALENDAR
-PRODID:-//Google Inc//Google Calendar 70.9054//EN
-VERSION:2.0
-CALSCALE:GREGORIAN
-X-WR-CALNAME:calmozilla1@gmail.com
-X-WR-TIMEZONE:America/Los_Angeles
-BEGIN:VTIMEZONE
-TZID:America/Los_Angeles
-X-LIC-LOCATION:America/Los_Angeles
-BEGIN:DAYLIGHT
-TZOFFSETFROM:-0800
-TZOFFSETTO:-0700
-TZNAME:PDT
-DTSTART:19700308T020000
-RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=2SU
-END:DAYLIGHT
-BEGIN:STANDARD
-TZOFFSETFROM:-0700
-TZOFFSETTO:-0800
-TZNAME:PST
-DTSTART:19701101T020000
-RRULE:FREQ=YEARLY;BYMONTH=11;BYDAY=1SU
-END:STANDARD
-END:VTIMEZONE
-BEGIN:VEVENT
-DTSTART;TZID=America/Los_Angeles:20120630T060000
-DTEND;TZID=America/Los_Angeles:20120630T070000
-DTSTAMP:20120724T212411Z
-UID:dn4vrfmfn5p05roahsopg57h48@google.com
-CREATED:20120724T212411Z
-DESCRIPTION:
-LAST-MODIFIED:20120724T212411Z
-LOCATION:
-SEQUENCE:0
-STATUS:CONFIRMED
-SUMMARY:Really long event name thing
-TRANSP:OPAQUE
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/missing-timezone.ics b/includes/composer/vendor/om/icalparser/tests/cal/missing-timezone.ics
deleted file mode 100644
index 2579548..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/missing-timezone.ics
+++ /dev/null
@@ -1,47 +0,0 @@
-BEGIN:VCALENDAR
-PRODID;X-RICAL-TZSOURCE=TZINFO:-//Airbnb Inc//Hosting Calendar 0.8.8//EN
-CALSCALE:GREGORIAN
-VERSION:2.0
-BEGIN:VEVENT
-DTEND;VALUE=DATE:20220520
-DTSTART;VALUE=DATE:20220412
-UID:1418fdfasfdasdfsad@airbnb.com
-DESCRIPTION:Reservation URL: https://www.airbnb.com/hosting/reservations/
- details/HMQHSAR9SE\nPhone Number (Last 4 Digits): 0431
-SUMMARY:Reserved
-END:VEVENT
-BEGIN:VEVENT
-DTEND;VALUE=DATE:20220620
-DTSTART;VALUE=DATE:20220617
-UID:1418fb94e984-dfasdfasdfsdfsdfsd@airbnb.com
-DESCRIPTION:Reservation URL: https://www.airbnb.com/hosting/reservations/
- details/HMWQXYQSM4\nPhone Number (Last 4 Digits): 2360
-SUMMARY:Reserved
-END:VEVENT
-BEGIN:VEVENT
-DTEND;VALUE=DATE:20220628
-DTSTART;VALUE=DATE:20220625
-UID:1418fb94e984-dafdfdfadfdfadsfasdafsd@airbnb.com
-DESCRIPTION:Reservation URL: https://www.airbnb.com/hosting/reservations/
- details/HM49HZXKQT\nPhone Number (Last 4 Digits): 1537
-SUMMARY:Reserved
-END:VEVENT
-BEGIN:VEVENT
-DTEND;VALUE=DATE:20220724
-DTSTART;VALUE=DATE:20220723
-UID:6fec1092d3fa-afdfasdfdsfasdfasdfsdfasd@airbnb.com
-SUMMARY:Airbnb (Not available)
-END:VEVENT
-BEGIN:VEVENT
-DTEND;VALUE=DATE:20220807
-DTSTART;VALUE=DATE:20220725
-UID:6fec1092d3fa-afdfsdfsdfasdfadsfsfs@airbnb.com
-SUMMARY:Airbnb (Not available)
-END:VEVENT
-BEGIN:VEVENT
-DTEND;VALUE=DATE:20230512
-DTSTART;VALUE=DATE:20221107
-UID:6fec1092d3fa-afdafdsafsdfdfsdfsd@airbnb.com
-SUMMARY:Airbnb (Not available)
-END:VEVENT
-END:VCALENDAR \ No newline at end of file
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/missing_RRULE_notice.ics b/includes/composer/vendor/om/icalparser/tests/cal/missing_RRULE_notice.ics
deleted file mode 100644
index 84ace92..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/missing_RRULE_notice.ics
+++ /dev/null
@@ -1,39 +0,0 @@
-BEGIN:VCALENDAR
-VERSION:2.0
-X-WR-CALNAME:URL
-CALSCALE:GREGORIAN
-BEGIN:VTIMEZONE
-TZID:Europe/Berlin
-TZURL:http://tzurl.org/zoneinfo-outlook/Europe/Berlin
-X-LIC-LOCATION:Europe/Berlin
-BEGIN:DAYLIGHT
-TZOFFSETFROM:+0100
-TZOFFSETTO:+0200
-TZNAME:CEST
-DTSTART:19700329T020000
-RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=-1SU
-END:DAYLIGHT
-BEGIN:STANDARD
-TZOFFSETFROM:+0200
-TZOFFSETTO:+0100
-TZNAME:CET
-DTSTART:19701025T030000
-RRULE:FREQ=YEARLY;BYMONTH=10;BYDAY=-1SU
-END:STANDARD
-END:VTIMEZONE
-BEGIN:VEVENT
-UID:111
-DTSTAMP:20181123T192651Z
-CATEGORIES;LANGUAGE=de-DE:Party
-CONTACT:
-DESCRIPTION:xxx
-DTSTART;TZID=Europe/Berlin:20160415T210000
-DTEND;TZID=Europe/Berlin:20160416T040000
-LOCATION:xxx
-RDATE;TZID=Europe/Berlin:20161216T210000
-RDATE;TZID=Europe/Berlin:20161223T210000
-RDATE;TZID=Europe/Berlin:20161230T210000
-SEQUENCE:0
-SUMMARY:xxx
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/multiline_description.ics b/includes/composer/vendor/om/icalparser/tests/cal/multiline_description.ics
deleted file mode 100644
index b5ff35c..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/multiline_description.ics
+++ /dev/null
@@ -1,52 +0,0 @@
-BEGIN:VCALENDAR
-PRODID:-//Google Inc//Google Calendar 70.9054//EN
-VERSION:2.0
-CALSCALE:GREGORIAN
-X-WR-CALNAME:calmozilla1@gmail.com
-X-WR-TIMEZONE:America/Los_Angeles
-BEGIN:VTIMEZONE
-TZID:America/Los_Angeles
-X-LIC-LOCATION:America/Los_Angeles
-BEGIN:DAYLIGHT
-TZOFFSETFROM:-0800
-TZOFFSETTO:-0700
-TZNAME:PDT
-DTSTART:19700308T020000
-RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=2SU
-END:DAYLIGHT
-BEGIN:STANDARD
-TZOFFSETFROM:-0700
-TZOFFSETTO:-0800
-TZNAME:PST
-DTSTART:19701101T020000
-RRULE:FREQ=YEARLY;BYMONTH=11;BYDAY=1SU
-END:STANDARD
-END:VTIMEZONE
-BEGIN:VEVENT
-DTSTART;TZID=America/Los_Angeles:20120630T060000
-DTEND;TZID=America/Los_Angeles:20120630T070000
-DTSTAMP:20120724T212411Z
-UID:dn4vrfmfn5p05roahsopg57h48@google.com
-CREATED:20120724T212411Z
-DESCRIPTION:Here is a description that spans multiple lines!\n\nThis should be on
- a new line as well because the description contains newline characters.
-LAST-MODIFIED:20120724T212411Z
-LOCATION:
-SEQUENCE:0
-STATUS:CONFIRMED
-SUMMARY:Really long event name thing
-TRANSP:OPAQUE
-BEGIN:VALARM
-ACTION:EMAIL
-DESCRIPTION:This is an event reminder
-SUMMARY:Alarm notification
-ATTENDEE:mailto:calmozilla1@gmail.com
-TRIGGER:-P0DT0H30M0S
-END:VALARM
-BEGIN:VALARM
-ACTION:DISPLAY
-DESCRIPTION:This is an event reminder
-TRIGGER:-P0DT0H30M0S
-END:VALARM
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/multiple_attachments.ics b/includes/composer/vendor/om/icalparser/tests/cal/multiple_attachments.ics
deleted file mode 100755
index 0c25f82..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/multiple_attachments.ics
+++ /dev/null
@@ -1,45 +0,0 @@
-BEGIN:VCALENDAR
-VERSION:2.0
-PRODID:Zimbra-Calendar-Provider
-BEGIN:VTIMEZONE
-TZID:America/Los_Angeles
-BEGIN:STANDARD
-DTSTART:19710101T020000
-TZOFFSETTO:-0800
-TZOFFSETFROM:-0700
-RRULE:FREQ=YEARLY;WKST=MO;INTERVAL=1;BYMONTH=11;BYDAY=1SU
-TZNAME:PST
-END:STANDARD
-BEGIN:DAYLIGHT
-DTSTART:19710101T020000
-TZOFFSETTO:-0700
-TZOFFSETFROM:-0800
-RRULE:FREQ=YEARLY;WKST=MO;INTERVAL=1;BYMONTH=3;BYDAY=2SU
-TZNAME:PDT
-END:DAYLIGHT
-END:VTIMEZONE
-BEGIN:VEVENT
-UID:1334F9B7-6136-444E-A58D-472564C6AA73
-SUMMARY:sahaja <> frashed
-DESCRIPTION:weekly 1on1
-ATTACH:http://globe-views.com/dcim/dreams/dog/dog-01.jpg
-ATTACH:http://www.hdanimals.com/static/cache/e9/59/e959f33a6b440f36cad24beca8bf6d1c.jpg
-ATTENDEE;CN=James Lal;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=NEEDS
- -ACTION;RSVP=TRUE:mailto:jlal@mozilla.com
-ORGANIZER;CN=Faramarz Rashed:mailto:frashed@mozilla.com
-DTSTART;TZID=America/Los_Angeles:20120326T110000
-DTEND;TZID=America/Los_Angeles:20120326T113000
-STATUS:CONFIRMED
-CLASS:PUBLIC
-TRANSP:OPAQUE
-LAST-MODIFIED:20120326T161522Z
-DTSTAMP:20120730T165637Z
-SEQUENCE:9
-BEGIN:VALARM
-ACTION:DISPLAY
-TRIGGER;RELATED=START:-PT5M
-DESCRIPTION:Reminder
-END:VALARM
-END:VEVENT
-END:VCALENDAR
-
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/multiple_categories.ics b/includes/composer/vendor/om/icalparser/tests/cal/multiple_categories.ics
deleted file mode 100755
index 5353845..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/multiple_categories.ics
+++ /dev/null
@@ -1,67 +0,0 @@
-BEGIN:VCALENDAR
-VERSION:2.0
-PRODID:Zimbra-Calendar-Provider
-BEGIN:VTIMEZONE
-TZID:America/Los_Angeles
-BEGIN:STANDARD
-DTSTART:19710101T020000
-TZOFFSETTO:-0800
-TZOFFSETFROM:-0700
-RRULE:FREQ=YEARLY;WKST=MO;INTERVAL=1;BYMONTH=11;BYDAY=1SU
-TZNAME:PST
-END:STANDARD
-BEGIN:DAYLIGHT
-DTSTART:19710101T020000
-TZOFFSETTO:-0700
-TZOFFSETFROM:-0800
-RRULE:FREQ=YEARLY;WKST=MO;INTERVAL=1;BYMONTH=3;BYDAY=2SU
-TZNAME:PDT
-END:DAYLIGHT
-END:VTIMEZONE
-BEGIN:VEVENT
-UID:1334F9B7-6136-444E-A58D-472564C6AA73
-SUMMARY:sahaja <> frashed
-DESCRIPTION:weekly 1on1
-CATEGORIES:one, two, three
-ATTENDEE;CN=James Lal;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=NEEDS
- -ACTION;RSVP=TRUE:mailto:jlal@mozilla.com
-ORGANIZER;CN=Faramarz Rashed:mailto:frashed@mozilla.com
-DTSTART;TZID=America/Los_Angeles:20120326T110000
-DTEND;TZID=America/Los_Angeles:20120326T113000
-STATUS:CONFIRMED
-CLASS:PUBLIC
-TRANSP:OPAQUE
-LAST-MODIFIED:20120326T161522Z
-DTSTAMP:20120730T165637Z
-SEQUENCE:9
-BEGIN:VALARM
-ACTION:DISPLAY
-TRIGGER;RELATED=START:-PT5M
-DESCRIPTION:Reminder
-END:VALARM
-END:VEVENT
-BEGIN:VEVENT
-UID:14556F9B7-6136-444E-A58D-472564C6AA73
-SUMMARY:something something
-DESCRIPTION:weekly 1on1
-CATEGORIES:one
-CATEGORIES:two
-CATEGORIES:three
-ATTENDEE;CN=James Lal;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=NEEDS
- -ACTION;RSVP=TRUE:mailto:jlal@mozilla.com
-ORGANIZER;CN=Faramarz Rashed:mailto:frashed@mozilla.com
-DTSTART;TZID=America/Los_Angeles:20120326T110000
-DTEND;TZID=America/Los_Angeles:20120326T113000
-STATUS:CONFIRMED
-CLASS:PUBLIC
-TRANSP:OPAQUE
-LAST-MODIFIED:20120326T161522Z
-DTSTAMP:20120730T165637Z
-SEQUENCE:9
-BEGIN:VALARM
-ACTION:DISPLAY
-TRIGGER;RELATED=START:-PT5M
-DESCRIPTION:Reminder
-END:VALARM
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/multiple_rrules.ics b/includes/composer/vendor/om/icalparser/tests/cal/multiple_rrules.ics
deleted file mode 100755
index 339c318..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/multiple_rrules.ics
+++ /dev/null
@@ -1,45 +0,0 @@
-BEGIN:VCALENDAR
-VERSION:2.0
-PRODID:Zimbra-Calendar-Provider
-BEGIN:VTIMEZONE
-TZID:America/Los_Angeles
-BEGIN:STANDARD
-DTSTART:19710101T020000
-TZOFFSETTO:-0800
-TZOFFSETFROM:-0700
-RRULE:FREQ=YEARLY;WKST=MO;INTERVAL=1;BYMONTH=11;BYDAY=1SU
-TZNAME:PST
-END:STANDARD
-BEGIN:DAYLIGHT
-DTSTART:19710101T020000
-TZOFFSETTO:-0700
-TZOFFSETFROM:-0800
-RRULE:FREQ=YEARLY;WKST=MO;INTERVAL=1;BYMONTH=3;BYDAY=2SU
-TZNAME:PDT
-END:DAYLIGHT
-END:VTIMEZONE
-BEGIN:VEVENT
-UID:1334F9B7-6136-444E-A58D-472564C6AA73
-RRULE:FREQ=WEEKLY;UNTIL=20120730T065959Z
-RRULE:FREQ=MONTHLY;BYDAY=SU;UNTIL=20120730T065959Z
-SUMMARY:sahaja <> frashed
-DESCRIPTION:weekly 1on1
-ATTENDEE;CN=James Lal;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=NEEDS
- -ACTION;RSVP=TRUE:mailto:jlal@mozilla.com
-ORGANIZER;CN=Faramarz Rashed:mailto:frashed@mozilla.com
-DTSTART;TZID=America/Los_Angeles:20120326T110000
-DTEND;TZID=America/Los_Angeles:20120326T113000
-STATUS:CONFIRMED
-CLASS:PUBLIC
-TRANSP:OPAQUE
-LAST-MODIFIED:20120326T161522Z
-DTSTAMP:20120730T165637Z
-SEQUENCE:9
-BEGIN:VALARM
-ACTION:DISPLAY
-TRIGGER;RELATED=START:-PT5M
-DESCRIPTION:Reminder
-END:VALARM
-END:VEVENT
-END:VCALENDAR
-
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/parserv2.ics b/includes/composer/vendor/om/icalparser/tests/cal/parserv2.ics
deleted file mode 100755
index 11c8301..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/parserv2.ics
+++ /dev/null
@@ -1,45 +0,0 @@
-BEGIN:VCALENDAR
-VERSION:2.0
-PRODID:Zimbra-Calendar-Provider
-BEGIN:VTIMEZONE
-TZID:America/Los_Angeles
-BEGIN:STANDARD
-DTSTART:19710101T020000
-TZOFFSETTO:-0800
-TZOFFSETFROM:-0700
-RRULE:FREQ=YEARLY;BYDAY=1SU;BYMONTH=11
-TZNAME:PST
-END:STANDARD
-BEGIN:DAYLIGHT
-DTSTART:19710101T020000
-TZOFFSETTO:-0700
-TZOFFSETFROM:-0800
-RRULE:FREQ=YEARLY;BYDAY=2SU;BYMONTH=3
-TZNAME:PDT
-END:DAYLIGHT
-END:VTIMEZONE
-BEGIN:VEVENT
-UID:44c10eaa-db0b-4223-8653-cf2b63f26326
-RRULE:FREQ=DAILY;BYDAY=MO,TU,WE,TH,FR
-SUMMARY:Calendar
-DESCRIPTION:desc
-ATTENDEE;CN=XXX;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;RSVP=TRU
- E:mailto:foo@bar.com
-ATTENDEE;CN=XXXX;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;RSVP=TR
- UE:mailto:x@bar.com
-ORGANIZER;CN=foobar:mailto:x@bar.com
-DTSTART;TZID=America/Los_Angeles:20120911T103000
-DTEND;TZID=America/Los_Angeles:20120911T110000
-STATUS:CONFIRMED
-CLASS:PUBLIC
-TRANSP:OPAQUE
-LAST-MODIFIED:20120911T184851Z
-DTSTAMP:20120911T184851Z
-SEQUENCE:1
-BEGIN:VALARM
-ACTION:DISPLAY
-TRIGGER;RELATED=START:-PT5M
-DESCRIPTION:Reminder
-END:VALARM
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/readme.md b/includes/composer/vendor/om/icalparser/tests/cal/readme.md
deleted file mode 100644
index 4e3ec57..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/readme.md
+++ /dev/null
@@ -1,3 +0,0 @@
-# iCal source
-
-- https://github.com/mozilla-comm/ical.js/tree/master/samples
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/recur_instances.ics b/includes/composer/vendor/om/icalparser/tests/cal/recur_instances.ics
deleted file mode 100755
index d26903f..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/recur_instances.ics
+++ /dev/null
@@ -1,92 +0,0 @@
-BEGIN:VCALENDAR
-VERSION:2.0
-PRODID:Zimbra-Calendar-Provider
-BEGIN:VTIMEZONE
-TZID:America/Los_Angeles
-BEGIN:STANDARD
-DTSTART:19710101T020000
-TZOFFSETTO:-0800
-TZOFFSETFROM:-0700
-RRULE:FREQ=YEARLY;WKST=MO;INTERVAL=1;BYMONTH=11;BYDAY=1SU
-TZNAME:PST
-END:STANDARD
-BEGIN:DAYLIGHT
-DTSTART:19710101T020000
-TZOFFSETTO:-0700
-TZOFFSETFROM:-0800
-RRULE:FREQ=YEARLY;WKST=MO;INTERVAL=1;BYMONTH=3;BYDAY=2SU
-TZNAME:PDT
-END:DAYLIGHT
-END:VTIMEZONE
-BEGIN:VEVENT
-UID:623c13c0-6c2b-45d6-a12b-c33ad61c4868
-DESCRIPTION:IAM FOO
-RRULE:FREQ=MONTHLY;INTERVAL=1;BYDAY=1TU
-SUMMARY:Crazy Event Thingy!
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;CN=Sahaja
- Lal;X-NUM-GUESTS=0:mailto:calmozilla1@gmail.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=NEEDS-ACTION;CN=ja
- mes@lightsofapollo.com;X-NUM-GUESTS=0:mailto:james@lightsofapollo.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=NEEDS-ACTION;CN=ia
- m.revelation@gmail.com;X-NUM-GUESTS=0:mailto:iam.revelation@gmail.com
-LOCATION:PLACE
-ORGANIZER;CN=James Lal:mailto:jlal@mozilla.com
-DTSTART;TZID=America/Los_Angeles:20121002T100000
-DTEND;TZID=America/Los_Angeles:20121002T103000
-STATUS:CONFIRMED
-CLASS:PUBLIC
-TRANSP:OPAQUE
-LAST-MODIFIED:20120912T171506Z
-DTSTAMP:20120912T171506Z
-SEQUENCE:0
-RDATE;TZID=America/Los_Angeles:20121105T100000
-RDATE;TZID=America/Los_Angeles:20121110T100000,20121130T100000
-EXDATE;TZID=America/Los_Angeles:20130402T100000
-EXDATE;TZID=America/Los_Angeles:20121204T100000
-EXDATE;TZID=America/Los_Angeles:20130205T100000
-BEGIN:VALARM
-ACTION:DISPLAY
-TRIGGER;RELATED=START:-PT5M
-DESCRIPTION:Reminder
-END:VALARM
-END:VEVENT
-BEGIN:VEVENT
-UID:623c13c0-6c2b-45d6-a12b-c33ad61c4868
-SUMMARY:Crazy Event Thingy!
-DESCRIPTION:I HAZ CHANGED!
-ORGANIZER;CN=James Lal:mailto:jlal@mozilla.com
-DTSTART;TZID=America/Los_Angeles:20121002T150000
-DTEND;TZID=America/Los_Angeles:20121002T153000
-STATUS:CONFIRMED
-CLASS:PUBLIC
-TRANSP:OPAQUE
-RECURRENCE-ID;TZID=America/Los_Angeles:20121002T100000
-LAST-MODIFIED:20120912T171540Z
-DTSTAMP:20120912T171540Z
-SEQUENCE:1
-BEGIN:VALARM
-ACTION:DISPLAY
-TRIGGER;RELATED=START:-PT5M
-DESCRIPTION:Reminder
-END:VALARM
-END:VEVENT
-BEGIN:VEVENT
-UID:623c13c0-6c2b-45d6-a12b-c33ad61c4868
-SUMMARY:Crazy Event Thingy!
-ORGANIZER;CN=James Lal:mailto:jlal@mozilla.com
-DTSTART;TZID=America/Los_Angeles:20121106T200000
-DTEND;TZID=America/Los_Angeles:20121106T203000
-STATUS:CONFIRMED
-CLASS:PUBLIC
-TRANSP:OPAQUE
-RECURRENCE-ID:20121105T180000Z
-LAST-MODIFIED:20120912T171820Z
-DTSTAMP:20120912T171820Z
-SEQUENCE:1
-BEGIN:VALARM
-ACTION:DISPLAY
-TRIGGER;RELATED=START:-PT5M
-DESCRIPTION:Reminder
-END:VALARM
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/recur_instances_finite.ics b/includes/composer/vendor/om/icalparser/tests/cal/recur_instances_finite.ics
deleted file mode 100755
index e7dc481..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/recur_instances_finite.ics
+++ /dev/null
@@ -1,50 +0,0 @@
-BEGIN:VCALENDAR
-VERSION:2.0
-PRODID:Zimbra-Calendar-Provider
-BEGIN:VTIMEZONE
-TZID:America/Los_Angeles
-BEGIN:STANDARD
-DTSTART:19710101T020000
-TZOFFSETTO:-0800
-TZOFFSETFROM:-0700
-RRULE:FREQ=YEARLY;WKST=MO;INTERVAL=1;BYMONTH=11;BYDAY=1SU
-TZNAME:PST
-END:STANDARD
-BEGIN:DAYLIGHT
-DTSTART:19710101T020000
-TZOFFSETTO:-0700
-TZOFFSETFROM:-0800
-RRULE:FREQ=YEARLY;WKST=MO;INTERVAL=1;BYMONTH=3;BYDAY=2SU
-TZNAME:PDT
-END:DAYLIGHT
-END:VTIMEZONE
-BEGIN:VEVENT
-UID:623c13c0-6c2b-45d6-a12b-c33ad61c4868
-DESCRIPTION:IAM FOO
-RRULE:FREQ=MONTHLY;INTERVAL=1;BYDAY=1TU;UNTIL=20121231T100000
-SUMMARY:Crazy Event Thingy!
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;CN=Sahaja
- Lal;X-NUM-GUESTS=0:mailto:calmozilla1@gmail.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=NEEDS-ACTION;CN=ja
- mes@lightsofapollo.com;X-NUM-GUESTS=0:mailto:james@lightsofapollo.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=NEEDS-ACTION;CN=ia
- m.revelation@gmail.com;X-NUM-GUESTS=0:mailto:iam.revelation@gmail.com
-LOCATION:PLACE
-ORGANIZER;CN=James Lal:mailto:jlal@mozilla.com
-DTSTART;TZID=America/Los_Angeles:20121002T100000
-DTEND;TZID=America/Los_Angeles:20121002T103000
-STATUS:CONFIRMED
-CLASS:PUBLIC
-TRANSP:OPAQUE
-LAST-MODIFIED:20120912T171506Z
-DTSTAMP:20120912T171506Z
-SEQUENCE:0
-RDATE;TZID=America/Los_Angeles:20121110T100000
-RDATE;TZID=America/Los_Angeles:20121105T100000
-BEGIN:VALARM
-ACTION:DISPLAY
-TRIGGER;RELATED=START:-PT5M
-DESCRIPTION:Reminder
-END:VALARM
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/recur_instances_with_modifications.ics b/includes/composer/vendor/om/icalparser/tests/cal/recur_instances_with_modifications.ics
deleted file mode 100644
index dcaef06..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/recur_instances_with_modifications.ics
+++ /dev/null
@@ -1,63 +0,0 @@
-BEGIN:VCALENDAR
-PRODID:-//Google Inc//Google Calendar 70.9054//EN
-VERSION:2.0
-CALSCALE:GREGORIAN
-METHOD:PUBLISH
-X-WR-CALNAME:School Board
-X-WR-TIMEZONE:America/Chicago
-X-WR-CALDESC:
-BEGIN:VTIMEZONE
-TZID:America/Chicago
-X-LIC-LOCATION:America/Chicago
-BEGIN:DAYLIGHT
-TZOFFSETFROM:-0600
-TZOFFSETTO:-0500
-TZNAME:CDT
-DTSTART:19700308T020000
-RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=2SU
-END:DAYLIGHT
-BEGIN:STANDARD
-TZOFFSETFROM:-0500
-TZOFFSETTO:-0600
-TZNAME:CST
-DTSTART:19701101T020000
-RRULE:FREQ=YEARLY;BYMONTH=11;BYDAY=1SU
-END:STANDARD
-END:VTIMEZONE
-BEGIN:VEVENT
-DTSTART;TZID=America/Chicago:20160808T180000
-DTEND;TZID=America/Chicago:20160808T203000
-DTSTAMP:20160718T160226Z
-UID:kpgr4590djmi89l3sv51gmalrc@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;CN=School
- Board;X-NUM-GUESTS=0:mailto:aliceisd.net_7hatmpq9uek3a1h6if0r0sn5bc@group.
- calendar.google.com
-RECURRENCE-ID;TZID=America/Chicago:20160808T183000
-CREATED:20150715T183809Z
-DESCRIPTION:
-LAST-MODIFIED:20160718T155538Z
-LOCATION:
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Regular Board Meeting Modified
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;TZID=America/Chicago:20150810T183000
-DTEND;TZID=America/Chicago:20150810T210000
-RRULE:FREQ=MONTHLY;UNTIL=20180709T233000Z;BYDAY=2MO
-DTSTAMP:20160718T160226Z
-UID:kpgr4590djmi89l3sv51gmalrc@google.com
-ATTENDEE;CUTYPE=INDIVIDUAL;ROLE=REQ-PARTICIPANT;PARTSTAT=ACCEPTED;CN=School
- Board;X-NUM-GUESTS=0:mailto:aliceisd.net_7hatmpq9uek3a1h6if0r0sn5bc@group.
- calendar.google.com
-CREATED:20150715T183809Z
-DESCRIPTION:
-LAST-MODIFIED:20160718T155538Z
-LOCATION:
-SEQUENCE:0
-STATUS:CONFIRMED
-SUMMARY:Regular Board Meeting
-TRANSP:OPAQUE
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/recur_instances_with_modifications_and_interval.ics b/includes/composer/vendor/om/icalparser/tests/cal/recur_instances_with_modifications_and_interval.ics
deleted file mode 100644
index 202393e..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/recur_instances_with_modifications_and_interval.ics
+++ /dev/null
@@ -1,578 +0,0 @@
-BEGIN:VCALENDAR
-PRODID:-//Google Inc//Google Calendar 70.9054//EN
-VERSION:2.0
-CALSCALE:GREGORIAN
-METHOD:PUBLISH
-X-WR-CALNAME:SB-1213
-X-WR-TIMEZONE:America/Denver
-X-WR-CALDESC:
-BEGIN:VTIMEZONE
-TZID:America/New_York
-X-LIC-LOCATION:America/New_York
-BEGIN:DAYLIGHT
-TZOFFSETFROM:-0500
-TZOFFSETTO:-0400
-TZNAME:EDT
-DTSTART:19700308T020000
-RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=2SU
-END:DAYLIGHT
-BEGIN:STANDARD
-TZOFFSETFROM:-0400
-TZOFFSETTO:-0500
-TZNAME:EST
-DTSTART:19701101T020000
-RRULE:FREQ=YEARLY;BYMONTH=11;BYDAY=1SU
-END:STANDARD
-END:VTIMEZONE
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170602
-DTEND;VALUE=DATE:20170603
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170601
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:4
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170531
-DTEND;VALUE=DATE:20170601
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170530
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:4
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170524
-DTEND;VALUE=DATE:20170525
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170524
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:5
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170216
-DTEND;VALUE=DATE:20170217
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170215
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170214
-DTEND;VALUE=DATE:20170215
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170213
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170210
-DTEND;VALUE=DATE:20170211
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170209
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170208
-DTEND;VALUE=DATE:20170209
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170207
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170206
-DTEND;VALUE=DATE:20170207
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170205
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170202
-DTEND;VALUE=DATE:20170203
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170201
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170131
-DTEND;VALUE=DATE:20170201
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170130
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170127
-DTEND;VALUE=DATE:20170128
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170126
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170125
-DTEND;VALUE=DATE:20170126
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170124
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170123
-DTEND;VALUE=DATE:20170124
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170122
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170119
-DTEND;VALUE=DATE:20170120
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170118
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170113
-DTEND;VALUE=DATE:20170114
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170112
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170111
-DTEND;VALUE=DATE:20170112
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170110
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170109
-DTEND;VALUE=DATE:20170110
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170108
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170105
-DTEND;VALUE=DATE:20170106
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170104
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170103
-DTEND;VALUE=DATE:20170104
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170102
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20161122
-DTEND;VALUE=DATE:20161123
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20161121
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20161118
-DTEND;VALUE=DATE:20161119
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20161117
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20161116
-DTEND;VALUE=DATE:20161117
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20161115
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20161114
-DTEND;VALUE=DATE:20161115
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20161113
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20161110
-DTEND;VALUE=DATE:20161111
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20161109
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20160923
-DTEND;VALUE=DATE:20160924
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20160922
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20160921
-DTEND;VALUE=DATE:20160922
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20160920
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20160919
-DTEND;VALUE=DATE:20160920
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20160916
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20160915
-DTEND;VALUE=DATE:20160916
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20160914
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20160913
-DTEND;VALUE=DATE:20160914
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20160912
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20160909
-DTEND;VALUE=DATE:20160910
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20160908
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20160907
-DTEND;VALUE=DATE:20160908
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20160906
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20160817
-DTEND;VALUE=DATE:20160818
-EXDATE;VALUE=DATE:20160821
-EXDATE;VALUE=DATE:20160827
-EXDATE;VALUE=DATE:20160904
-EXDATE;VALUE=DATE:20160910
-EXDATE;VALUE=DATE:20160918
-EXDATE;VALUE=DATE:20160924
-EXDATE;VALUE=DATE:20160926
-EXDATE;VALUE=DATE:20161002
-EXDATE;VALUE=DATE:20161008
-EXDATE;VALUE=DATE:20161016
-EXDATE;VALUE=DATE:20161022
-EXDATE;VALUE=DATE:20161030
-EXDATE;VALUE=DATE:20161105
-EXDATE;VALUE=DATE:20161107
-EXDATE;VALUE=DATE:20161111
-EXDATE;VALUE=DATE:20161119
-EXDATE;VALUE=DATE:20161123
-EXDATE;VALUE=DATE:20161125
-EXDATE;VALUE=DATE:20161127
-EXDATE;VALUE=DATE:20161203
-EXDATE;VALUE=DATE:20161211
-EXDATE;VALUE=DATE:20161217
-EXDATE;VALUE=DATE:20161219
-EXDATE;VALUE=DATE:20161221
-EXDATE;VALUE=DATE:20161223
-EXDATE;VALUE=DATE:20161225
-EXDATE;VALUE=DATE:20161227
-EXDATE;VALUE=DATE:20161229
-EXDATE;VALUE=DATE:20161231
-EXDATE;VALUE=DATE:20170106
-EXDATE;VALUE=DATE:20170114
-EXDATE;VALUE=DATE:20170116
-EXDATE;VALUE=DATE:20170120
-EXDATE;VALUE=DATE:20170128
-EXDATE;VALUE=DATE:20170203
-EXDATE;VALUE=DATE:20170211
-EXDATE;VALUE=DATE:20170217
-EXDATE;VALUE=DATE:20170219
-EXDATE;VALUE=DATE:20170225
-EXDATE;VALUE=DATE:20170305
-EXDATE;VALUE=DATE:20170311
-EXDATE;VALUE=DATE:20170319
-EXDATE;VALUE=DATE:20170325
-EXDATE;VALUE=DATE:20170327
-EXDATE;VALUE=DATE:20170402
-EXDATE;VALUE=DATE:20170408
-EXDATE;VALUE=DATE:20170410
-EXDATE;VALUE=DATE:20170412
-EXDATE;VALUE=DATE:20170414
-EXDATE;VALUE=DATE:20170416
-EXDATE;VALUE=DATE:20170422
-EXDATE;VALUE=DATE:20170430
-EXDATE;VALUE=DATE:20170506
-EXDATE;VALUE=DATE:20170514
-EXDATE;VALUE=DATE:20170520
-EXDATE;VALUE=DATE:20170528
-RRULE:FREQ=DAILY;UNTIL=20170601;INTERVAL=2
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:B
-TRANSP:TRANSPARENT
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20170601
-DTEND;VALUE=DATE:20170602
-DTSTAMP:20160829T191852Z
-UID:h9i3hjtisl53goaljdcdb681fc@google.com
-RECURRENCE-ID;VALUE=DATE:20170526
-CREATED:20160829T134437Z
-DESCRIPTION:
-LAST-MODIFIED:20160829T134450Z
-LOCATION:
-SEQUENCE:6
-STATUS:CONFIRMED
-SUMMARY:A
-TRANSP:TRANSPARENT
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/recur_instances_with_modifications_to_first_day.ics b/includes/composer/vendor/om/icalparser/tests/cal/recur_instances_with_modifications_to_first_day.ics
deleted file mode 100755
index 7dd2939..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/recur_instances_with_modifications_to_first_day.ics
+++ /dev/null
@@ -1,57 +0,0 @@
-BEGIN:VCALENDAR
-PRODID:-//Google Inc//Google Calendar 70.9054//EN
-VERSION:2.0
-CALSCALE:GREGORIAN
-METHOD:PUBLISH
-X-WR-CALNAME:G. C. Hawley Middle School
-X-WR-TIMEZONE:America/New_York
-X-WR-CALDESC:This is the website calendar for GC Hawley MS.
-BEGIN:VTIMEZONE
-TZID:America/New_York
-X-LIC-LOCATION:America/New_York
-BEGIN:DAYLIGHT
-TZOFFSETFROM:-0500
-TZOFFSETTO:-0400
-TZNAME:EDT
-DTSTART:19700308T020000
-RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=2SU
-END:DAYLIGHT
-BEGIN:STANDARD
-TZOFFSETFROM:-0400
-TZOFFSETTO:-0500
-TZNAME:EST
-DTSTART:19701101T020000
-RRULE:FREQ=YEARLY;BYMONTH=11;BYDAY=1SU
-END:STANDARD
-END:VTIMEZONE
-BEGIN:VEVENT
-DTSTART;TZID=America/New_York:20160915T123000
-DTEND;TZID=America/New_York:20160915T160000
-RRULE:FREQ=MONTHLY;UNTIL=20161020T035959Z;BYDAY=3TH
-DTSTAMP:20160913T221241Z
-UID:d28i2lkvhp2qb2v7n6oe9poikc@google.com
-CREATED:20160705T193430Z
-DESCRIPTION:Professional Development for Staff
-LAST-MODIFIED:20160825T003008Z
-LOCATION:
-SEQUENCE:1
-STATUS:CONFIRMED
-SUMMARY:Early Release for Students
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;TZID=America/New_York:20160929T123000
-DTEND;TZID=America/New_York:20160929T160000
-DTSTAMP:20160913T221241Z
-UID:d28i2lkvhp2qb2v7n6oe9poikc@google.com
-RECURRENCE-ID;TZID=America/New_York:20160915T123000
-CREATED:20160705T193430Z
-DESCRIPTION:Professional Development for Staff
-LAST-MODIFIED:20160825T003008Z
-LOCATION:
-SEQUENCE:2
-STATUS:CONFIRMED
-SUMMARY:Early Release for Students
-TRANSP:OPAQUE
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/rrule_interval.ics b/includes/composer/vendor/om/icalparser/tests/cal/rrule_interval.ics
deleted file mode 100644
index 262721a..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/rrule_interval.ics
+++ /dev/null
@@ -1,34 +0,0 @@
-BEGIN:VCALENDAR
-PRODID:-//Google Inc//Google Calendar 70.9054//EN
-VERSION:2.0
-CALSCALE:GREGORIAN
-X-WR-CALNAME:calmozilla1@gmail.com
-X-WR-TIMEZONE:America/Los_Angeles
-BEGIN:VTIMEZONE
-TZID:America/Los_Angeles
-X-LIC-LOCATION:America/Los_Angeles
-BEGIN:DAYLIGHT
-TZOFFSETFROM:-0800
-TZOFFSETTO:-0700
-TZNAME:PDT
-DTSTART:19700308T020000
-RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=2SU
-END:DAYLIGHT
-BEGIN:STANDARD
-TZOFFSETFROM:-0700
-TZOFFSETTO:-0800
-TZNAME:PST
-DTSTART:19701101T020000
-RRULE:FREQ=YEARLY;BYMONTH=11;BYDAY=1SU
-END:STANDARD
-END:VTIMEZONE
-BEGIN:VEVENT
-DTSTART;TZID=America/Los_Angeles:20230131T050000
-DTEND;TZID=America/Los_Angeles:20230131T060000
-RRULE:FREQ=WEEKLY;WKST=MO;UNTIL=20230228T090000;INTERVAL=2;BYDAY=TU
-DTSTAMP:20120803T221236Z
-DESCRIPTION:
-SUMMARY:Every day recurring
-TRANSP:OPAQUE
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/url.ics b/includes/composer/vendor/om/icalparser/tests/cal/url.ics
deleted file mode 100644
index 8ae6620..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/url.ics
+++ /dev/null
@@ -1,32 +0,0 @@
-BEGIN:VCALENDAR
-VERSION:2.0
-X-WR-CALNAME:URL
-CALSCALE:GREGORIAN
-BEGIN:VTIMEZONE
-TZID:Europe/Berlin
-TZURL:http://tzurl.org/zoneinfo-outlook/Europe/Berlin
-X-LIC-LOCATION:Europe/Berlin
-BEGIN:DAYLIGHT
-TZOFFSETFROM:+0100
-TZOFFSETTO:+0200
-TZNAME:CEST
-DTSTART:19700329T020000
-RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=-1SU
-END:DAYLIGHT
-BEGIN:STANDARD
-TZOFFSETFROM:+0200
-TZOFFSETTO:+0100
-TZNAME:CET
-DTSTART:19701025T030000
-RRULE:FREQ=YEARLY;BYMONTH=10;BYDAY=-1SU
-END:STANDARD
-END:VTIMEZONE
-BEGIN:VEVENT
-DTSTAMP:20191106T093607Z
-UID:20191106T093607Z-791992399@marudot.com
-DTSTART;VALUE=DATE:20191101
-DTEND;VALUE=DATE:20191102
-SUMMARY:Example event
-URL:https%3A%2F%2Fgithub.com%2FOzzyCzech%2Ficalparser%2F
-END:VEVENT
-END:VCALENDAR \ No newline at end of file
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/utc_negative_zero.ics b/includes/composer/vendor/om/icalparser/tests/cal/utc_negative_zero.ics
deleted file mode 100755
index e61ad9a..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/utc_negative_zero.ics
+++ /dev/null
@@ -1,27 +0,0 @@
-BEGIN:VCALENDAR
-VERSION:2.0
-PRODID:Zimbra-Calendar-Provider
-BEGIN:VTIMEZONE
-TZID:Etc/GMT
-BEGIN:STANDARD
-DTSTART:19710101T000000
-TZOFFSETTO:-0000
-TZOFFSETFROM:-0000
-TZNAME:GMT
-END:STANDARD
-END:VTIMEZONE
-BEGIN:VEVENT
-UID:d118e997-3683-4552-8fe8-57c641f1f179
-SUMMARY:And another
-ORGANIZER;CN=Sahaja Lal:mailto:calmozilla1@yahoo.com
-DTSTART;TZID=Etc/GMT:20120821T210000
-DTEND;TZID=Etc/GMT:20120821T213000
-STATUS:CONFIRMED
-CLASS:PUBLIC
-X-MICROSOFT-CDO-INTENDEDSTATUS:BUSY
-TRANSP:OPAQUE
-X-MICROSOFT-DISALLOW-COUNTER:TRUE
-DTSTAMP:20120817T032509Z
-SEQUENCE:0
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/weird_windows_timezones.ics b/includes/composer/vendor/om/icalparser/tests/cal/weird_windows_timezones.ics
deleted file mode 100644
index 5d736a1..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/weird_windows_timezones.ics
+++ /dev/null
@@ -1,237 +0,0 @@
-BEGIN:VCALENDAR
-METHOD:PUBLISH
-PRODID:Microsoft Exchange Server 2010
-VERSION:2.0
-X-WR-CALNAME:High School Counselors Office
-BEGIN:VTIMEZONE
-TZID:(UTC-06:00) Central Time (US & Canada)
-BEGIN:STANDARD
-DTSTART:16010101T020000
-TZOFFSETFROM:-0500
-TZOFFSETTO:-0600
-RRULE:FREQ=YEARLY;INTERVAL=1;BYDAY=1SU;BYMONTH=11
-END:STANDARD
-BEGIN:DAYLIGHT
-DTSTART:16010101T020000
-TZOFFSETFROM:-0600
-TZOFFSETTO:-0500
-RRULE:FREQ=YEARLY;INTERVAL=1;BYDAY=2SU;BYMONTH=3
-END:DAYLIGHT
-END:VTIMEZONE
-BEGIN:VTIMEZONE
-TZID:Eastern Time
-BEGIN:STANDARD
-DTSTART:16010101T020000
-TZOFFSETFROM:-0400
-TZOFFSETTO:-0500
-RRULE:FREQ=YEARLY;INTERVAL=1;BYDAY=1SU;BYMONTH=11
-END:STANDARD
-BEGIN:DAYLIGHT
-DTSTART:16010101T020000
-TZOFFSETFROM:-0500
-TZOFFSETTO:-0400
-RRULE:FREQ=YEARLY;INTERVAL=1;BYDAY=2SU;BYMONTH=3
-END:DAYLIGHT
-END:VTIMEZONE
-BEGIN:VTIMEZONE
-TZID:Greenwich Standard Time
-BEGIN:STANDARD
-DTSTART:16010101T000000
-TZOFFSETFROM:+0000
-TZOFFSETTO:+0000
-END:STANDARD
-BEGIN:DAYLIGHT
-DTSTART:16010101T000000
-TZOFFSETFROM:+0000
-TZOFFSETTO:+0000
-END:DAYLIGHT
-END:VTIMEZONE
-BEGIN:VEVENT
-DESCRIPTION:All seniors MUST make an appointment in the counseling office\,
- to visit with a counselor and go over their application for graduation.\n
-UID:040000008200E00074C5B7101A82E008000000004A8A50D0FC09D201000000000000000
- 010000000D27D08FB73761145BC661D80CE521463
-SUMMARY:Senior Appointment Sign-up
-DTSTART;VALUE=DATE:20160914
-DTEND;VALUE=DATE:20160915
-CLASS:PUBLIC
-PRIORITY:5
-DTSTAMP:20160916T193959Z
-TRANSP:OPAQUE
-STATUS:CONFIRMED
-SEQUENCE:0
-LOCATION:
-X-MICROSOFT-CDO-APPT-SEQUENCE:0
-X-MICROSOFT-CDO-BUSYSTATUS:FREE
-X-MICROSOFT-CDO-INTENDEDSTATUS:BUSY
-X-MICROSOFT-CDO-ALLDAYEVENT:TRUE
-X-MICROSOFT-CDO-IMPORTANCE:1
-X-MICROSOFT-CDO-INSTTYPE:0
-X-MICROSOFT-DISALLOW-COUNTER:FALSE
-END:VEVENT
-BEGIN:VEVENT
-DESCRIPTION:Registration for the PSAT test begins in the counseling office.
- The test is open to any junior or sophomore. The test is $15 and must be
- paid at the time of registration. Test date is Wednesday\, October 19th.\n
-UID:040000008200E00074C5B7101A82E008000000004B8D8376DB0AD201000000000000000
- 010000000CF196AE75B9C684C9E51C33A403CA455
-SUMMARY:PSAT Registration
-DTSTART;VALUE=DATE:20160915
-DTEND;VALUE=DATE:20160916
-CLASS:PUBLIC
-PRIORITY:5
-DTSTAMP:20160916T193959Z
-TRANSP:OPAQUE
-STATUS:CONFIRMED
-SEQUENCE:0
-LOCATION:
-X-MICROSOFT-CDO-APPT-SEQUENCE:0
-X-MICROSOFT-CDO-BUSYSTATUS:FREE
-X-MICROSOFT-CDO-INTENDEDSTATUS:BUSY
-X-MICROSOFT-CDO-ALLDAYEVENT:TRUE
-X-MICROSOFT-CDO-IMPORTANCE:1
-X-MICROSOFT-CDO-INSTTYPE:0
-X-MICROSOFT-DISALLOW-COUNTER:FALSE
-END:VEVENT
-BEGIN:VEVENT
-DESCRIPTION:Financial Aid night for all seniors and their parents at 7:00pm
- in the high school auditorium.\n
-UID:040000008200E00074C5B7101A82E00800000000A3D802C7DB0AD201000000000000000
- 0100000004690B516982D4841A6A5808F1BF285D2
-SUMMARY:Financial Aid NIght
-DTSTART;TZID="(UTC-06:00) Central Time (US & Canada)":20160919T190000
-DTEND;TZID="(UTC-06:00) Central Time (US & Canada)":20160919T200000
-CLASS:PUBLIC
-PRIORITY:5
-DTSTAMP:20160916T193959Z
-TRANSP:OPAQUE
-STATUS:CONFIRMED
-SEQUENCE:0
-LOCATION:
-X-MICROSOFT-CDO-APPT-SEQUENCE:0
-X-MICROSOFT-CDO-BUSYSTATUS:BUSY
-X-MICROSOFT-CDO-INTENDEDSTATUS:BUSY
-X-MICROSOFT-CDO-ALLDAYEVENT:FALSE
-X-MICROSOFT-CDO-IMPORTANCE:1
-X-MICROSOFT-CDO-INSTTYPE:0
-X-MICROSOFT-DISALLOW-COUNTER:FALSE
-END:VEVENT
-BEGIN:VEVENT
-DESCRIPTION:This is the last day to register for the PSAT test in October!
- Please see the counseling office if you would like to register.\n
-UID:040000008200E00074C5B7101A82E00800000000DE3BE28BDB0AD201000000000000000
- 0100000008C413809A1751A4E82CEB8F1BB526C61
-SUMMARY:PSAT Test registration ends
-DTSTART;VALUE=DATE:20160923
-DTEND;VALUE=DATE:20160924
-CLASS:PUBLIC
-PRIORITY:5
-DTSTAMP:20160916T193959Z
-TRANSP:OPAQUE
-STATUS:CONFIRMED
-SEQUENCE:0
-LOCATION:
-X-MICROSOFT-CDO-APPT-SEQUENCE:0
-X-MICROSOFT-CDO-BUSYSTATUS:FREE
-X-MICROSOFT-CDO-INTENDEDSTATUS:BUSY
-X-MICROSOFT-CDO-ALLDAYEVENT:TRUE
-X-MICROSOFT-CDO-IMPORTANCE:1
-X-MICROSOFT-CDO-INSTTYPE:0
-X-MICROSOFT-DISALLOW-COUNTER:FALSE
-END:VEVENT
-BEGIN:VEVENT
-DESCRIPTION:College Application Day for all interested seniors! The Bank of
- North Dakota is waiving the application fee for any student to apply to a
- North Dakota college or university. Counselors and college staff will be
- assisting students with their applications periods 1-3 in the high school
- library!\n
-UID:040000008200E00074C5B7101A82E0080000000019668644DC0AD201000000000000000
- 010000000DB1D0B39660D4045A6AC5C232EB0D76B
-SUMMARY:College Application Day
-DTSTART;TZID="(UTC-06:00) Central Time (US & Canada)":20161005T080000
-DTEND;TZID="(UTC-06:00) Central Time (US & Canada)":20161005T081500
-CLASS:PUBLIC
-PRIORITY:5
-DTSTAMP:20160916T193959Z
-TRANSP:OPAQUE
-STATUS:CONFIRMED
-SEQUENCE:0
-LOCATION:
-X-MICROSOFT-CDO-APPT-SEQUENCE:0
-X-MICROSOFT-CDO-BUSYSTATUS:BUSY
-X-MICROSOFT-CDO-INTENDEDSTATUS:BUSY
-X-MICROSOFT-CDO-ALLDAYEVENT:FALSE
-X-MICROSOFT-CDO-IMPORTANCE:1
-X-MICROSOFT-CDO-INSTTYPE:0
-X-MICROSOFT-DISALLOW-COUNTER:FALSE
-END:VEVENT
-BEGIN:VEVENT
-DESCRIPTION:PSAT Test in the high school auditorium for all students that r
- egistered. Please report to the auditorium at 8:30am with a sharpened #2 p
- encil and calculator.\n
-UID:040000008200E00074C5B7101A82E00800000000E68A2E67DC0AD201000000000000000
- 01000000080E5BC118E41944ABC1C94B815AB2235
-SUMMARY:PSAT Test
-DTSTART;VALUE=DATE:20161019
-DTEND;VALUE=DATE:20161020
-CLASS:PUBLIC
-PRIORITY:5
-DTSTAMP:20160916T193959Z
-TRANSP:OPAQUE
-STATUS:CONFIRMED
-SEQUENCE:0
-LOCATION:
-X-MICROSOFT-CDO-APPT-SEQUENCE:0
-X-MICROSOFT-CDO-BUSYSTATUS:FREE
-X-MICROSOFT-CDO-INTENDEDSTATUS:BUSY
-X-MICROSOFT-CDO-ALLDAYEVENT:TRUE
-X-MICROSOFT-CDO-IMPORTANCE:1
-X-MICROSOFT-CDO-INSTTYPE:0
-X-MICROSOFT-DISALLOW-COUNTER:FALSE
-END:VEVENT
-BEGIN:VEVENT
-DESCRIPTION:North Dakota State Assessment for all juniors (periods 2-4).\n
-UID:040000008200E00074C5B7101A82E008000000002EB6D123DD0AD201000000000000000
- 01000000061F7AF4CD0D2C84B9C6A916D2C633339
-SUMMARY:NDSA Science Assessment
-DTSTART;TZID="(UTC-06:00) Central Time (US & Canada)":20161025T091500
-DTEND;TZID="(UTC-06:00) Central Time (US & Canada)":20161025T114500
-CLASS:PUBLIC
-PRIORITY:5
-DTSTAMP:20160916T193959Z
-TRANSP:OPAQUE
-STATUS:CONFIRMED
-SEQUENCE:0
-LOCATION:
-X-MICROSOFT-CDO-APPT-SEQUENCE:0
-X-MICROSOFT-CDO-BUSYSTATUS:BUSY
-X-MICROSOFT-CDO-INTENDEDSTATUS:BUSY
-X-MICROSOFT-CDO-ALLDAYEVENT:FALSE
-X-MICROSOFT-CDO-IMPORTANCE:1
-X-MICROSOFT-CDO-INSTTYPE:0
-X-MICROSOFT-DISALLOW-COUNTER:FALSE
-END:VEVENT
-BEGIN:VEVENT
-DESCRIPTION:\n
-UID:040000008200E00074C5B7101A82E0080000000052D533E856D6D301000000000000000
- 010000000568B47E6EF679B4B812809E063BB64E1
-SUMMARY:Test Event
-DTSTART;TZID=Eastern Time:20180419T103000
-DTEND;TZID=Eastern Time:20180419T113000
-CLASS:PUBLIC
-PRIORITY:5
-DTSTAMP:20180417T144309Z
-TRANSP:OPAQUE
-STATUS:CONFIRMED
-SEQUENCE:0
-LOCATION:Boardroom
-X-MICROSOFT-CDO-APPT-SEQUENCE:0
-X-MICROSOFT-CDO-BUSYSTATUS:BUSY
-X-MICROSOFT-CDO-INTENDEDSTATUS:BUSY
-X-MICROSOFT-CDO-ALLDAYEVENT:FALSE
-X-MICROSOFT-CDO-IMPORTANCE:1
-X-MICROSOFT-CDO-INSTTYPE:0
-X-MICROSOFT-DONOTFORWARDMEETING:FALSE
-X-MICROSOFT-DISALLOW-COUNTER:FALSE
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/cal/wrong_dates.ics b/includes/composer/vendor/om/icalparser/tests/cal/wrong_dates.ics
deleted file mode 100644
index 0468020..0000000
--- a/includes/composer/vendor/om/icalparser/tests/cal/wrong_dates.ics
+++ /dev/null
@@ -1,37 +0,0 @@
-BEGIN:VCALENDAR
-PRODID:-//Google Inc//Google Calendar 70.9054//EN
-VERSION:2.0
-CALSCALE:GREGORIAN
-X-WR-CALNAME:calmozilla1@gmail.com
-X-WR-TIMEZONE:America/Los_Angeles
-BEGIN:VTIMEZONE
-TZID:America/Los_Angeles
-X-LIC-LOCATION:America/Los_Angeles
-END:VTIMEZONE
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:2014929
-DTEND;VALUE=DATE:20140930
-UID:dn4vrfmfn5p05roahsopg57h48@google.com
-CREATED:20120724T212411Z
-DESCRIPTION:
-LAST-MODIFIED:20120724T212411Z
-LOCATION:
-SEQUENCE:0
-STATUS:CONFIRMED
-SUMMARY:Really long event name thing
-TRANSP:OPAQUE
-END:VEVENT
-BEGIN:VEVENT
-DTSTART;VALUE=DATE:20140929
-DTEND;VALUE=DATE:2014930
-UID:dn4vrfmfn5p05roahsopg57h48@google.com
-CREATED:20120724T212411Z
-DESCRIPTION:
-LAST-MODIFIED:20120724T212411Z
-LOCATION:
-SEQUENCE:0
-STATUS:CONFIRMED
-SUMMARY:Really long event name thing
-TRANSP:OPAQUE
-END:VEVENT
-END:VCALENDAR
diff --git a/includes/composer/vendor/om/icalparser/tests/event.attachements.phpt b/includes/composer/vendor/om/icalparser/tests/event.attachements.phpt
deleted file mode 100644
index 1218fb7..0000000
--- a/includes/composer/vendor/om/icalparser/tests/event.attachements.phpt
+++ /dev/null
@@ -1,26 +0,0 @@
-<?php
-/**
- * @author PC Drew <pc@soprisapps.com>
- */
-
-use om\IcalParser;
-use Tester\Assert;
-use Tester\Environment;
-use function tests\test;
-
-require_once __DIR__ . '/bootstrap.php';
-date_default_timezone_set('Europe/Prague');
-
-test('Event with multiple ATTACHMENTS', function () {
- $cal = new IcalParser();
- $cal->parseFile(__DIR__ . '/cal/multiple_attachments.ics');
- $first = $cal->getEvents()->getIterator()->current();
-
- // Backwards compatibility, there is only ever one key displayed
- Assert::hasKey('ATTACH', $first);
- Assert::type('string', $first['ATTACH']);
-
- // The new key 'ATTACHMENTS' is an array with 1 or more attachments
- Assert::type('array', $first['ATTACHMENTS']);
- Assert::count(2, $first['ATTACHMENTS']);
-});
diff --git a/includes/composer/vendor/om/icalparser/tests/event.categories.phpt b/includes/composer/vendor/om/icalparser/tests/event.categories.phpt
deleted file mode 100644
index 43c56cb..0000000
--- a/includes/composer/vendor/om/icalparser/tests/event.categories.phpt
+++ /dev/null
@@ -1,25 +0,0 @@
-<?php
-/**
- * Copyright (c) 2004-2022 Roman Ožana (https://ozana.cz)
- *
- * @license BSD-3-Clause
- * @author Roman Ožana <roman@ozana.cz>
- */
-
-use om\IcalParser;
-use Tester\Assert;
-use function tests\test;
-
-require_once __DIR__ . '/bootstrap.php';
-date_default_timezone_set('Europe/Prague');
-
-test('Multiple categories test', function () {
- $cal = new IcalParser();
- $cal->parseFile(__DIR__ . '/cal/multiple_categories.ics');
- $events = $cal->getEvents()->sorted();
-
- foreach ($events as $event) {
- Assert::type('array', $event['CATEGORIES']);
- Assert::same(['one', 'two', 'three'], $event['CATEGORIES']);
- }
-});
diff --git a/includes/composer/vendor/om/icalparser/tests/event.dates.phpt b/includes/composer/vendor/om/icalparser/tests/event.dates.phpt
deleted file mode 100644
index 6af95ae..0000000
--- a/includes/composer/vendor/om/icalparser/tests/event.dates.phpt
+++ /dev/null
@@ -1,25 +0,0 @@
-<?php
-/**
- * Copyright (c) 2004-2022 Roman Ožana (https://ozana.cz)
- *
- * @license BSD-3-Clause
- * @author Roman Ožana <roman@ozana.cz>
- */
-
-use om\IcalParser;
-use Tester\Assert;
-use function tests\test;
-
-require_once __DIR__ . '/bootstrap.php';
-
-test('Events with wrong dates', function () {
- $cal = new IcalParser();
- $cal->parseFile(__DIR__ . '/cal/wrong_dates.ics');
- $events = $cal->getEvents()->sorted();
- Assert::same('29.9.2014 00:00:00', $events[1]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::same(null, $events[1]['DTEND']);
-
- Assert::same(null, $events[0]['DTSTART']);
- Assert::same('30.9.2014 00:00:00', $events[0]['DTEND']->format('j.n.Y H:i:s'));
-});
-
diff --git a/includes/composer/vendor/om/icalparser/tests/event.description.phpt b/includes/composer/vendor/om/icalparser/tests/event.description.phpt
deleted file mode 100644
index 8426e32..0000000
--- a/includes/composer/vendor/om/icalparser/tests/event.description.phpt
+++ /dev/null
@@ -1,34 +0,0 @@
-<?php
-/**
- * Copyright (c) 2004-2022 Roman Ožana (https://ozana.cz)
- *
- * @license BSD-3-Clause
- * @author Roman Ožana <roman@ozana.cz>
- */
-
-use om\IcalParser;
-use Tester\Assert;
-use function tests\test;
-
-require_once __DIR__ . '/bootstrap.php';
-date_default_timezone_set('Europe/Prague');
-
-test('Blank description test', function () {
- $cal = new IcalParser();
- $results = $cal->parseFile(__DIR__ . '/cal/blank_description.ics');
- $first = $cal->getEvents()->getIterator()->current();
-
- Assert::hasKey('DESCRIPTION', $first);
- Assert::same('', $first['DESCRIPTION']);
-});
-
-test('Multiple lines description', function () {
- $cal = new IcalParser();
- $cal->parseFile(__DIR__ . '/cal/multiline_description.ics');
- $events = $cal->getEvents()->sorted();
- $first = $events->getIterator()->current();
-
- Assert::same('30.6.2012 06:00:00', $first['DTSTART']->format('j.n.Y H:i:s'));
- Assert::same("Here is a description that spans multiple lines!\n\nThis should be on a new line as well because the description contains newline characters.", $first['DESCRIPTION']);
-});
-
diff --git a/includes/composer/vendor/om/icalparser/tests/event.timezones.phpt b/includes/composer/vendor/om/icalparser/tests/event.timezones.phpt
deleted file mode 100644
index fcb708b..0000000
--- a/includes/composer/vendor/om/icalparser/tests/event.timezones.phpt
+++ /dev/null
@@ -1,39 +0,0 @@
-<?php
-/**
- * @author Marc Vachette <marc.vachette@gmail.com>
- */
-
-use om\IcalParser;
-use Tester\Assert;
-use function tests\test;
-
-require_once __DIR__ . '/bootstrap.php';
-date_default_timezone_set('Europe/Paris');
-
-test('Normal time zone', function () {
- $cal = new IcalParser();
- $cal->parseFile(__DIR__ . '/cal/blank_description.ics');
- Assert::same('America/Los_Angeles', $cal->timezone->getName());
-});
-
-test('Negative zero UTC timezone', function () {
- $cal = new IcalParser();
- $cal->parseFile(__DIR__ . '/cal/utc_negative_zero.ics');
- Assert::same('Etc/GMT', $cal->timezone->getName());
-});
-
-/**
- * Time zone with custom prefixes (Mozilla files tken from here: https://www.mozilla.org/en-US/projects/calendar/holidays/)
- */
-test('Time zone with custom prefixes', function () {
- $cal = new IcalParser();
- $cal->parseFile(__DIR__ . '/cal/FrenchHolidays.ics');
- Assert::same('Europe/Paris', $cal->timezone->getName());
-});
-
-test('Weird windows timezones', function () {
- $cal = new IcalParser();
- $cal->parseFile(__DIR__ . '/cal/weird_windows_timezones.ics');
- $cal->getEvents()->sorted();
- Assert::same('Atlantic/Reykjavik', $cal->timezone->getName());
-});
diff --git a/includes/composer/vendor/om/icalparser/tests/event.url.phpt b/includes/composer/vendor/om/icalparser/tests/event.url.phpt
deleted file mode 100644
index b39d3e3..0000000
--- a/includes/composer/vendor/om/icalparser/tests/event.url.phpt
+++ /dev/null
@@ -1,22 +0,0 @@
-<?php
-/**
- * Copyright (c) 2004-2022 Roman Ožana (https://ozana.cz)
- *
- * @license BSD-3-Clause
- * @author Roman Ožana <roman@ozana.cz>
- */
-
-use om\IcalParser;
-use Tester\Assert;
-use function tests\test;
-
-require_once __DIR__ . '/bootstrap.php';
-
-test('URL parsing check', function () {
- $cal = new IcalParser();
- $cal->parseFile(__DIR__ . '/cal/url.ics');
- $first = $cal->getEvents()->getIterator()->current();
-
- Assert::hasKey('URL', $first);
- Assert::same($first['URL'], urlencode('https://github.com/OzzyCzech/icalparser/'));
-});
diff --git a/includes/composer/vendor/om/icalparser/tests/events.recurring.phpt b/includes/composer/vendor/om/icalparser/tests/events.recurring.phpt
deleted file mode 100644
index 9606992..0000000
--- a/includes/composer/vendor/om/icalparser/tests/events.recurring.phpt
+++ /dev/null
@@ -1,260 +0,0 @@
-<?php
-/**
- * @author PC Drew <pc@schoolblocks.com>
- * @author Roman Ožana <roman@ozana.cz>
- */
-
-use om\IcalParser;
-use Tester\Assert;
-use function tests\test;
-
-require_once __DIR__ . '/bootstrap.php';
-
-test('Recurring instances finite', function () {
- $cal = new IcalParser();
-
- $cal->parseFile(__DIR__ . '/cal/recur_instances_finite.ics');
- $events = $cal->getEvents()->sorted();
-
-// DTSTART;TZID=America/Los_Angeles:20121002T100000
-// DTEND;TZID=America/Los_Angeles:20121002T103000
-// RRULE:FREQ=MONTHLY;INTERVAL=1;BYDAY=1TU;UNTIL=20121231T100000
-// RDATE;TZID=America/Los_Angeles:20121110T100000
-// RDATE;TZID=America/Los_Angeles:20121105T100000
- Assert::equal(5, $events->count());
- Assert::equal('2.10.2012 10:00:00', $events[0]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('5.11.2012 10:00:00', $events[1]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('6.11.2012 10:00:00', $events[2]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('10.11.2012 10:00:00', $events[3]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('4.12.2012 10:00:00', $events[4]['DTSTART']->format('j.n.Y H:i:s'));
-});
-
-test('Recurring instance check', function () {
- $cal = new IcalParser();
- $results = $cal->parseFile(__DIR__ . '/cal/recur_instances.ics');
- $events = $cal->getEvents()->sorted();
-
- $recurrences = [];
- foreach ($events as $i => $event) {
- $recurrences[] = $event['DTSTART'];
- }
-
-// DTSTART;TZID=America/Los_Angeles:20121002T100000
-// DTEND;TZID=America/Los_Angeles:20121002T103000
-// RRULE:FREQ=MONTHLY;INTERVAL=1;BYDAY=1TU
-// RDATE;TZID=America/Los_Angeles:20121105T100000
-// RDATE;TZID=America/Los_Angeles:20121110T100000,20121130T100000
-// EXDATE;TZID=America/Los_Angeles:20130402T100000
-// EXDATE;TZID=America/Los_Angeles:20121204T100000
-// EXDATE;TZID=America/Los_Angeles:20130205T100000
-// because there is no "UNTIL", we calculate until 3 years from now of repeating events
- $now = new DateTime('now');
- $diff = $now->diff(new DateTime('20121002T100000'));
- $count = ($diff->y + 3) * 12 + $diff->m;
- Assert::equal($count, count($recurrences));
- Assert::equal('02.10.2012 15:00:00', $recurrences[0]->format('d.m.Y H:i:s'));
- Assert::equal('06.11.2012 20:00:00', $recurrences[1]->format('d.m.Y H:i:s'));
- Assert::equal('10.11.2012 10:00:00', $recurrences[2]->format('d.m.Y H:i:s'));
- Assert::equal('30.11.2012 10:00:00', $recurrences[3]->format('d.m.Y H:i:s'));
- Assert::equal('01.01.2013 10:00:00', $recurrences[4]->format('d.m.Y H:i:s'));
- Assert::equal('05.03.2013 10:00:00', $recurrences[5]->format('d.m.Y H:i:s'));
- Assert::equal('07.05.2013 10:00:00', $recurrences[6]->format('d.m.Y H:i:s'));
- Assert::equal('04.06.2013 10:00:00', $recurrences[7]->format('d.m.Y H:i:s'));
- Assert::equal('02.07.2013 10:00:00', $recurrences[8]->format('d.m.Y H:i:s'));
- Assert::equal('06.08.2013 10:00:00', $recurrences[9]->format('d.m.Y H:i:s'));
- Assert::equal('03.09.2013 10:00:00', $recurrences[10]->format('d.m.Y H:i:s'));
- Assert::equal('01.10.2013 10:00:00', $recurrences[11]->format('d.m.Y H:i:s'));
- Assert::equal('05.11.2013 10:00:00', $recurrences[12]->format('d.m.Y H:i:s'));
- Assert::equal('03.12.2013 10:00:00', $recurrences[13]->format('d.m.Y H:i:s'));
- Assert::equal('07.01.2014 10:00:00', $recurrences[14]->format('d.m.Y H:i:s'));
- Assert::equal('04.02.2014 10:00:00', $recurrences[15]->format('d.m.Y H:i:s'));
- Assert::equal('04.03.2014 10:00:00', $recurrences[16]->format('d.m.Y H:i:s'));
- Assert::equal('01.04.2014 10:00:00', $recurrences[17]->format('d.m.Y H:i:s'));
- Assert::equal('06.05.2014 10:00:00', $recurrences[18]->format('d.m.Y H:i:s'));
- Assert::equal('03.06.2014 10:00:00', $recurrences[19]->format('d.m.Y H:i:s'));
- Assert::equal('01.07.2014 10:00:00', $recurrences[20]->format('d.m.Y H:i:s'));
- Assert::equal('05.08.2014 10:00:00', $recurrences[21]->format('d.m.Y H:i:s'));
- Assert::equal('02.09.2014 10:00:00', $recurrences[22]->format('d.m.Y H:i:s'));
- Assert::equal('07.10.2014 10:00:00', $recurrences[23]->format('d.m.Y H:i:s'));
- Assert::equal('04.11.2014 10:00:00', $recurrences[24]->format('d.m.Y H:i:s'));
- Assert::equal('02.12.2014 10:00:00', $recurrences[25]->format('d.m.Y H:i:s'));
- Assert::equal('06.01.2015 10:00:00', $recurrences[26]->format('d.m.Y H:i:s'));
- Assert::equal('03.02.2015 10:00:00', $recurrences[27]->format('d.m.Y H:i:s'));
- Assert::equal('03.03.2015 10:00:00', $recurrences[28]->format('d.m.Y H:i:s'));
- Assert::equal('07.04.2015 10:00:00', $recurrences[29]->format('d.m.Y H:i:s'));
- Assert::equal('05.05.2015 10:00:00', $recurrences[30]->format('d.m.Y H:i:s'));
- Assert::equal('02.06.2015 10:00:00', $recurrences[31]->format('d.m.Y H:i:s'));
- Assert::equal('07.07.2015 10:00:00', $recurrences[32]->format('d.m.Y H:i:s'));
- Assert::equal('04.08.2015 10:00:00', $recurrences[33]->format('d.m.Y H:i:s'));
- Assert::equal('01.09.2015 10:00:00', $recurrences[34]->format('d.m.Y H:i:s'));
-
- foreach ($events->getIterator()->current()['EXDATES'] as $exDate) {
- Assert::notContains($exDate, $recurrences);
- }
-});
-
-test('Recurrent event with modifications at single date', function () {
- $cal = new IcalParser();
- $cal->parseFile(__DIR__ . '/cal/recur_instances_with_modifications.ics');
- $events = $cal->getEvents()->sorted();
-
- // There should be 36 total events because of the modified event + 35 recurrences
- Assert::count(36, $events); // 36 events
-
- // There should be 35 total recurrences because the modified event should've removed 1 recurrence
- Assert::hasKey('RECURRENCES', $events->offsetGet(1));
- $recurrences = $events->getIterator()->current()['RECURRENCES'];
- Assert::count(35, $recurrences);
-
- // reccurent event don't have RECURRENCES
- foreach (range(2, 35) as $index) {
- Assert::hasNotKey('RECURRENCES', $events->offsetGet($index));
- }
-
- // the date 8.8.2016 should be modified
- $modifiedEvent = $events->offsetGet(0);
- Assert::hasNotKey('RECURRENCES', $modifiedEvent);
-// the 12th entry is the modified event, related to the remaining recurring events
- Assert::same('8.8.2016', $modifiedEvent['DTSTART']->format('j.n.Y'));
- Assert::notContains($modifiedEvent['DTSTART'], $recurrences);
-});
-
-test('Recuring instances with modifications and interval', function () {
- $cal = new IcalParser();
- $results = $cal->parseFile(__DIR__ . '/cal/recur_instances_with_modifications_and_interval.ics');
-
-// Build the cache of RECURRENCE-IDs and EXDATES first, so that we can properly determine the interval
- $eventCache = [];
- foreach ($results['VEVENT'] as $event) {
- $eventSequence = empty($event['SEQUENCE']) ? "0" : $event['SEQUENCE'];
- $eventRecurrenceID = empty($event['RECURRENCE-ID']) ? "0" : $event['RECURRENCE-ID'];
- $eventCache[$event['UID']][$eventRecurrenceID][$eventSequence] = $event;
- }
- $trueEvents = [];
- foreach ($results['VEVENT'] as $event) {
- if (empty($event['RECURRENCES'])) {
- $trueEvents[] = $event;
- } else {
- $eventUID = $event['UID'];
- foreach ($event['RECURRENCES'] as $recurrence) {
- $eventRecurrenceID = $recurrence->format("Ymd");
- if (empty($eventCache[$eventUID][$eventRecurrenceID])) {
- $trueEvents[$eventRecurrenceID] = ['DTSTART' => $recurrence];
- } else {
- krsort($eventCache[$eventUID][$eventRecurrenceID]);
- $keys = array_keys($eventCache[$eventUID][$eventRecurrenceID]);
- $trueEvents[$eventRecurrenceID] = $eventCache[$eventUID][$eventRecurrenceID][$keys[0]];
- }
- }
- }
- }
-
- usort(
- $trueEvents,
- static function ($a, $b): int {
- return ($a['DTSTART'] > $b['DTSTART']) ? 1 : -1;
- }
- );
-
- $events = $cal->getEvents()->sorted()->getArrayCopy();
-
- Assert::false(empty($events[0]['RECURRENCES']));
- Assert::equal(count($trueEvents), count($events));
- foreach ($trueEvents as $index => $trueEvent) {
- Assert::equal($trueEvent['DTSTART']->format("Ymd"), $events[$index]['DTSTART']->format("Ymd"));
- }
-
-});
-
-test('', function () {
- $cal = new IcalParser();
-// There is still an issue that needs to be resolved when modifications are made to the initial event that is the
-// base of the recurrences. The below ICS file has a great edge case example: one event, no recurrences in the
-// recurring ruleset, and a modification to the initial event.
- $results = $cal->parseFile(__DIR__ . '/cal/recur_instances_with_modifications_to_first_day.ics');
- $events = $cal->getEvents()->sorted()->getArrayCopy();
- Assert::true(empty($events[0]['RECURRENCES'])); // edited event
- Assert::true(empty($events[1]['RECURRENCES'])); // recurring event base with no recurrences
- Assert::equal(1, count($events));
-});
-
-test('', function () {
- $cal = new IcalParser();
- $results = $cal->parseFile(__DIR__ . '/cal/daily_recur.ics');
- $events = $cal->getEvents()->sorted()->getArrayCopy();
- $period = new DatePeriod(new DateTime('20120801T050000'), new DateInterval('P1D'), new DateTime('20150801T050000'));
- foreach ($period as $i => $day) {
- Assert::equal($day->format('j.n.Y H:i:s'), $events[$i]['DTSTART']->format('j.n.Y H:i:s'));
- }
-});
-
-test('', function () {
- $cal = new IcalParser();
- $results = $cal->parseFile(__DIR__ . '/cal/daily_recur2.ics');
- $events = $cal->getEvents()->sorted()->getArrayCopy();
-
- Assert::equal(4, count($events));
- Assert::equal('21.8.2017 00:00:00', $events[0]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('28.8.2017 00:00:00', $events[1]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('4.9.2017 00:00:00', $events[2]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('11.9.2017 00:00:00', $events[3]['DTSTART']->format('j.n.Y H:i:s'));
-});
-
-test('', function () {
-//https://github.com/OzzyCzech/icalparser/issues/38
- $cal = new IcalParser();
- $cal->parseFile(__DIR__ . '/cal/38_weekly_recurring_event_missing_day.ics');
- $events = $cal->getEvents()->sorted()->getArrayCopy();
-
- //first monday
- Assert::equal('25.2.2019 09:00:00', $events[0]['DTSTART']->format('j.n.Y H:i:s'));
- //rest of week
- Assert::equal('26.2.2019 09:00:00', $events[1]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('27.2.2019 09:00:00', $events[2]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('28.2.2019 09:00:00', $events[3]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('1.3.2019 09:00:00', $events[4]['DTSTART']->format('j.n.Y H:i:s'));
- //now check the next 4 mondays to make sure they exist as well
- Assert::equal('4.3.2019 09:00:00', $events[5]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('11.3.2019 09:00:00', $events[10]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('18.3.2019 09:00:00', $events[15]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('25.3.2019 09:00:00', $events[20]['DTSTART']->format('j.n.Y H:i:s'));
-
- //Last week that works correctly
- Assert::equal('1.4.2019 09:00:00', $events[25]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('2.4.2019 09:00:00', $events[26]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('3.4.2019 09:00:00', $events[27]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('4.4.2019 09:00:00', $events[28]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('5.4.2019 09:00:00', $events[29]['DTSTART']->format('j.n.Y H:i:s'));
-
- //This week starts failing
- Assert::equal('8.4.2019 09:00:00', $events[30]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('9.4.2019 09:00:00', $events[31]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('10.4.2019 09:00:00', $events[32]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('11.4.2019 09:00:00', $events[33]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('12.4.2019 09:00:00', $events[34]['DTSTART']->format('j.n.Y H:i:s'));
-
- Assert::equal('15.4.2019 09:00:00', $events[35]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('16.4.2019 09:00:00', $events[36]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('17.4.2019 09:00:00', $events[37]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('18.4.2019 09:00:00', $events[38]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('19.4.2019 09:00:00', $events[39]['DTSTART']->format('j.n.Y H:i:s'));
-});
-
-test('Recurring instances bi-weekly', function () {
-// https://github.com/OzzyCzech/icalparser/issues/61
- $cal = new IcalParser();
-
- $cal->parseFile(__DIR__ . '/cal/rrule_interval.ics');
- $events = $cal->getEvents()->sorted();
-
- var_dump($events[0]['RECURRENCES']);
-
-// DTSTART;TZID=America/Los_Angeles:20230131T050000
-// DTEND;TZID=America/Los_Angeles:20230131T060000
-// RRULE:FREQ=WEEKLY;WKST=MO;UNTIL=20230228T090000;INTERVAL=2;BYDAY=TU
- Assert::equal(3, count($events[0]['RECURRENCES']));
- Assert::equal(3, $events->count());
- Assert::equal('31.1.2023 05:00:00', $events[0]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('14.2.2023 05:00:00', $events[1]['DTSTART']->format('j.n.Y H:i:s'));
- Assert::equal('28.2.2023 05:00:00', $events[2]['DTSTART']->format('j.n.Y H:i:s'));
-}); \ No newline at end of file
diff --git a/includes/composer/vendor/om/icalparser/tests/events.sorting.phpt b/includes/composer/vendor/om/icalparser/tests/events.sorting.phpt
deleted file mode 100644
index 5463396..0000000
--- a/includes/composer/vendor/om/icalparser/tests/events.sorting.phpt
+++ /dev/null
@@ -1,36 +0,0 @@
-<?php
-/**
- * Copyright (c) 2004-2022 Roman Ožana (https://ozana.cz)
- *
- * @license BSD-3-Clause
- * @author Roman Ožana <roman@ozana.cz>
- */
-
-use om\IcalParser;
-use Tester\Assert;
-use function tests\test;
-
-require_once __DIR__ . '/bootstrap.php';
-
-date_default_timezone_set('Europe/Prague');
-
-test('Natural sort order by date', function () {
- $cal = new IcalParser();
- $cal->parseFile(__DIR__ . '/cal/basic.ics');
- $first = $cal->getEvents()->sorted()->getIterator()->current();
- Assert::same('1.1.2013 00:00:00', $first['DTSTART']->format('j.n.Y H:i:s'));
-});
-
-test('Reverse events sort (parseFile)', function () {
- $cal = new IcalParser();
- $cal->parseFile(__DIR__ . '/cal/basic.ics');
- $first = $cal->getEvents()->reversed()->getIterator()->current();
- Assert::same('26.12.2015 00:00:00', $first['DTSTART']->format('j.n.Y H:i:s'));
-});
-
-test('Reverse events sort (parseString)', function () {
- $cal = new IcalParser();
- $cal->parseString(file_get_contents(__DIR__ . '/cal/basic.ics'));
- $first = $cal->getEvents()->reversed()->getIterator()->current();
- Assert::same('26.12.2015 00:00:00', $first['DTSTART']->format('j.n.Y H:i:s'));
-});
diff --git a/includes/composer/vendor/om/icalparser/tests/missing.timezone.phpt b/includes/composer/vendor/om/icalparser/tests/missing.timezone.phpt
deleted file mode 100644
index 63eb6c2..0000000
--- a/includes/composer/vendor/om/icalparser/tests/missing.timezone.phpt
+++ /dev/null
@@ -1,24 +0,0 @@
-<?php
-
-use om\IcalParser;
-use Tester\Assert;
-use function tests\test;
-
-require_once __DIR__ . '/bootstrap.php';
-date_default_timezone_set('Europe/Prague');
-
-test('Time zone should remain empty', function () {
- $cal = new IcalParser();
- $cal->parseFile(__DIR__ . '/cal/missing-timezone.ics');
-
- Assert::null($cal->timezone);
-});
-
-test('Timezone should be same as current timezone', function () {
- $cal = new IcalParser();
- $cal->parseFile(__DIR__ . '/cal/missing-timezone.ics');
- $dtstart = $cal->getEvents()->reversed()->getIterator()->current()['DTSTART'];
- /** @var DateTime $dtstart */
- Assert::same('Europe/Prague', $dtstart->getTimezone()->getName());
- Assert::same('7.11.2022', $dtstart->format('j.n.Y'));
-}); \ No newline at end of file