mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-24 11:51:12 +01:00
Merge branch 'JS-Cleanup'
This commit is contained in:
commit
e294b9657f
6
.dockerignore
Normal file
6
.dockerignore
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
database
|
||||||
|
node_modules
|
||||||
|
www/cache
|
||||||
|
www/dist
|
||||||
|
userdata
|
||||||
|
!userdata/wiki
|
2
.gitignore
vendored
2
.gitignore
vendored
@ -4,3 +4,5 @@ userdata
|
|||||||
www/cache/
|
www/cache/
|
||||||
node_modules/
|
node_modules/
|
||||||
www/themes/new/css/custom.css
|
www/themes/new/css/custom.css
|
||||||
|
docker-compose.override.yml
|
||||||
|
.idea
|
@ -44,14 +44,6 @@ class Bootstrap
|
|||||||
/** @var LegacyApplication $app */
|
/** @var LegacyApplication $app */
|
||||||
$app = $container->get('LegacyApplication');
|
$app = $container->get('LegacyApplication');
|
||||||
|
|
||||||
if (!class_exists('License')) {
|
return new EnvironmentConfigProvider($app->Conf);
|
||||||
$test = dirname(__DIR__, 3) . '/phpwf/plugins/class.license.php';
|
|
||||||
$file = new SplFileInfo($test);
|
|
||||||
if ($file->isFile()) {
|
|
||||||
include $test;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return new EnvironmentConfigProvider(new License(), $app->Conf);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -34,11 +34,6 @@ final class EnvironmentConfig
|
|||||||
*/
|
*/
|
||||||
private $userdataDirectoryPath;
|
private $userdataDirectoryPath;
|
||||||
|
|
||||||
/**
|
|
||||||
* @var array|null $ioncubeSystemInformation
|
|
||||||
*/
|
|
||||||
private $ioncubeSystemInformation;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $databaseHost
|
* @param string $databaseHost
|
||||||
* @param string $databaseName
|
* @param string $databaseName
|
||||||
@ -46,7 +41,6 @@ final class EnvironmentConfig
|
|||||||
* @param string $databasePassword
|
* @param string $databasePassword
|
||||||
* @param int $databasePort
|
* @param int $databasePort
|
||||||
* @param string $userdataDirectoryPath
|
* @param string $userdataDirectoryPath
|
||||||
* @param array $ioncubeSystemInformation
|
|
||||||
*/
|
*/
|
||||||
public function __construct(
|
public function __construct(
|
||||||
string $databaseHost,
|
string $databaseHost,
|
||||||
@ -54,8 +48,7 @@ final class EnvironmentConfig
|
|||||||
string $databaseUser,
|
string $databaseUser,
|
||||||
string $databasePassword,
|
string $databasePassword,
|
||||||
int $databasePort,
|
int $databasePort,
|
||||||
string $userdataDirectoryPath,
|
string $userdataDirectoryPath
|
||||||
?array $ioncubeSystemInformation
|
|
||||||
) {
|
) {
|
||||||
$this->databaseHost = $databaseHost;
|
$this->databaseHost = $databaseHost;
|
||||||
$this->databaseName = $databaseName;
|
$this->databaseName = $databaseName;
|
||||||
@ -63,7 +56,6 @@ final class EnvironmentConfig
|
|||||||
$this->databasePassword = $databasePassword;
|
$this->databasePassword = $databasePassword;
|
||||||
$this->databasePort = $databasePort;
|
$this->databasePort = $databasePort;
|
||||||
$this->userdataDirectoryPath = $userdataDirectoryPath;
|
$this->userdataDirectoryPath = $userdataDirectoryPath;
|
||||||
$this->ioncubeSystemInformation = $ioncubeSystemInformation;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -113,121 +105,4 @@ final class EnvironmentConfig
|
|||||||
{
|
{
|
||||||
return $this->userdataDirectoryPath;
|
return $this->userdataDirectoryPath;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @return ?array
|
|
||||||
*/
|
|
||||||
public function getIoncubeSystemInformation(): ?array
|
|
||||||
{
|
|
||||||
return $this->ioncubeSystemInformation;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
public function isSystemHostedOnCloud(): bool
|
|
||||||
{
|
|
||||||
return !empty($this->ioncubeSystemInformation['iscloud']['value']);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
public function isSystemFlaggedAsDevelopmentVersion(): bool
|
|
||||||
{
|
|
||||||
return !empty($this->ioncubeSystemInformation['isdevelopmentversion']['value']);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
public function isSystemFlaggedAsTestVersion(): bool
|
|
||||||
{
|
|
||||||
return !empty($this->ioncubeSystemInformation['testlizenz']['value']);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return int
|
|
||||||
*/
|
|
||||||
public function getMaxUser(): int
|
|
||||||
{
|
|
||||||
if (!isset($this->ioncubeSystemInformation['maxuser']['value'])) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return (int)$this->ioncubeSystemInformation['maxuser']['value'];
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return int
|
|
||||||
*/
|
|
||||||
public function getMaxLightUser(): int
|
|
||||||
{
|
|
||||||
if (!isset($this->ioncubeSystemInformation['maxlightuser']['value'])) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return (int)$this->ioncubeSystemInformation['maxlightuser']['value'];
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return int|null
|
|
||||||
*/
|
|
||||||
public function getExpirationTimeStamp(): ?int
|
|
||||||
{
|
|
||||||
if (!isset($this->ioncubeSystemInformation['expdate']['value'])) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return (int)$this->ioncubeSystemInformation['expdate']['value'];
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param string $name
|
|
||||||
*
|
|
||||||
* @return string|null
|
|
||||||
*/
|
|
||||||
public function getValueOfSpecificIoncubeSystemInformation(string $name): ?string
|
|
||||||
{
|
|
||||||
if ($this->ioncubeSystemInformation === null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (array_key_exists($name, $this->ioncubeSystemInformation)) {
|
|
||||||
return $this->ioncubeSystemInformation[$name]['value'];
|
|
||||||
}
|
|
||||||
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return array
|
|
||||||
*/
|
|
||||||
public function getSystemFallbackEmailAddresses(): array
|
|
||||||
{
|
|
||||||
$emailAddresses = [];
|
|
||||||
$mailAddressSelfBuyCustomer = (string)$this->getValueOfSpecificIoncubeSystemInformation('buyemail');
|
|
||||||
if ($mailAddressSelfBuyCustomer !== '') {
|
|
||||||
$emailAddresses[] = $mailAddressSelfBuyCustomer;
|
|
||||||
}
|
|
||||||
|
|
||||||
$mailAddressCustomerLicence = (string)$this->getValueOfSpecificIoncubeSystemInformation('emaillicence');
|
|
||||||
if ($mailAddressCustomerLicence !== ''
|
|
||||||
&& strpos($mailAddressCustomerLicence, '@') !== false
|
|
||||||
&& strpos($mailAddressCustomerLicence, '@xentral.com') === false
|
|
||||||
&& strpos($mailAddressCustomerLicence, '@xentral.biz') === false) {
|
|
||||||
$emailAddresses[] = $mailAddressCustomerLicence;
|
|
||||||
}
|
|
||||||
|
|
||||||
//in old licences email-address of customer can be insert in name instead email
|
|
||||||
$nameCustomerLicence = (string)$this->getValueOfSpecificIoncubeSystemInformation('namelicence');
|
|
||||||
if ($nameCustomerLicence !== ''
|
|
||||||
&& strpos($nameCustomerLicence, '@') !== false
|
|
||||||
&& strpos($nameCustomerLicence, '@xentral.com') === false
|
|
||||||
&& strpos($nameCustomerLicence, '@xentral.biz') === false) {
|
|
||||||
$emailAddresses[] = $nameCustomerLicence;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $emailAddresses;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -7,19 +7,14 @@ use License;
|
|||||||
|
|
||||||
final class EnvironmentConfigProvider
|
final class EnvironmentConfigProvider
|
||||||
{
|
{
|
||||||
/** @var License $license */
|
|
||||||
private $license;
|
|
||||||
|
|
||||||
/** @var Config $config */
|
/** @var Config $config */
|
||||||
private $config;
|
private $config;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param License $license
|
|
||||||
* @param Config $config
|
* @param Config $config
|
||||||
*/
|
*/
|
||||||
public function __construct(License $license, Config $config)
|
public function __construct(Config $config)
|
||||||
{
|
{
|
||||||
$this->license = $license;
|
|
||||||
$this->config = $config;
|
$this->config = $config;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -30,8 +25,7 @@ final class EnvironmentConfigProvider
|
|||||||
{
|
{
|
||||||
$environmentConfig = new EnvironmentConfig(
|
$environmentConfig = new EnvironmentConfig(
|
||||||
$this->config->WFdbhost, $this->config->WFdbname, $this->config->WFdbuser,
|
$this->config->WFdbhost, $this->config->WFdbname, $this->config->WFdbuser,
|
||||||
$this->config->WFdbpass, $this->config->WFdbport, $this->config->WFuserdata,
|
$this->config->WFdbpass, $this->config->WFdbport, $this->config->WFuserdata
|
||||||
(array)$this->license->getProperties()
|
|
||||||
);
|
);
|
||||||
|
|
||||||
return $environmentConfig;
|
return $environmentConfig;
|
||||||
|
@ -84,10 +84,6 @@ final class ErrorHandler
|
|||||||
public function handleException($exception)
|
public function handleException($exception)
|
||||||
{
|
{
|
||||||
$title = null;
|
$title = null;
|
||||||
if ($this->isIoncubeError($exception)) {
|
|
||||||
$title = $this->handleIoncubeError($exception);
|
|
||||||
}
|
|
||||||
|
|
||||||
$data = new ErrorPageData($exception, $title);
|
$data = new ErrorPageData($exception, $title);
|
||||||
$renderer = new ErrorPageRenderer($data);
|
$renderer = new ErrorPageRenderer($data);
|
||||||
header('HTTP/1.1 500 Internal Server Error');
|
header('HTTP/1.1 500 Internal Server Error');
|
||||||
@ -125,96 +121,4 @@ final class ErrorHandler
|
|||||||
{
|
{
|
||||||
return in_array((int)$type, self::THROWABLE_ERROR_TYPES, true);
|
return in_array((int)$type, self::THROWABLE_ERROR_TYPES, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Throwable $exception
|
|
||||||
*
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
private function isIoncubeError($exception)
|
|
||||||
{
|
|
||||||
if ((int)$exception->getCode() !== E_CORE_ERROR) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (strpos($exception->getMessage(), 'requires a license file.') !== false) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strpos($exception->getMessage(), 'ionCube Encoder') !== false) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Throwable $exception
|
|
||||||
*
|
|
||||||
* @return string|null
|
|
||||||
*/
|
|
||||||
private function handleIoncubeError($exception)
|
|
||||||
{
|
|
||||||
$file = $this->extractFileFromIoncubeError($exception);
|
|
||||||
if (empty($file)) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$this->isDeleteableFile($file)) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
@unlink($file);
|
|
||||||
if(is_file($file)) {
|
|
||||||
return sprintf('Es wurde eine alte Systemdatei gefunden die nicht manuell gelöscht werden konnte.
|
|
||||||
Bitte löschen Sie die Datei %s', $file);
|
|
||||||
}
|
|
||||||
return 'Es wurde eine alte Systemdatei gefunden und automatisch gelöscht.
|
|
||||||
Bitte führen Sie das Update nochmal durch dann sollte diese Meldung nicht mehr erscheinen.';
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param string $file
|
|
||||||
*
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
private function isDeleteableFile(string $file)
|
|
||||||
{
|
|
||||||
if (!is_file($file)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
$dir = dirname($file);
|
|
||||||
foreach (self::DELETE_FILE_FOLDERS as $folder) {
|
|
||||||
if (substr($dir, -strlen($folder)) === $folder) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @example "<br>The encoded file <b>/var/www/xentral/www/pages/adresse.php</b> requires a license file.<br>"
|
|
||||||
* "The license file <b>/var/www/xentral/key.php</b> is corrupt."
|
|
||||||
*
|
|
||||||
* @param Throwable $exception
|
|
||||||
*
|
|
||||||
* @return string|null
|
|
||||||
*/
|
|
||||||
private function extractFileFromIoncubeError($exception)
|
|
||||||
{
|
|
||||||
$message = strip_tags($exception->getMessage());
|
|
||||||
$theFilePos = stripos($message, 'The File ');
|
|
||||||
if ($theFilePos === false) {
|
|
||||||
$theFilePos = strpos($message, 'The encoded file');
|
|
||||||
if ($theFilePos === false) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
$theFilePos += 16;
|
|
||||||
} else {
|
|
||||||
$theFilePos += 9;
|
|
||||||
}
|
|
||||||
$file = trim(substr($message, $theFilePos));
|
|
||||||
$file = explode(' ', $file);
|
|
||||||
|
|
||||||
return reset($file);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -323,15 +323,6 @@ final class ErrorPageData implements JsonSerializable
|
|||||||
'ldap' => function () {
|
'ldap' => function () {
|
||||||
return function_exists('ldap_connect');
|
return function_exists('ldap_connect');
|
||||||
},
|
},
|
||||||
'ioncube' => function () {
|
|
||||||
if (!function_exists('ioncube_loader_version')) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$ioncubeMajorVersion = (int)@ioncube_loader_version();
|
|
||||||
|
|
||||||
return $ioncubeMajorVersion >= 5;
|
|
||||||
},
|
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -16,6 +16,7 @@ class ArticleService
|
|||||||
function CopyArticle(int $id, bool $purchasePrices, bool $sellingPrices, bool $files, bool $properties,
|
function CopyArticle(int $id, bool $purchasePrices, bool $sellingPrices, bool $files, bool $properties,
|
||||||
bool $instructions, bool $partLists, bool $customFields, string $newArticleNumber = '')
|
bool $instructions, bool $partLists, bool $customFields, string $newArticleNumber = '')
|
||||||
{
|
{
|
||||||
|
$newArticleNumber = $this->app->DB->real_escape_string($newArticleNumber);
|
||||||
$this->app->DB->MysqlCopyRow('artikel','id',$id);
|
$this->app->DB->MysqlCopyRow('artikel','id',$id);
|
||||||
|
|
||||||
$idnew = $this->app->DB->GetInsertID();
|
$idnew = $this->app->DB->GetInsertID();
|
||||||
@ -26,7 +27,7 @@ class ArticleService
|
|||||||
$this->app->DB->Update("UPDATE artikel SET steuersatz = '$steuersatz' WHERE id = '$idnew' LIMIT 1");
|
$this->app->DB->Update("UPDATE artikel SET steuersatz = '$steuersatz' WHERE id = '$idnew' LIMIT 1");
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->app->DB->Update("UPDATE artikel SET nummer='$newArticleNumber' WHERE id='$idnew' LIMIT 1");
|
$this->app->DB->Update("UPDATE artikel SET nummer='$newArticleNumber', matrixprodukt = 0 WHERE id='$idnew' LIMIT 1");
|
||||||
if($this->app->DB->Select("SELECT variante_kopie FROM artikel WHERE id = '$id' LIMIT 1"))
|
if($this->app->DB->Select("SELECT variante_kopie FROM artikel WHERE id = '$id' LIMIT 1"))
|
||||||
$this->app->DB->Update("UPDATE artikel SET variante = 1, variante_von = '$id' WHERE id = '$idnew' LIMIT 1");
|
$this->app->DB->Update("UPDATE artikel SET variante = 1, variante_von = '$id' WHERE id = '$idnew' LIMIT 1");
|
||||||
|
|
||||||
|
@ -6,9 +6,6 @@ namespace Xentral\Modules\GoogleApi;
|
|||||||
|
|
||||||
final class GoogleScope
|
final class GoogleScope
|
||||||
{
|
{
|
||||||
/** @var string CLOUDPRINT */
|
|
||||||
public const CLOUDPRINT = 'https://www.googleapis.com/auth/cloudprint';
|
|
||||||
|
|
||||||
/** @var string CALENDAR */
|
/** @var string CALENDAR */
|
||||||
public const CALENDAR = 'https://www.googleapis.com/auth/calendar';
|
public const CALENDAR = 'https://www.googleapis.com/auth/calendar';
|
||||||
|
|
||||||
|
@ -213,25 +213,6 @@ final class GoogleAccountGateway
|
|||||||
return array_values($pairs);
|
return array_values($pairs);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Will be removed after Dec 31. 2020
|
|
||||||
*
|
|
||||||
* @deprecated
|
|
||||||
*
|
|
||||||
* @codeCoverageIgnore
|
|
||||||
*
|
|
||||||
* @return GoogleAccountData
|
|
||||||
*/
|
|
||||||
public function getCloudPrintAccount(): GoogleAccountData
|
|
||||||
{
|
|
||||||
$accounts = $this->getAccountsByScope(GoogleScope::CLOUDPRINT);
|
|
||||||
if (count($accounts) < 1) {
|
|
||||||
throw new GoogleAccountNotFoundException('No cloud printing account available.');
|
|
||||||
}
|
|
||||||
|
|
||||||
return $accounts[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param int $accountId
|
* @param int $accountId
|
||||||
*
|
*
|
||||||
|
@ -1,109 +0,0 @@
|
|||||||
|
|
||||||
/**
|
|
||||||
* Für die Bedienung der Modul-Oberfläche
|
|
||||||
*/
|
|
||||||
var PrinterGoogleCloudPrint = (function ($) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var me = {
|
|
||||||
|
|
||||||
isInitialized: false,
|
|
||||||
$apiSelect: null,
|
|
||||||
$printerSelect: null,
|
|
||||||
initApiValue: null,
|
|
||||||
initPrinterValue: null,
|
|
||||||
printercache: {},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return void
|
|
||||||
*/
|
|
||||||
init: function () {
|
|
||||||
if (me.isInitialized === true) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
me.$apiSelect = $('select[name="google_api"]');
|
|
||||||
me.$printerSelect = $('select[name="google_printer"]');
|
|
||||||
me.initApiValue = me.$apiSelect.val();
|
|
||||||
me.initPrinterValue = me.$printerSelect.val();
|
|
||||||
|
|
||||||
var options = {};
|
|
||||||
$('select[name="google_printer"] option').each( function () {
|
|
||||||
options[$(this).attr('value')] = $(this).text();
|
|
||||||
});
|
|
||||||
me.printercache[me.initApiValue] = options;
|
|
||||||
|
|
||||||
me.registerEvents();
|
|
||||||
me.isInitialized = true;
|
|
||||||
},
|
|
||||||
|
|
||||||
setPrinterSelectOptions: function(options, selected) {
|
|
||||||
me.$printerSelect.empty(); // remove old options
|
|
||||||
$.each(options, function(value, display) {
|
|
||||||
me.$printerSelect.append($('<option></option>').attr('value', value).text(display));
|
|
||||||
});
|
|
||||||
if (selected in options) {
|
|
||||||
me.$printerSelect.val(selected);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return {void}
|
|
||||||
*/
|
|
||||||
registerEvents: function () {
|
|
||||||
me.$apiSelect.change(function () {
|
|
||||||
me.ajaxLoadPrinterOptions(this.value);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param {number} fieldId
|
|
||||||
*
|
|
||||||
* @return {void}
|
|
||||||
*/
|
|
||||||
ajaxLoadPrinterOptions: function (apiName) {
|
|
||||||
if (apiName === '') {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (apiName in me.printercache) {
|
|
||||||
me.setPrinterSelectOptions(me.printercache[apiName], me.initPrinterValue);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$.ajax({
|
|
||||||
url: 'index.php?module=googleapi&action=ajaxprinters',
|
|
||||||
data: {
|
|
||||||
api_name: apiName
|
|
||||||
},
|
|
||||||
method: 'post',
|
|
||||||
dataType: 'json',
|
|
||||||
beforeSend: function () {
|
|
||||||
me.$printerSelect.prop('disabled', true);
|
|
||||||
me.$apiSelect.prop('disabled', true);
|
|
||||||
App.loading.open();
|
|
||||||
},
|
|
||||||
complete: function() {
|
|
||||||
me.$printerSelect.prop('disabled', false);
|
|
||||||
me.$apiSelect.prop('disabled', false);
|
|
||||||
},
|
|
||||||
error: function (error) {
|
|
||||||
App.loading.close();
|
|
||||||
},
|
|
||||||
success: function (data) {
|
|
||||||
me.printercache[apiName] = data;
|
|
||||||
me.setPrinterSelectOptions(data, me.initPrinterValue);
|
|
||||||
App.loading.close();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
return {
|
|
||||||
init: me.init,
|
|
||||||
};
|
|
||||||
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
$(document).ready(function () {
|
|
||||||
PrinterGoogleCloudPrint.init();
|
|
||||||
});
|
|
@ -130,13 +130,25 @@ final class MatrixProductService
|
|||||||
foreach ($optionArr as $option) {
|
foreach ($optionArr as $option) {
|
||||||
$groupId = $this->gateway->GetArticleGroupIdByName($articleId, $option['groupname']);
|
$groupId = $this->gateway->GetArticleGroupIdByName($articleId, $option['groupname']);
|
||||||
if (!$groupId) {
|
if (!$groupId) {
|
||||||
$obj = new Group($option['groupname'], nameExternal: $option['groupnameext'], projectId: $option['groupprojekt'], required: $option['grouprequired'], articleId: $articleId);
|
$obj = new Group(
|
||||||
|
name: $option['groupname'],
|
||||||
|
nameExternal: $option['groupnameext'],
|
||||||
|
projectId: $option['groupprojekt'],
|
||||||
|
required: $option['grouprequired'],
|
||||||
|
articleId: $articleId);
|
||||||
$group = $this->gateway->InsertArticleGroup($obj);
|
$group = $this->gateway->InsertArticleGroup($obj);
|
||||||
$groupId = $group->id;
|
$groupId = $group->id;
|
||||||
}
|
}
|
||||||
$optionId = $this->gateway->GetArticleOptionIdByName($articleId, $groupId, $option['name']);
|
$optionId = $this->gateway->GetArticleOptionIdByName($articleId, $groupId, $option['name']);
|
||||||
if (!$optionId) {
|
if (!$optionId) {
|
||||||
$obj = new Option($option['name'], $groupId, nameExternal: $option['name_ext'], sort: $option['sort'], globalOptionId: $option['id'], articleId: $articleId);
|
$obj = new Option(
|
||||||
|
name: $option['name'],
|
||||||
|
groupId: $groupId,
|
||||||
|
nameExternal: $option['name_ext'],
|
||||||
|
sort: $option['sort'],
|
||||||
|
articleNumberSuffix: $option['articlenumber_suffix'],
|
||||||
|
globalOptionId: $option['id'],
|
||||||
|
articleId: $articleId);
|
||||||
$this->gateway->InsertArticleOption($obj);
|
$this->gateway->InsertArticleOption($obj);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
<!--
|
<!--
|
||||||
SPDX-FileCopyrightText: 2023 Andreas Palm
|
SPDX-FileCopyrightText: 2023-2024 Andreas Palm
|
||||||
|
|
||||||
SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
||||||
-->
|
-->
|
||||||
@ -9,6 +9,7 @@ import {ref, onMounted} from "vue";
|
|||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
import Dialog from "primevue/dialog";
|
import Dialog from "primevue/dialog";
|
||||||
import Listbox from "primevue/listbox";
|
import Listbox from "primevue/listbox";
|
||||||
|
import Fluid from "primevue/fluid";
|
||||||
import Button from "primevue/button";
|
import Button from "primevue/button";
|
||||||
import {AlertErrorHandler} from '@res/js/ajaxErrorHandler';
|
import {AlertErrorHandler} from '@res/js/ajaxErrorHandler';
|
||||||
|
|
||||||
@ -36,17 +37,19 @@ async function save() {
|
|||||||
|
|
||||||
<template>
|
<template>
|
||||||
<Dialog visible modal header="Globale Optionen hinzufügen" style="width: 500px" @update:visible="emit('close')">
|
<Dialog visible modal header="Globale Optionen hinzufügen" style="width: 500px" @update:visible="emit('close')">
|
||||||
|
<Fluid>
|
||||||
<div v-if="model" class="grid gap-1" style="grid-template-columns: 25% 75%">
|
<div v-if="model" class="grid gap-1" style="grid-template-columns: 25% 75%">
|
||||||
<label for="matrixProductOptions" style="padding-top: 5px;">Optionen:</label>
|
<label for="matrixProductOptions" style="padding-top: 5px;">Optionen:</label>
|
||||||
<Listbox multiple
|
<Listbox multiple
|
||||||
:options="model"
|
:options="model"
|
||||||
optionGroupLabel="name"
|
option-group-label="name"
|
||||||
optionGroupChildren="options"
|
option-group-children="options"
|
||||||
optionLabel="name"
|
option-label="name"
|
||||||
optionValue="id"
|
option-value="id"
|
||||||
listStyle="height: 200px"
|
list-style="height: 200px"
|
||||||
v-model="selected" />
|
v-model="selected" />
|
||||||
</div>
|
</div>
|
||||||
|
</Fluid>
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<Button label="ABBRECHEN" @click="emit('close')" />
|
<Button label="ABBRECHEN" @click="emit('close')" />
|
||||||
<Button label="HINZUFÜGEN" @click="save" :disabled="selected.length === 0"/>
|
<Button label="HINZUFÜGEN" @click="save" :disabled="selected.length === 0"/>
|
||||||
|
@ -1,7 +1,15 @@
|
|||||||
|
<!--
|
||||||
|
SPDX-FileCopyrightText: 2023-2024 Andreas Palm
|
||||||
|
|
||||||
|
SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
||||||
|
-->
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import Button from "primevue/button";
|
import Button from "primevue/button";
|
||||||
import Dialog from "primevue/dialog";
|
import Dialog from "primevue/dialog";
|
||||||
import MultiSelect from "primevue/multiselect";
|
import MultiSelect from "primevue/multiselect";
|
||||||
|
import Fluid from "primevue/fluid";
|
||||||
|
import InputText from "primevue/inputtext";
|
||||||
import {onMounted, ref} from "vue";
|
import {onMounted, ref} from "vue";
|
||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
import {AlertErrorHandler} from "@res/js/ajaxErrorHandler";
|
import {AlertErrorHandler} from "@res/js/ajaxErrorHandler";
|
||||||
@ -16,27 +24,35 @@ const model = ref({});
|
|||||||
onMounted(async () => {
|
onMounted(async () => {
|
||||||
model.value = await axios.get('index.php?module=matrixprodukt&action=artikel&cmd=createMissing', {
|
model.value = await axios.get('index.php?module=matrixprodukt&action=artikel&cmd=createMissing', {
|
||||||
params: {...props}
|
params: {...props}
|
||||||
}).then(response => { return {...props, ...response.data}})
|
}).then(response => {
|
||||||
|
return {...props, ...response.data}
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
async function save() {
|
async function save() {
|
||||||
await axios.post('index.php?module=matrixprodukt&action=artikel&cmd=createMissing', {...props, ...model.value})
|
await axios.post('index.php?module=matrixprodukt&action=artikel&cmd=createMissing', {...props, ...model.value})
|
||||||
.catch(AlertErrorHandler)
|
.catch(AlertErrorHandler)
|
||||||
.then(() => {emit('save')});
|
.then(() => {
|
||||||
|
emit('save')
|
||||||
|
});
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<Dialog visible modal header="Variante" style="width: 500px" @update:visible="emit('close')">
|
<Dialog visible modal header="Variante" style="width: 500px" @update:visible="emit('close')">
|
||||||
<div class="grid gap-1" style="grid-template-columns: 25% 75%;">
|
<Fluid>
|
||||||
|
<div class="grid gap-1" style="grid-template-columns: 25% 75%;" autofocus>
|
||||||
|
<label>Trennzeichen:</label>
|
||||||
|
<InputText v-model="model.separator" maxlength="2" />
|
||||||
<template v-for="group in model.groups">
|
<template v-for="group in model.groups">
|
||||||
<label>{{ group.name }}</label>
|
<label>{{ group.name }}</label>
|
||||||
<MultiSelect v-model="group.selected" :options="group.options" optionLabel="name" optionValue="value" />
|
<MultiSelect v-model="group.selected" :options="group.options" option-label="name" option-value="value"/>
|
||||||
</template>
|
</template>
|
||||||
</div>
|
</div>
|
||||||
|
</Fluid>
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<Button label="ABBRECHEN" @click="emit('close')" />
|
<Button label="ABBRECHEN" @click="emit('close')"/>
|
||||||
<Button label="ERSTELLEN" @click="save" />
|
<Button label="ERSTELLEN" @click="save"/>
|
||||||
</template>
|
</template>
|
||||||
</Dialog>
|
</Dialog>
|
||||||
</template>
|
</template>
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
<!--
|
<!--
|
||||||
SPDX-FileCopyrightText: 2023 Andreas Palm
|
SPDX-FileCopyrightText: 2023-2024 Andreas Palm
|
||||||
|
|
||||||
SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
||||||
-->
|
-->
|
||||||
@ -9,6 +9,10 @@ import {ref, onMounted} from "vue";
|
|||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
import Dialog from "primevue/dialog";
|
import Dialog from "primevue/dialog";
|
||||||
import Button from "primevue/button";
|
import Button from "primevue/button";
|
||||||
|
import InputText from "primevue/inputtext";
|
||||||
|
import InputNumber from "primevue/inputnumber";
|
||||||
|
import Checkbox from "primevue/checkbox";
|
||||||
|
import Fluid from "primevue/fluid";
|
||||||
import {AlertErrorHandler} from "@res/js/ajaxErrorHandler";
|
import {AlertErrorHandler} from "@res/js/ajaxErrorHandler";
|
||||||
import AutoComplete from "@res/vue/AutoComplete.vue";
|
import AutoComplete from "@res/vue/AutoComplete.vue";
|
||||||
|
|
||||||
@ -44,26 +48,28 @@ async function save() {
|
|||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<Dialog visible modal header="Gruppe anlegen/bearbeiten" style="width: 500px" @update:visible="emit('close')" class="p-fluid">
|
<Dialog visible modal header="Gruppe anlegen/bearbeiten" style="width: 500px" @update:visible="emit('close')">
|
||||||
|
<Fluid>
|
||||||
<div class="grid gap-1" style="grid-template-columns: 25% 75%">
|
<div class="grid gap-1" style="grid-template-columns: 25% 75%">
|
||||||
<label for="matrixProduct_group_name">Name:</label>
|
<label for="matrixProduct_group_name">Name:</label>
|
||||||
<input type="text" v-model="model.name" required />
|
<InputText id="matrixProduct_group_name" v-model="model.name" autofocus required />
|
||||||
<label for="matrixProduct_group_nameExternal">Name Extern:</label>
|
<label for="matrixProduct_group_nameExternal">Name Extern:</label>
|
||||||
<input type="text" v-model="model.nameExternal" />
|
<InputText id="matrixProduct_group_nameExternal" v-model="model.nameExternal" />
|
||||||
<label for="matrixProduct_group_project">Projekt:</label>
|
<label for="matrixProduct_group_project">Projekt:</label>
|
||||||
<AutoComplete
|
<AutoComplete input-id="matrixProduct_group_project"
|
||||||
v-model="model.project"
|
v-model="model.project"
|
||||||
:optionLabel="item => [item.abkuerzung, item.name].join(' ')"
|
:optionLabel="item => [item.abkuerzung, item.name].join(' ')"
|
||||||
ajaxFilter="projektname"
|
ajaxFilter="projektname"
|
||||||
forceSelection
|
forceSelection
|
||||||
/>
|
/>
|
||||||
<label v-if="articleId" for="matrixProduct_group_sort">Sortierung:</label>
|
<label v-if="articleId" for="matrixProduct_group_sort">Sortierung:</label>
|
||||||
<input v-if="articleId" type="text" v-model="model.sort">
|
<InputNumber v-if="articleId" v-model="model.sort" input-id="matrixProduct_group_sort" show-buttons />
|
||||||
<label for="matrixProduct_group_required">Pflicht:</label>
|
<label for="matrixProduct_group_required">Pflicht:</label>
|
||||||
<input type="checkbox" v-model="model.required" class="justify-self-start">
|
<Checkbox v-model="model.required" binary />
|
||||||
<label for="matrixProduct_group_active">Aktiv:</label>
|
<label for="matrixProduct_group_active">Aktiv:</label>
|
||||||
<input type="checkbox" v-model="model.active" class="justify-self-start">
|
<Checkbox v-model="model.active" binary />
|
||||||
</div>
|
</div>
|
||||||
|
</Fluid>
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<Button label="ABBRECHEN" @click="emit('close')" />
|
<Button label="ABBRECHEN" @click="emit('close')" />
|
||||||
<Button label="SPEICHERN" @click="save" :disabled="!model.name"/>
|
<Button label="SPEICHERN" @click="save" :disabled="!model.name"/>
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
<!--
|
<!--
|
||||||
SPDX-FileCopyrightText: 2023 Andreas Palm
|
SPDX-FileCopyrightText: 2023-2024 Andreas Palm
|
||||||
|
|
||||||
SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
||||||
-->
|
-->
|
||||||
@ -9,6 +9,10 @@ import {ref, onMounted} from "vue";
|
|||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
import Button from "primevue/button";
|
import Button from "primevue/button";
|
||||||
import Dialog from "primevue/dialog";
|
import Dialog from "primevue/dialog";
|
||||||
|
import Fluid from "primevue/fluid";
|
||||||
|
import InputText from "primevue/inputtext";
|
||||||
|
import InputNumber from "primevue/inputnumber";
|
||||||
|
import Checkbox from "primevue/checkbox";
|
||||||
import {AlertErrorHandler} from "@res/js/ajaxErrorHandler";
|
import {AlertErrorHandler} from "@res/js/ajaxErrorHandler";
|
||||||
|
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
@ -43,18 +47,20 @@ async function save() {
|
|||||||
|
|
||||||
<template>
|
<template>
|
||||||
<Dialog visible modal header="Option anlegen/bearbeiten" style="width: 500px" @update:visible="emit('close')">
|
<Dialog visible modal header="Option anlegen/bearbeiten" style="width: 500px" @update:visible="emit('close')">
|
||||||
|
<Fluid>
|
||||||
<div class="grid gap-1" style="grid-template-columns: 25% 75%">
|
<div class="grid gap-1" style="grid-template-columns: 25% 75%">
|
||||||
<label for="matrixProduct_option_name">Name:</label>
|
<label for="matrixProduct_option_name">Name:</label>
|
||||||
<input id="matrixProduct_option_name" type="text" v-model="model.name" required />
|
<InputText id="matrixProduct_option_name" v-model="model.name" required autofocus />
|
||||||
<label for="matrixProduct_option_nameExternal">Name Extern:</label>
|
<label for="matrixProduct_option_nameExternal">Name Extern:</label>
|
||||||
<input id="matrixProduct_option_nameExternal" type="text" v-model="model.nameExternal" />
|
<InputText id="matrixProduct_option_nameExternal" v-model="model.nameExternal" />
|
||||||
<label for="matrixProduct_option_articleNumberSuffix">Artikelnummer-Suffix:</label>
|
<label for="matrixProduct_option_articleNumberSuffix">Artikelnummer-Suffix:</label>
|
||||||
<input id="matrixProduct_option_articleNumberSuffix" type="text" v-model="model.articleNumberSuffix" />
|
<InputText id="matrixProduct_option_articleNumberSuffix" v-model="model.articleNumberSuffix" />
|
||||||
<label for="matrixProduct_option_sort">Sortierung:</label>
|
<label for="matrixProduct_option_sort">Sortierung:</label>
|
||||||
<input id="matrixProduct_option_sort" type="text" v-model="model.sort" />
|
<InputNumber input-id="matrixProduct_option_sort" v-model="model.sort" show-buttons />
|
||||||
<label for="matrixProduct_option_active">Aktiv:</label>
|
<label for="matrixProduct_option_active">Aktiv:</label>
|
||||||
<input id="matrixProduct_option_active" type="checkbox" v-model="model.active" class="justify-self-start" />
|
<Checkbox input-id="matrixProduct_option_active" v-model="model.active" binary />
|
||||||
</div>
|
</div>
|
||||||
|
</Fluid>
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<Button label="ABBRECHEN" @click="emit('close')" />
|
<Button label="ABBRECHEN" @click="emit('close')" />
|
||||||
<Button label="SPEICHERN" @click="save" :disabled="!model.name" />
|
<Button label="SPEICHERN" @click="save" :disabled="!model.name" />
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
<!--
|
<!--
|
||||||
SPDX-FileCopyrightText: 2023 Andreas Palm
|
SPDX-FileCopyrightText: 2023-2024 Andreas Palm
|
||||||
|
|
||||||
SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
||||||
-->
|
-->
|
||||||
@ -9,7 +9,9 @@ import {ref, onMounted} from "vue";
|
|||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
import Dialog from "primevue/dialog";
|
import Dialog from "primevue/dialog";
|
||||||
import Button from "primevue/button";
|
import Button from "primevue/button";
|
||||||
import Dropdown from "primevue/dropdown";
|
import Fluid from "primevue/fluid";
|
||||||
|
import InputText from "primevue/inputtext";
|
||||||
|
import Select from "primevue/select";
|
||||||
import {AlertErrorHandler} from "@res/js/ajaxErrorHandler";
|
import {AlertErrorHandler} from "@res/js/ajaxErrorHandler";
|
||||||
|
|
||||||
|
|
||||||
@ -59,24 +61,26 @@ function ready() {
|
|||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<Dialog visible modal header="Übersetzung anlegen/bearbeiten" style="width: 500px" @update:visible="emit('close')" class="p-fluid">
|
<Dialog visible modal header="Übersetzung anlegen/bearbeiten" style="width: 500px" @update:visible="emit('close')">
|
||||||
|
<Fluid>
|
||||||
<div class="grid gap-1" style="grid-template-columns: 25% 75%">
|
<div class="grid gap-1" style="grid-template-columns: 25% 75%">
|
||||||
<label for="matrixProduct_nameFrom">DE Name:</label>
|
<label for="matrixProduct_nameFrom">DE Name:</label>
|
||||||
<input type="text" v-model="model.nameFrom" required />
|
<InputText v-model="model.nameFrom" required autofocus />
|
||||||
<label for="matrixProduct_nameExternalFrom">DE Name Extern:</label>
|
<label for="matrixProduct_nameExternalFrom">DE Name Extern:</label>
|
||||||
<input type="text" v-model="model.nameExternalFrom" />
|
<InputText v-model="model.nameExternalFrom" />
|
||||||
<label for="matrixProduct_languageTo">Sprache:</label>
|
<label for="matrixProduct_languageTo">Sprache:</label>
|
||||||
<Dropdown
|
<Select
|
||||||
v-model="model.languageTo"
|
v-model="model.languageTo"
|
||||||
:options="languages"
|
:options="languages"
|
||||||
option-label="bezeichnung_de"
|
option-label="bezeichnung_de"
|
||||||
option-value="iso"
|
option-value="iso"
|
||||||
/>
|
/>
|
||||||
<label for="matrixProduct_nameTo">Übersetzung Name:</label>
|
<label for="matrixProduct_nameTo">Übersetzung Name:</label>
|
||||||
<input type="text" v-model="model.nameTo" required>
|
<InputText v-model="model.nameTo" required />
|
||||||
<label for="matrixProduct_nameTo">Übersetzung Name Extern:</label>
|
<label for="matrixProduct_nameTo">Übersetzung Name Extern:</label>
|
||||||
<input type="text" v-model="model.nameExternalTo" :required="model.nameExternalFrom">
|
<InputText v-model="model.nameExternalTo" :required="model.nameExternalFrom" />
|
||||||
</div>
|
</div>
|
||||||
|
</Fluid>
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<Button label="ABBRECHEN" @click="emit('close')" />
|
<Button label="ABBRECHEN" @click="emit('close')" />
|
||||||
<Button label="SPEICHERN" @click="save" :disabled="!ready()"/>
|
<Button label="SPEICHERN" @click="save" :disabled="!ready()"/>
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
<!--
|
<!--
|
||||||
SPDX-FileCopyrightText: 2023 Andreas Palm
|
SPDX-FileCopyrightText: 2023-2024 Andreas Palm
|
||||||
|
|
||||||
SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
||||||
-->
|
-->
|
||||||
@ -8,7 +8,8 @@ SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
|||||||
import AutoComplete from "@res/vue/AutoComplete.vue";
|
import AutoComplete from "@res/vue/AutoComplete.vue";
|
||||||
import Button from "primevue/button";
|
import Button from "primevue/button";
|
||||||
import Dialog from "primevue/dialog";
|
import Dialog from "primevue/dialog";
|
||||||
import Dropdown from "primevue/dropdown";
|
import Select from "primevue/select";
|
||||||
|
import Fluid from "primevue/fluid";
|
||||||
import {onMounted, ref} from "vue";
|
import {onMounted, ref} from "vue";
|
||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
import {AlertErrorHandler} from "@res/js/ajaxErrorHandler";
|
import {AlertErrorHandler} from "@res/js/ajaxErrorHandler";
|
||||||
@ -41,18 +42,21 @@ const buttons = {
|
|||||||
|
|
||||||
<template>
|
<template>
|
||||||
<Dialog visible modal header="Variante" style="width: 500px" @update:visible="emit('close')">
|
<Dialog visible modal header="Variante" style="width: 500px" @update:visible="emit('close')">
|
||||||
|
<Fluid>
|
||||||
<div class="grid gap-1" style="grid-template-columns: 25% 75%;">
|
<div class="grid gap-1" style="grid-template-columns: 25% 75%;">
|
||||||
<label>Artikel</label>
|
<label>Artikel</label>
|
||||||
<AutoComplete v-model="model.variant"
|
<AutoComplete v-model="model.variant"
|
||||||
:optionLabel="(item) => [item.nummer, item.name].join(' ')"
|
:option-label="(item) => [item.nummer, item.name].join(' ')"
|
||||||
ajax-filter="artikelnummer"
|
ajax-filter="artikelnummer"
|
||||||
forceSelection
|
force-selection
|
||||||
|
autofocus
|
||||||
/>
|
/>
|
||||||
<template v-for="group in model.groups">
|
<template v-for="group in model.groups">
|
||||||
<label>{{ group.name }}</label>
|
<label>{{ group.name }}</label>
|
||||||
<Dropdown v-model="group.selected" :options="group.options" optionLabel="name" optionValue="value" />
|
<Select v-model="group.selected" :options="group.options" option-label="name" option-value="value" />
|
||||||
</template>
|
</template>
|
||||||
</div>
|
</div>
|
||||||
|
</Fluid>
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<Button label="ABBRECHEN" @click="emit('close')" />
|
<Button label="ABBRECHEN" @click="emit('close')" />
|
||||||
<Button label="SPEICHERN" @click="save" />
|
<Button label="SPEICHERN" @click="save" />
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
// SPDX-FileCopyrightText: 2023 Andreas Palm
|
// SPDX-FileCopyrightText: 2023-2024 Andreas Palm
|
||||||
//
|
//
|
||||||
// SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
// SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
||||||
|
|
||||||
import App from "./App.vue";
|
import App from "./App.vue";
|
||||||
import {createVueApp} from "@res/js/vue";
|
import {createVueApp} from "@res/js/vue";
|
||||||
|
|
||||||
const app = createVueApp(App).mount('#vueapp')
|
createVueApp(App).mount('#vueapp')
|
59
composer.json
Normal file
59
composer.json
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
{
|
||||||
|
"require": {
|
||||||
|
"php": "^7.4|^8",
|
||||||
|
"ext-gd": "*",
|
||||||
|
"aura/sqlquery": "2.7.1",
|
||||||
|
"aws/aws-sdk-php": "3.175.2",
|
||||||
|
"container-interop/container-interop": "1.2.0",
|
||||||
|
"ezyang/htmlpurifier": "v4.13.0",
|
||||||
|
"fiskaly/fiskaly-sdk-php": "1.2.100",
|
||||||
|
"guzzlehttp/guzzle": "6.5.5",
|
||||||
|
"guzzlehttp/promises": "1.4.1",
|
||||||
|
"guzzlehttp/psr7": "1.8.1",
|
||||||
|
"laminas/laminas-loader": "2.6.1",
|
||||||
|
"laminas/laminas-mime": "2.7.4",
|
||||||
|
"laminas/laminas-mail": "2.12.5",
|
||||||
|
"laminas/laminas-stdlib": "3.2.1",
|
||||||
|
"laminas/laminas-validator": "2.13.5",
|
||||||
|
"league/color-extractor": "0.3.2",
|
||||||
|
"league/flysystem": "1.0.70",
|
||||||
|
"league/oauth1-client": "v1.9.0",
|
||||||
|
"league/oauth2-client": "2.6.0",
|
||||||
|
"lfkeitel/phptotp": "v1.0.0",
|
||||||
|
"mtdowling/jmespath.php": "2.6.0",
|
||||||
|
"nikic/fast-route": "v1.3.0",
|
||||||
|
"phpmailer/phpmailer": "v6.3.0",
|
||||||
|
"phpseclib/phpseclib": "2.0.30",
|
||||||
|
"psr/container": "1.1.1",
|
||||||
|
"psr/http-message": "1.0.1",
|
||||||
|
"psr/log": "1.1.3",
|
||||||
|
"rakit/validation": "v0.22.3",
|
||||||
|
"sabre/dav": "3.2.3",
|
||||||
|
"smarty/smarty": "v3.1.39",
|
||||||
|
"swiss-payment-slip/swiss-payment-slip": "0.13.0 as 0.11.1",
|
||||||
|
"swiss-payment-slip/swiss-payment-slip-fpdf": "0.6.0",
|
||||||
|
"symfony/polyfill-intl-idn": "v1.22.1",
|
||||||
|
"symfony/polyfill-intl-normalizer": "v1.22.1",
|
||||||
|
"symfony/polyfill-mbstring": "v1.22.1",
|
||||||
|
"symfony/polyfill-php72": "v1.22.1",
|
||||||
|
"tecnickcom/tcpdf": "6.3.5",
|
||||||
|
"y0lk/oauth1-etsy": "1.1.0"
|
||||||
|
},
|
||||||
|
"replace": {
|
||||||
|
"itbz/fpdf": "*",
|
||||||
|
"laminas/laminas-zendframework-bridge": "*"
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"Xentral\\": "classes"
|
||||||
|
},
|
||||||
|
"classmap": ["www/lib/versandarten/"]
|
||||||
|
},
|
||||||
|
"config": {
|
||||||
|
"platform": {
|
||||||
|
"php": "7.4",
|
||||||
|
"ext-gd": "7.4"
|
||||||
|
},
|
||||||
|
"optimize-autoloader": true
|
||||||
|
}
|
||||||
|
}
|
3104
composer.lock
generated
Normal file
3104
composer.lock
generated
Normal file
File diff suppressed because it is too large
Load Diff
8
docker-compose.override.example.yml
Normal file
8
docker-compose.override.example.yml
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
# This file can be used to override defaults from the docker-compose.yml file
|
||||||
|
# if it is copied/renamed to docker-compose.override.yml
|
||||||
|
|
||||||
|
version: '3.9'
|
||||||
|
services:
|
||||||
|
vite:
|
||||||
|
# Set this to your local uid:gid to run the frontend build as your user and keep the working directory clean
|
||||||
|
user: 1000:1000
|
62
docker-compose.yml
Normal file
62
docker-compose.yml
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
version: '3.9'
|
||||||
|
services:
|
||||||
|
vite:
|
||||||
|
build:
|
||||||
|
context: .
|
||||||
|
dockerfile: docker/Dockerfile
|
||||||
|
target: frontend
|
||||||
|
image: openxe_frontend
|
||||||
|
entrypoint: npm run dev
|
||||||
|
volumes:
|
||||||
|
- .:/app
|
||||||
|
ports:
|
||||||
|
- "5173:5173"
|
||||||
|
app_init:
|
||||||
|
image: openxe:test
|
||||||
|
volumes:
|
||||||
|
- .:/var/www/html
|
||||||
|
working_dir: /var/www/html/upgrade
|
||||||
|
entrypoint: php data/upgrade.php -db -do
|
||||||
|
depends_on:
|
||||||
|
mysql:
|
||||||
|
condition: service_healthy
|
||||||
|
app:
|
||||||
|
build:
|
||||||
|
context: .
|
||||||
|
dockerfile: docker/Dockerfile
|
||||||
|
image: openxe:test
|
||||||
|
volumes:
|
||||||
|
- .:/var/www/html
|
||||||
|
ports:
|
||||||
|
- "8081:80"
|
||||||
|
depends_on:
|
||||||
|
app_init:
|
||||||
|
condition: service_completed_successfully
|
||||||
|
mysql:
|
||||||
|
condition: service_healthy
|
||||||
|
mysql:
|
||||||
|
image: mariadb:10.11
|
||||||
|
environment:
|
||||||
|
MYSQL_ROOT_PASSWORD: "rootpw"
|
||||||
|
MYSQL_USER: "openxe"
|
||||||
|
MYSQL_PASSWORD: "openxe"
|
||||||
|
MYSQL_DATABASE: "openxe"
|
||||||
|
MARIADB_AUTO_UPGRADE: "1"
|
||||||
|
volumes:
|
||||||
|
- mysqldata:/var/lib/mysql
|
||||||
|
ports:
|
||||||
|
- "3306:3306"
|
||||||
|
healthcheck:
|
||||||
|
interval: 5s
|
||||||
|
retries: 3
|
||||||
|
test:
|
||||||
|
[
|
||||||
|
"CMD",
|
||||||
|
"healthcheck.sh",
|
||||||
|
"--connect",
|
||||||
|
"--innodb_initialized"
|
||||||
|
]
|
||||||
|
timeout: 30s
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
mysqldata: {}
|
29
docker/Dockerfile
Normal file
29
docker/Dockerfile
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
ARG PHP_EXT="gd ldap imap mysqli soap zip"
|
||||||
|
ARG DEB_PKG="libc-client2007e libaom3 libavif15 libdav1d6 libfreetype6 libjpeg62-turbo libldap-common libpng16-16 libwebp7 libxpm4 libzip4"
|
||||||
|
ARG DEB_PKG_TMP="cmake gnutls-dev libaom-dev libavif-dev libbz2-dev libc-client-dev libdav1d-dev libfreetype6-dev libjpeg62-turbo-dev libkrb5-dev libldap2-dev libpng-dev libssl-dev libwebp-dev libxml2-dev libxpm-dev libzip-dev zlib1g-dev"
|
||||||
|
|
||||||
|
FROM node:20 as frontend
|
||||||
|
WORKDIR /app
|
||||||
|
COPY package.json package-lock.json vite.config.js /app/
|
||||||
|
RUN npm install
|
||||||
|
COPY classes /app/classes
|
||||||
|
COPY resources /app/resources
|
||||||
|
COPY www /app/www
|
||||||
|
RUN npm run build
|
||||||
|
|
||||||
|
#FROM php:8.1-fpm as fpm_server
|
||||||
|
FROM php:8.1-apache as web_server
|
||||||
|
ARG PHP_EXT
|
||||||
|
ARG DEB_PKG
|
||||||
|
ARG DEB_PKG_TMP
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
RUN apt-get update && apt-get install -y ${DEB_PKG} ${DEB_PKG_TMP} && \
|
||||||
|
docker-php-ext-configure imap --with-kerberos --with-imap-ssl && \
|
||||||
|
docker-php-ext-install ${PHP_EXT} && \
|
||||||
|
apt-get remove --purge -y ${DEB_PKG_TMP} && \
|
||||||
|
mv "$PHP_INI_DIR/php.ini-production" "$PHP_INI_DIR/php.ini"
|
||||||
|
|
||||||
|
COPY docker/php "$PHP_INI_DIR/conf.d/"
|
||||||
|
COPY --chown=www-data:www-data . /var/www/html
|
||||||
|
COPY --chown=www-data:www-data --from=frontend /app/www/dist /var/www/html/www/dist
|
3
docker/php/memory.ini
Normal file
3
docker/php/memory.ini
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
memory_limit = 256M
|
||||||
|
upload_max_filesize = 32M
|
||||||
|
post_max_size = 32M
|
14648
package-lock.json
generated
14648
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
33
package.json
33
package.json
@ -1,29 +1,26 @@
|
|||||||
{
|
{
|
||||||
"private": true,
|
"private": true,
|
||||||
|
"type": "module",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"api-docs:validate": "./node_modules/raml2html/bin/raml2html --validate www/api/docs.raml > /dev/null",
|
"api-docs:validate": "./node_modules/raml2html/bin/raml2html --validate www/api/docs.raml > /dev/null",
|
||||||
"api-docs:build": "./node_modules/raml2html/bin/raml2html --validate --theme raml2html-werk-theme --input www/api/docs.raml --output www/api/docs-tmp.html && cat www/api/docs-tmp.html | sed -e 's/<\\/head>/<link rel=\\\"stylesheet\\\" href=\\\"\\.\\/assets\\/docs_custom\\.css\\\"><\\/head>/' > www/api/docs.html && rm www/api/docs-tmp.html",
|
"api-docs:build": "./node_modules/raml2html/bin/raml2html --validate --theme raml2html-werk-theme --input www/api/docs.raml --output www/api/docs-tmp.html && cat www/api/docs-tmp.html | sed -e 's/<\\/head>/<link rel=\\\"stylesheet\\\" href=\\\"\\.\\/assets\\/docs_custom\\.css\\\"><\\/head>/' > www/api/docs.html && rm www/api/docs-tmp.html",
|
||||||
"dev": "npm run development",
|
"dev": "vite -d --cors --host ::",
|
||||||
"development": "./node_modules/cross-env/src/bin/cross-env-shell.js NODE_ENV=development node_modules/webpack/bin/webpack.js --progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js",
|
"build": "vite build",
|
||||||
"watch": "npm run development -- --watch",
|
"preview": "vite preview"
|
||||||
"hot": "./node_modules/cross-env/src/bin/cross-env-shell.js NODE_ENV=development node_modules/webpack-dev-server/bin/webpack-dev-server.js --inline --hot --disable-host-check --config=node_modules/laravel-mix/setup/webpack.config.js",
|
|
||||||
"prod": "npm run production",
|
|
||||||
"production": "./node_modules/cross-env/src/bin/cross-env-shell.js NODE_ENV=production node_modules/webpack/bin/webpack.js --no-progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js"
|
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"cross-env": "^7.0",
|
"raml2html": "^7.8.0",
|
||||||
"laravel-mix": "^5.0.1",
|
"raml2html-werk-theme": "^1.3.4"
|
||||||
"raml2html": "^7.6.0",
|
|
||||||
"raml2html-werk-theme": "^1.1.0",
|
|
||||||
"resolve-url-loader": "^3.1.0",
|
|
||||||
"sass": "^1.15.2",
|
|
||||||
"sass-loader": "^8.0.0"
|
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@vitejs/plugin-vue": "^4.3.4",
|
"@primevue/icons": "^4.0.7",
|
||||||
"axios": "^1.5.0",
|
"@primevue/themes": "^4.0.7",
|
||||||
"primevue": "^3.35.0",
|
"@vitejs/plugin-vue": "^5",
|
||||||
"vite": "^4.4.9",
|
"axios": "^1",
|
||||||
"vue": "^3.3.4"
|
"glob": "^11",
|
||||||
|
"primeicons": "^7.0.0",
|
||||||
|
"primevue": "^4",
|
||||||
|
"vite": "^5",
|
||||||
|
"vue": "^3"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* SPDX-FileCopyrightText: 2019 Xentral ERP Software GmbH, Fuggerstrasse 11, D-86150 Augsburg
|
* SPDX-FileCopyrightText: 2019 Xentral ERP Software GmbH, Fuggerstrasse 11, D-86150 Augsburg
|
||||||
* SPDX-FileCopyrightText: 2023 Andreas Palm
|
* SPDX-FileCopyrightText: 2023-2024 Andreas Palm
|
||||||
*
|
*
|
||||||
* SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
* SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
||||||
*/
|
*/
|
||||||
@ -104,104 +104,6 @@ class Player {
|
|||||||
$module = 'welcome';
|
$module = 'welcome';
|
||||||
$action = 'main';
|
$action = 'main';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if($this->app->erp->isIoncube() && method_exists($this->app->erp, 'IoncubeProperty')
|
|
||||||
&& WithGUI() && !(($module=='welcome' && $action=='upgrade') || $module=='' || ($module=='welcome' && $action=='start')))
|
|
||||||
{
|
|
||||||
if(method_exists('erpAPI','Ioncube_getMaxUser'))
|
|
||||||
{
|
|
||||||
$maxuser = erpAPI::Ioncube_getMaxUser();
|
|
||||||
}elseif(method_exists($this->app->erp, 'IoncubegetMaxUser'))
|
|
||||||
{
|
|
||||||
$maxuser = $this->app->erp->IoncubegetMaxUser();
|
|
||||||
}else{
|
|
||||||
$maxuser = 0;
|
|
||||||
}
|
|
||||||
if(method_exists('erpAPI','Ioncube_getMaxLightusers'))
|
|
||||||
{
|
|
||||||
$maxlightuser = erpAPI::Ioncube_getMaxLightusers();
|
|
||||||
}else{
|
|
||||||
$maxlightuser = 0;
|
|
||||||
}
|
|
||||||
if($maxuser)
|
|
||||||
{
|
|
||||||
$anzuser2 = 0;
|
|
||||||
if($maxlightuser > 0) {
|
|
||||||
$anzuser2 = (int)$this->app->DB->Select("SELECT count(DISTINCT u.id) FROM `user` u WHERE activ = 1 AND type = 'lightuser' ");
|
|
||||||
$anzuser = (int)$this->app->DB->Select("SELECT count(id) FROM `user` WHERE activ = 1 AND not isnull(hwtoken) AND hwtoken <> 4") - $anzuser2;
|
|
||||||
$anzuserzeiterfassung = (int)$this->app->DB->Select("SELECT count(*) from user where activ = 1 AND hwtoken = 4 AND type != 'lightuser'");
|
|
||||||
}else{
|
|
||||||
$anzuser = $this->app->DB->Select("SELECT count(*) from user where activ = 1 AND hwtoken <> 4 ");
|
|
||||||
$anzuserzeiterfassung = (int)$this->app->DB->Select("SELECT count(*) from user where activ = 1 AND hwtoken = 4");
|
|
||||||
}
|
|
||||||
|
|
||||||
$maxmitarbeiterzeiterfassung = $this->app->erp->ModulVorhanden('mitarbeiterzeiterfassung')?$maxuser:0;
|
|
||||||
if($anzuser > $maxuser
|
|
||||||
|| (
|
|
||||||
($anzuser + $anzuserzeiterfassung + $anzuser2) >
|
|
||||||
$maxmitarbeiterzeiterfassung + $maxuser + $maxlightuser
|
|
||||||
)
|
|
||||||
|| (($anzuser + $anzuserzeiterfassung) > $maxmitarbeiterzeiterfassung + $maxuser)
|
|
||||||
) {
|
|
||||||
if(!(($module == 'welcome' &&
|
|
||||||
($action=='info' || $action == 'start' || $action == 'logout' || $action == '' || $action == 'main')) ||
|
|
||||||
($module == 'einstellungen' && ($action == 'list' || $action == '')) ||
|
|
||||||
$module == 'benutzer'
|
|
||||||
))
|
|
||||||
{
|
|
||||||
if($this->app->erp->RechteVorhanden('benutzer','list'))
|
|
||||||
{
|
|
||||||
$module = 'benutzer';
|
|
||||||
$action = 'list';
|
|
||||||
|
|
||||||
if($maxlightuser > 0){
|
|
||||||
$error = 'Es existieren mehr aktive Benutzer als Ihre Lizenz erlaubt: Benutzer ' . ($anzuser + $anzuser2) . ($maxlightuser > 0 ? ' (davon ' . $anzuser2 . ' Light-User)' : '') . ' von ' . ($maxuser + $maxlightuser) . ($maxlightuser > 0 ? ' (' . $maxlightuser . ' Light-User)' : '');
|
|
||||||
}else{
|
|
||||||
$error = 'Es existieren mehr aktive Benutzer als Ihre Lizenz erlaubt: Benutzer ' . ($anzuser + $anzuser2) . ($maxlightuser > 0 ? ' (davon ' . $anzuser2 . ' Zeiterfassungs-User)' : '') . ' von ' . ($maxuser + $anzuser2) . ($anzuser2 > 0 ? ' (' . $anzuser2 . ' Zeiterfassungs-User)' : '');
|
|
||||||
}
|
|
||||||
$error = '<div class="error">'.$error.'</div>';
|
|
||||||
$this->app->Tpl->Add('MESSAGE', $error);
|
|
||||||
$this->app->Secure->GET['msg'] = $this->app->erp->base64_url_encode($error);
|
|
||||||
}else{
|
|
||||||
$module = 'welcome';
|
|
||||||
$action = 'info';
|
|
||||||
}
|
|
||||||
$this->app->Secure->GET['module'] = $module;
|
|
||||||
$this->app->Secure->GET['action'] = $action;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if(method_exists('erpAPI','Ioncube_Property'))
|
|
||||||
{
|
|
||||||
$deaktivateonexp = erpAPI::Ioncube_Property('deaktivateonexp');
|
|
||||||
}else{
|
|
||||||
$deaktivateonexp = $this->app->erp->IoncubeProperty('deaktivateonexp');
|
|
||||||
}
|
|
||||||
if($deaktivateonexp)
|
|
||||||
{
|
|
||||||
if(method_exists('erpAPI','Ioncube_HasExpired'))
|
|
||||||
{
|
|
||||||
$IoncubeHasExpired = erpAPI::Ioncube_HasExpired();
|
|
||||||
}elseif(method_exists($this->app->erp, 'IoncubeHasExpired'))
|
|
||||||
{
|
|
||||||
$IoncubeHasExpired = $this->app->erp->IoncubeHasExpired();
|
|
||||||
}else{
|
|
||||||
$IoncubeHasExpired = false;
|
|
||||||
}
|
|
||||||
}else{
|
|
||||||
$IoncubeHasExpired = false;
|
|
||||||
}
|
|
||||||
if($deaktivateonexp && $IoncubeHasExpired
|
|
||||||
&& !(($module == 'welcome' && $action='logout') || ($module == 'welcome' && $action='start') || ($module == 'welcome' && $action='main'))
|
|
||||||
)
|
|
||||||
{
|
|
||||||
$module = 'welcome';
|
|
||||||
$action = 'info';
|
|
||||||
$this->app->Secure->GET['module'] = $module;
|
|
||||||
$this->app->Secure->GET['action'] = $action;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if($action!="list" && $action!="css" && $action!="logo" && $action!="poll" && $module!="ajax" && $module!="protokoll" && $action!="thumbnail"){
|
if($action!="list" && $action!="css" && $action!="logo" && $action!="poll" && $module!="ajax" && $module!="protokoll" && $action!="thumbnail"){
|
||||||
|
@ -295,8 +295,6 @@ class Acl
|
|||||||
/** @var EnvironmentConfig $environmentConfig */
|
/** @var EnvironmentConfig $environmentConfig */
|
||||||
$environmentConfig = $this->app->Container->get('EnvironmentConfig');
|
$environmentConfig = $this->app->Container->get('EnvironmentConfig');
|
||||||
|
|
||||||
$mailAddresses = array_merge($mailAddresses, $environmentConfig->getSystemFallbackEmailAddresses());
|
|
||||||
|
|
||||||
return array_unique($mailAddresses);
|
return array_unique($mailAddresses);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -438,18 +436,6 @@ class Acl
|
|||||||
if(!empty($serverLocation)) {
|
if(!empty($serverLocation)) {
|
||||||
$server = rtrim($serverLocation,'/') . '?module=welcome&action=passwortvergessen&code=' . $code;
|
$server = rtrim($serverLocation,'/') . '?module=welcome&action=passwortvergessen&code=' . $code;
|
||||||
}
|
}
|
||||||
foreach(['default', 'fallback'] as $sentSetting) {
|
|
||||||
if($sentSetting === 'fallback') {
|
|
||||||
$db = $this->app->Conf->WFdbname;
|
|
||||||
if(
|
|
||||||
empty(erpAPI::Ioncube_Property('cloudemail'))
|
|
||||||
|| $this->app->erp->firmendaten[$db]['email'] === erpAPI::Ioncube_Property('cloudemail')
|
|
||||||
) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
$this->app->erp->firmendaten[$db]['mailanstellesmtp'] = 1;
|
|
||||||
$this->app->erp->firmendaten[$db]['email'] = erpAPI::Ioncube_Property('cloudemail');
|
|
||||||
}
|
|
||||||
foreach ($emailAddresses as $email) {
|
foreach ($emailAddresses as $email) {
|
||||||
$recipientMailAddress = $email;
|
$recipientMailAddress = $email;
|
||||||
$recipientName = $name;
|
$recipientName = $name;
|
||||||
@ -467,8 +453,7 @@ class Acl
|
|||||||
$recipientMailAddress, $recipientName, $mailSubject, $mailContent, '', 0, true, '', '', true
|
$recipientMailAddress, $recipientName, $mailSubject, $mailContent, '', 0, true, '', '', true
|
||||||
);
|
);
|
||||||
if($mailSuccessfullySent){
|
if($mailSuccessfullySent){
|
||||||
break 2;
|
break;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -64,7 +64,7 @@ class ModuleScriptCache
|
|||||||
$this->absoluteCacheDir = $this->baseDir . '/www/cache';
|
$this->absoluteCacheDir = $this->baseDir . '/www/cache';
|
||||||
$this->relativeCacheDir = './cache';
|
$this->relativeCacheDir = './cache';
|
||||||
$this->assetDir = '/dist';
|
$this->assetDir = '/dist';
|
||||||
$this->assetManifest = json_decode(file_get_contents($this->baseDir. '/www' . $this->assetDir . '/manifest.json'));
|
$this->assetManifest = json_decode(file_get_contents($this->baseDir. '/www' . $this->assetDir . '/.vite/manifest.json'));
|
||||||
|
|
||||||
// Cache-Ordner anzulegen, falls nicht existent
|
// Cache-Ordner anzulegen, falls nicht existent
|
||||||
if (!is_dir($this->absoluteCacheDir)) {
|
if (!is_dir($this->absoluteCacheDir)) {
|
||||||
@ -221,11 +221,7 @@ class ModuleScriptCache
|
|||||||
$realPath = realpath($this->baseDir . '/' . $file);
|
$realPath = realpath($this->baseDir . '/' . $file);
|
||||||
if (!is_file($realPath))
|
if (!is_file($realPath))
|
||||||
continue;
|
continue;
|
||||||
|
$this->javascriptModules[] = $file;
|
||||||
if (isset($this->assetManifest->$file))
|
|
||||||
$this->javascriptModules[] = $this->assetManifest->$file;
|
|
||||||
else
|
|
||||||
$this->javascriptModules[] = $realPath;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -299,29 +295,48 @@ class ModuleScriptCache
|
|||||||
if (empty($this->javascriptModules))
|
if (empty($this->javascriptModules))
|
||||||
return '';
|
return '';
|
||||||
|
|
||||||
$html = '';
|
$tags = [];
|
||||||
foreach ($this->javascriptModules as $module) {
|
|
||||||
if (is_object($module)) {
|
|
||||||
if (defined('VITE_DEV_SERVER')) {
|
if (defined('VITE_DEV_SERVER')) {
|
||||||
$url = 'http://' . VITE_DEV_SERVER . '/' . $module->src;
|
foreach ($this->javascriptModules as $module)
|
||||||
|
$tags[] = sprintf('<script type="module" src="%s"></script>',VITE_DEV_SERVER.'/'.$module);
|
||||||
} else {
|
} else {
|
||||||
$url = '.'.$this->assetDir . '/' . $module->file;
|
foreach ($this->javascriptModules as $module)
|
||||||
if (isset($module->css)) {
|
$this->includeChunk($module, true);
|
||||||
foreach ($module->css as $css)
|
foreach (array_unique($this->renderedCss) as $css)
|
||||||
$html .= sprintf('<link rel="stylesheet" type="text/css" href="%s" />', '.'.$this->assetDir.'/'.$css);
|
$tags[] = sprintf('<link rel="stylesheet" href="%s" />', $this->GetLinkUrl($css));
|
||||||
$html .= "\r\n";
|
foreach (array_unique($this->renderedJs) as $js)
|
||||||
}
|
$tags[] = sprintf('<script type="module" src="%s"></script>', $this->GetLinkUrl($js));
|
||||||
}
|
foreach (array_diff(array_unique($this->renderedPreload), $this->renderedJs) as $preload)
|
||||||
} elseif (str_starts_with($module,$this->baseDir.'/www')) {
|
$tags[] = sprintf('<link rel="modulepreload" href="%s" />', $this->GetLinkUrl($preload));
|
||||||
$url = '.'.substr($module, strlen($this->baseDir)+4);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($url)) {
|
return join("\n", $tags);
|
||||||
$html .= sprintf('<script type="module" src="%s"></script>', $url);
|
|
||||||
$html .= "\r\n";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private array $renderedCss = [];
|
||||||
|
private array $renderedJs = [];
|
||||||
|
private array $renderedPreload = [];
|
||||||
|
private function includeChunk(string $chunkName, bool $isRoot = false) : void
|
||||||
|
{
|
||||||
|
if (!isset($this->assetManifest->$chunkName))
|
||||||
|
return;
|
||||||
|
|
||||||
|
$manifestEntry = $this->assetManifest->$chunkName;
|
||||||
|
foreach ($manifestEntry->css as $cssFile)
|
||||||
|
$this->renderedCss[] = $cssFile;
|
||||||
|
foreach ($manifestEntry->imports as $import)
|
||||||
|
$this->includeChunk($import);
|
||||||
|
|
||||||
|
if ($isRoot)
|
||||||
|
$this->renderedJs[] = $manifestEntry->file;
|
||||||
|
else
|
||||||
|
$this->renderedPreload[] = $manifestEntry->file;
|
||||||
}
|
}
|
||||||
return $html;
|
|
||||||
|
private function GetLinkUrl(string $chunkFile) {
|
||||||
|
if (str_starts_with($chunkFile, 'http:'))
|
||||||
|
return $chunkFile;
|
||||||
|
return '.'.$this->assetDir.'/'.$chunkFile;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -4,12 +4,12 @@
|
|||||||
* SPDX-License-Identifier: AGPL-3.0-only
|
* SPDX-License-Identifier: AGPL-3.0-only
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@import "basecomponent.css";
|
||||||
@import "autocomplete.css";
|
@import "autocomplete.css";
|
||||||
@import "checkbox.css";
|
|
||||||
@import "dialog.css";
|
@import "dialog.css";
|
||||||
@import "dropdown.css";
|
@import "dropdown.css";
|
||||||
|
@import "icons.css";
|
||||||
@import "listbox.css";
|
@import "listbox.css";
|
||||||
@import "multiselect.css";
|
|
||||||
|
|
||||||
.p-component-overlay {
|
.p-component-overlay {
|
||||||
background-color: rgba(170,170,170,0.7);
|
background-color: rgba(170,170,170,0.7);
|
||||||
@ -26,6 +26,6 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
.p-icon {
|
.p-icon {
|
||||||
width: 1em;
|
width: 1rem;
|
||||||
height: 1em;
|
height: 1rem;
|
||||||
}
|
}
|
||||||
|
@ -106,3 +106,101 @@ input[type=text].p-autocomplete-dd-input {
|
|||||||
width: 14px;
|
width: 14px;
|
||||||
height: 14px;
|
height: 14px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@layer primevue {
|
||||||
|
.p-autocomplete {
|
||||||
|
display: inline-flex;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-autocomplete-loader {
|
||||||
|
position: absolute;
|
||||||
|
top: 50%;
|
||||||
|
margin-top: -0.5rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-autocomplete-dd .p-autocomplete-input {
|
||||||
|
flex: 1 1 auto;
|
||||||
|
width: 1%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-autocomplete-dd .p-autocomplete-input,
|
||||||
|
.p-autocomplete-dd .p-autocomplete-multiple-container {
|
||||||
|
border-top-right-radius: 0;
|
||||||
|
border-bottom-right-radius: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-autocomplete-dd .p-autocomplete-dropdown {
|
||||||
|
border-top-left-radius: 0;
|
||||||
|
border-bottom-left-radius: 0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-autocomplete .p-autocomplete-panel {
|
||||||
|
min-width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-autocomplete-panel {
|
||||||
|
position: absolute;
|
||||||
|
overflow: auto;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-autocomplete-items {
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
list-style-type: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-autocomplete-item {
|
||||||
|
cursor: pointer;
|
||||||
|
white-space: nowrap;
|
||||||
|
position: relative;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-autocomplete-multiple-container {
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
list-style-type: none;
|
||||||
|
cursor: text;
|
||||||
|
overflow: hidden;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
flex-wrap: wrap;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-autocomplete-token {
|
||||||
|
cursor: default;
|
||||||
|
display: inline-flex;
|
||||||
|
align-items: center;
|
||||||
|
flex: 0 0 auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-autocomplete-token-icon {
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-autocomplete-input-token {
|
||||||
|
flex: 1 1 auto;
|
||||||
|
display: inline-flex;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-autocomplete-input-token input {
|
||||||
|
border: 0 none;
|
||||||
|
outline: 0 none;
|
||||||
|
background-color: transparent;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
box-shadow: none;
|
||||||
|
border-radius: 0;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-fluid .p-autocomplete {
|
||||||
|
display: flex;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-fluid .p-autocomplete-dd .p-autocomplete-input {
|
||||||
|
width: 1%;
|
||||||
|
}
|
||||||
|
}
|
163
resources/css/primevue/basecomponent.css
Normal file
163
resources/css/primevue/basecomponent.css
Normal file
@ -0,0 +1,163 @@
|
|||||||
|
@layer primevue {
|
||||||
|
.p-component, .p-component * {
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
.p-hidden-space {
|
||||||
|
visibility: hidden;
|
||||||
|
}
|
||||||
|
.p-reset {
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
border: 0;
|
||||||
|
outline: 0;
|
||||||
|
text-decoration: none;
|
||||||
|
font-size: 100%;
|
||||||
|
list-style: none;
|
||||||
|
}
|
||||||
|
.p-disabled, .p-disabled * {
|
||||||
|
cursor: default;
|
||||||
|
pointer-events: none;
|
||||||
|
user-select: none;
|
||||||
|
}
|
||||||
|
.p-component-overlay {
|
||||||
|
position: fixed;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
.p-unselectable-text {
|
||||||
|
user-select: none;
|
||||||
|
}
|
||||||
|
.p-sr-only {
|
||||||
|
border: 0;
|
||||||
|
clip: rect(1px, 1px, 1px, 1px);
|
||||||
|
clip-path: inset(50%);
|
||||||
|
height: 1px;
|
||||||
|
margin: -1px;
|
||||||
|
overflow: hidden;
|
||||||
|
padding: 0;
|
||||||
|
position: absolute;
|
||||||
|
width: 1px;
|
||||||
|
word-wrap: normal;
|
||||||
|
}
|
||||||
|
.p-link {
|
||||||
|
text-align: left;
|
||||||
|
background-color: transparent;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
border: none;
|
||||||
|
cursor: pointer;
|
||||||
|
user-select: none;
|
||||||
|
}
|
||||||
|
.p-link:disabled {
|
||||||
|
cursor: default;
|
||||||
|
}
|
||||||
|
/* Non vue overlay animations */
|
||||||
|
.p-connected-overlay {
|
||||||
|
opacity: 0;
|
||||||
|
transform: scaleY(0.8);
|
||||||
|
transition: transform .12s cubic-bezier(0, 0, 0.2, 1), opacity .12s cubic-bezier(0, 0, 0.2, 1);
|
||||||
|
}
|
||||||
|
.p-connected-overlay-visible {
|
||||||
|
opacity: 1;
|
||||||
|
transform: scaleY(1);
|
||||||
|
}
|
||||||
|
.p-connected-overlay-hidden {
|
||||||
|
opacity: 0;
|
||||||
|
transform: scaleY(1);
|
||||||
|
transition: opacity .1s linear;
|
||||||
|
}
|
||||||
|
/* Vue based overlay animations */
|
||||||
|
.p-connected-overlay-enter-from {
|
||||||
|
opacity: 0;
|
||||||
|
transform: scaleY(0.8);
|
||||||
|
}
|
||||||
|
.p-connected-overlay-leave-to {
|
||||||
|
opacity: 0;
|
||||||
|
}
|
||||||
|
.p-connected-overlay-enter-active {
|
||||||
|
transition: transform .12s cubic-bezier(0, 0, 0.2, 1), opacity .12s cubic-bezier(0, 0, 0.2, 1);
|
||||||
|
}
|
||||||
|
.p-connected-overlay-leave-active {
|
||||||
|
transition: opacity .1s linear;
|
||||||
|
}
|
||||||
|
/* Toggleable Content */
|
||||||
|
.p-toggleable-content-enter-from,
|
||||||
|
.p-toggleable-content-leave-to {
|
||||||
|
max-height: 0;
|
||||||
|
}
|
||||||
|
.p-toggleable-content-enter-to,
|
||||||
|
.p-toggleable-content-leave-from {
|
||||||
|
max-height: 1000px;
|
||||||
|
}
|
||||||
|
.p-toggleable-content-leave-active {
|
||||||
|
overflow: hidden;
|
||||||
|
transition: max-height 0.45s cubic-bezier(0, 1, 0, 1);
|
||||||
|
}
|
||||||
|
.p-toggleable-content-enter-active {
|
||||||
|
overflow: hidden;
|
||||||
|
transition: max-height 1s ease-in-out;
|
||||||
|
}
|
||||||
|
.p-button {
|
||||||
|
display: inline-flex;
|
||||||
|
cursor: pointer;
|
||||||
|
user-select: none;
|
||||||
|
align-items: center;
|
||||||
|
vertical-align: bottom;
|
||||||
|
text-align: center;
|
||||||
|
overflow: hidden;
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
.p-button-label {
|
||||||
|
flex: 1 1 auto;
|
||||||
|
}
|
||||||
|
.p-button-icon-right {
|
||||||
|
order: 1;
|
||||||
|
}
|
||||||
|
.p-button:disabled {
|
||||||
|
cursor: default;
|
||||||
|
}
|
||||||
|
.p-button-icon-only {
|
||||||
|
justify-content: center;
|
||||||
|
}
|
||||||
|
.p-button-icon-only .p-button-label {
|
||||||
|
visibility: hidden;
|
||||||
|
width: 0;
|
||||||
|
flex: 0 0 auto;
|
||||||
|
}
|
||||||
|
.p-button-vertical {
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
.p-button-icon-bottom {
|
||||||
|
order: 2;
|
||||||
|
}
|
||||||
|
.p-buttonset .p-button {
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
.p-buttonset .p-button:not(:last-child), .p-buttonset .p-button:not(:last-child):hover {
|
||||||
|
border-right: 0 none;
|
||||||
|
}
|
||||||
|
.p-buttonset .p-button:not(:first-of-type):not(:last-of-type) {
|
||||||
|
border-radius: 0;
|
||||||
|
}
|
||||||
|
.p-buttonset .p-button:first-of-type:not(:only-of-type) {
|
||||||
|
border-top-right-radius: 0;
|
||||||
|
border-bottom-right-radius: 0;
|
||||||
|
}
|
||||||
|
.p-buttonset .p-button:last-of-type:not(:only-of-type) {
|
||||||
|
border-top-left-radius: 0;
|
||||||
|
border-bottom-left-radius: 0;
|
||||||
|
}
|
||||||
|
.p-buttonset .p-button:focus {
|
||||||
|
position: relative;
|
||||||
|
z-index: 1;
|
||||||
|
}
|
||||||
|
.p-fluid .p-inputtext {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
.p-fluid .p-input-icon-left,
|
||||||
|
.p-fluid .p-input-icon-right {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
}
|
@ -32,3 +32,135 @@
|
|||||||
border-bottom-right-radius: 4px;
|
border-bottom-right-radius: 4px;
|
||||||
border-bottom-left-radius: 4px;
|
border-bottom-left-radius: 4px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@layer primevue {
|
||||||
|
.p-dialog-mask.p-component-overlay {
|
||||||
|
pointer-events: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-dialog {
|
||||||
|
max-height: 90%;
|
||||||
|
transform: scale(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-dialog-content {
|
||||||
|
overflow-y: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-dialog-header {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: space-between;
|
||||||
|
flex-shrink: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-dialog-footer {
|
||||||
|
flex-shrink: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-dialog .p-dialog-header-icons {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-dialog .p-dialog-header-icon {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
overflow: hidden;
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Fluid */
|
||||||
|
.p-fluid .p-dialog-footer .p-button {
|
||||||
|
width: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Animation */
|
||||||
|
/* Center */
|
||||||
|
.p-dialog-enter-active {
|
||||||
|
transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
|
||||||
|
}
|
||||||
|
.p-dialog-leave-active {
|
||||||
|
transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
|
||||||
|
}
|
||||||
|
.p-dialog-enter-from,
|
||||||
|
.p-dialog-leave-to {
|
||||||
|
opacity: 0;
|
||||||
|
transform: scale(0.7);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Top, Bottom, Left, Right, Top* and Bottom* */
|
||||||
|
.p-dialog-top .p-dialog,
|
||||||
|
.p-dialog-bottom .p-dialog,
|
||||||
|
.p-dialog-left .p-dialog,
|
||||||
|
.p-dialog-right .p-dialog,
|
||||||
|
.p-dialog-topleft .p-dialog,
|
||||||
|
.p-dialog-topright .p-dialog,
|
||||||
|
.p-dialog-bottomleft .p-dialog,
|
||||||
|
.p-dialog-bottomright .p-dialog {
|
||||||
|
margin: 0.75rem;
|
||||||
|
transform: translate3d(0px, 0px, 0px);
|
||||||
|
}
|
||||||
|
.p-dialog-top .p-dialog-enter-active,
|
||||||
|
.p-dialog-top .p-dialog-leave-active,
|
||||||
|
.p-dialog-bottom .p-dialog-enter-active,
|
||||||
|
.p-dialog-bottom .p-dialog-leave-active,
|
||||||
|
.p-dialog-left .p-dialog-enter-active,
|
||||||
|
.p-dialog-left .p-dialog-leave-active,
|
||||||
|
.p-dialog-right .p-dialog-enter-active,
|
||||||
|
.p-dialog-right .p-dialog-leave-active,
|
||||||
|
.p-dialog-topleft .p-dialog-enter-active,
|
||||||
|
.p-dialog-topleft .p-dialog-leave-active,
|
||||||
|
.p-dialog-topright .p-dialog-enter-active,
|
||||||
|
.p-dialog-topright .p-dialog-leave-active,
|
||||||
|
.p-dialog-bottomleft .p-dialog-enter-active,
|
||||||
|
.p-dialog-bottomleft .p-dialog-leave-active,
|
||||||
|
.p-dialog-bottomright .p-dialog-enter-active,
|
||||||
|
.p-dialog-bottomright .p-dialog-leave-active {
|
||||||
|
transition: all 0.3s ease-out;
|
||||||
|
}
|
||||||
|
.p-dialog-top .p-dialog-enter-from,
|
||||||
|
.p-dialog-top .p-dialog-leave-to {
|
||||||
|
transform: translate3d(0px, -100%, 0px);
|
||||||
|
}
|
||||||
|
.p-dialog-bottom .p-dialog-enter-from,
|
||||||
|
.p-dialog-bottom .p-dialog-leave-to {
|
||||||
|
transform: translate3d(0px, 100%, 0px);
|
||||||
|
}
|
||||||
|
.p-dialog-left .p-dialog-enter-from,
|
||||||
|
.p-dialog-left .p-dialog-leave-to,
|
||||||
|
.p-dialog-topleft .p-dialog-enter-from,
|
||||||
|
.p-dialog-topleft .p-dialog-leave-to,
|
||||||
|
.p-dialog-bottomleft .p-dialog-enter-from,
|
||||||
|
.p-dialog-bottomleft .p-dialog-leave-to {
|
||||||
|
transform: translate3d(-100%, 0px, 0px);
|
||||||
|
}
|
||||||
|
.p-dialog-right .p-dialog-enter-from,
|
||||||
|
.p-dialog-right .p-dialog-leave-to,
|
||||||
|
.p-dialog-topright .p-dialog-enter-from,
|
||||||
|
.p-dialog-topright .p-dialog-leave-to,
|
||||||
|
.p-dialog-bottomright .p-dialog-enter-from,
|
||||||
|
.p-dialog-bottomright .p-dialog-leave-to {
|
||||||
|
transform: translate3d(100%, 0px, 0px);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Maximize */
|
||||||
|
.p-dialog-maximized {
|
||||||
|
width: 100vw !important;
|
||||||
|
height: 100vh !important;
|
||||||
|
top: 0px !important;
|
||||||
|
left: 0px !important;
|
||||||
|
max-height: 100%;
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
.p-dialog-maximized .p-dialog-content {
|
||||||
|
flex-grow: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-confirm-dialog .p-dialog-content {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
}
|
@ -4,6 +4,87 @@
|
|||||||
* SPDX-License-Identifier: AGPL-3.0-only
|
* SPDX-License-Identifier: AGPL-3.0-only
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@layer primevue {
|
||||||
|
.p-dropdown {
|
||||||
|
display: inline-flex;
|
||||||
|
cursor: pointer;
|
||||||
|
position: relative;
|
||||||
|
user-select: none;
|
||||||
|
}
|
||||||
|
.p-dropdown-clear-icon {
|
||||||
|
position: absolute;
|
||||||
|
top: 50%;
|
||||||
|
margin-top: -0.5rem;
|
||||||
|
}
|
||||||
|
.p-dropdown-trigger {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
flex-shrink: 0;
|
||||||
|
}
|
||||||
|
.p-dropdown-label {
|
||||||
|
display: block;
|
||||||
|
white-space: nowrap;
|
||||||
|
overflow: hidden;
|
||||||
|
flex: 1 1 auto;
|
||||||
|
width: 1%;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
.p-dropdown-label-empty {
|
||||||
|
overflow: hidden;
|
||||||
|
opacity: 0;
|
||||||
|
}
|
||||||
|
input.p-dropdown-label {
|
||||||
|
cursor: default;
|
||||||
|
}
|
||||||
|
.p-dropdown .p-dropdown-panel {
|
||||||
|
min-width: 100%;
|
||||||
|
}
|
||||||
|
.p-dropdown-panel {
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
}
|
||||||
|
.p-dropdown-items-wrapper {
|
||||||
|
overflow: auto;
|
||||||
|
}
|
||||||
|
.p-dropdown-item {
|
||||||
|
cursor: pointer;
|
||||||
|
font-weight: normal;
|
||||||
|
white-space: nowrap;
|
||||||
|
position: relative;
|
||||||
|
overflow: hidden;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
.p-dropdown-item-group {
|
||||||
|
cursor: auto;
|
||||||
|
}
|
||||||
|
.p-dropdown-items {
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
list-style-type: none;
|
||||||
|
}
|
||||||
|
.p-dropdown-filter {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
.p-dropdown-filter-container {
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
.p-dropdown-filter-icon {
|
||||||
|
position: absolute;
|
||||||
|
top: 50%;
|
||||||
|
margin-top: -0.5rem;
|
||||||
|
}
|
||||||
|
.p-fluid .p-dropdown {
|
||||||
|
display: flex;
|
||||||
|
}
|
||||||
|
.p-fluid .p-dropdown .p-dropdown-label {
|
||||||
|
width: 1%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.p-dropdown {
|
.p-dropdown {
|
||||||
background: #ffffff;
|
background: #ffffff;
|
||||||
border: 1px solid #ced4da;
|
border: 1px solid #ced4da;
|
||||||
|
@ -4,6 +4,36 @@
|
|||||||
* SPDX-License-Identifier: AGPL-3.0-only
|
* SPDX-License-Identifier: AGPL-3.0-only
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@layer primevue {
|
||||||
|
.p-listbox-list-wrapper {
|
||||||
|
overflow: auto;
|
||||||
|
}
|
||||||
|
.p-listbox-list {
|
||||||
|
list-style-type: none;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
.p-listbox-item {
|
||||||
|
cursor: pointer;
|
||||||
|
position: relative;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
.p-listbox-item-group {
|
||||||
|
cursor: auto;
|
||||||
|
}
|
||||||
|
.p-listbox-filter-container {
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
.p-listbox-filter-icon {
|
||||||
|
position: absolute;
|
||||||
|
top: 50%;
|
||||||
|
margin-top: -0.5rem;
|
||||||
|
}
|
||||||
|
.p-listbox-filter {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.p-listbox {
|
.p-listbox {
|
||||||
background: #ffffff;
|
background: #ffffff;
|
||||||
color: #6d6d6f;
|
color: #6d6d6f;
|
||||||
|
@ -28,10 +28,6 @@
|
|||||||
gap: 0.25rem;
|
gap: 0.25rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.grid label {
|
.grid label, .grid .p-checkbox {
|
||||||
padding-top: 5px;
|
padding-top: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.grid input[type=text] {
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
@ -3,10 +3,23 @@
|
|||||||
// SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
// SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
||||||
|
|
||||||
import '@res/css/vue.css';
|
import '@res/css/vue.css';
|
||||||
import '@res/css/primevue/_base.css';
|
|
||||||
import {createApp} from "vue";
|
import {createApp} from "vue";
|
||||||
import PrimeVue from "primevue/config";
|
import PrimeVue from "primevue/config";
|
||||||
|
import Aura from '@primevue/themes/aura';
|
||||||
|
import {definePreset} from "@primevue/themes";
|
||||||
|
|
||||||
|
const OpenXePreset = definePreset(Aura, {
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
export function createVueApp(rootComponent, rootProps) {
|
export function createVueApp(rootComponent, rootProps) {
|
||||||
return createApp(rootComponent, rootProps).use(PrimeVue);
|
return createApp(rootComponent, rootProps)
|
||||||
|
.use(PrimeVue, {
|
||||||
|
theme: {
|
||||||
|
preset: OpenXePreset,
|
||||||
|
options: {
|
||||||
|
darkModeSelector: '.openXeDarkMode'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
@ -8,12 +8,13 @@ SPDX-License-Identifier: AGPL-3.0-only
|
|||||||
import {ref} from "vue";
|
import {ref} from "vue";
|
||||||
import AutoComplete from "primevue/autocomplete";
|
import AutoComplete from "primevue/autocomplete";
|
||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
import SearchIcon from "primevue/icons/search";
|
import SearchIcon from "@primevue/icons/search";
|
||||||
|
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
ajaxFilter: String,
|
ajaxFilter: String,
|
||||||
modelValue: null,
|
modelValue: null,
|
||||||
forceSelection: Boolean
|
forceSelection: Boolean,
|
||||||
|
inputId: String,
|
||||||
});
|
});
|
||||||
const emit = defineEmits(['update:modelValue']);
|
const emit = defineEmits(['update:modelValue']);
|
||||||
|
|
||||||
@ -42,6 +43,7 @@ async function search(event) {
|
|||||||
dataKey="id"
|
dataKey="id"
|
||||||
:forceSelection="forceSelection"
|
:forceSelection="forceSelection"
|
||||||
dropdown
|
dropdown
|
||||||
|
:input-id="inputId"
|
||||||
>
|
>
|
||||||
<template #dropdownicon>
|
<template #dropdownicon>
|
||||||
<SearchIcon />
|
<SearchIcon />
|
||||||
|
18
vendor/autoload.php
vendored
18
vendor/autoload.php
vendored
@ -2,6 +2,24 @@
|
|||||||
|
|
||||||
// autoload.php @generated by Composer
|
// 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';
|
require_once __DIR__ . '/composer/autoload_real.php';
|
||||||
|
|
||||||
return ComposerAutoloaderInit0c49a81c1214ef2f7493c6ce921b17ee::getLoader();
|
return ComposerAutoloaderInit0c49a81c1214ef2f7493c6ce921b17ee::getLoader();
|
||||||
|
169
vendor/bin/jp.php
vendored
Normal file → Executable file
169
vendor/bin/jp.php
vendored
Normal file → Executable file
@ -1,74 +1,119 @@
|
|||||||
#!/usr/bin/env php
|
#!/usr/bin/env php
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
if (file_exists(__DIR__ . '/../vendor/autoload.php')) {
|
/**
|
||||||
require __DIR__ . '/../vendor/autoload.php';
|
* Proxy PHP file generated by Composer
|
||||||
} elseif (file_exists(__DIR__ . '/../../../autoload.php')) {
|
*
|
||||||
require __DIR__ . '/../../../autoload.php';
|
* This file includes the referenced bin path (../mtdowling/jmespath.php/bin/jp.php)
|
||||||
} elseif (file_exists(__DIR__ . '/../autoload.php')) {
|
* using a stream wrapper to prevent the shebang from being output on PHP<8
|
||||||
require __DIR__ . '/../autoload.php';
|
*
|
||||||
} else {
|
* @generated
|
||||||
throw new RuntimeException('Unable to locate autoload.php file.');
|
*/
|
||||||
}
|
|
||||||
|
|
||||||
use JmesPath\Env;
|
namespace Composer;
|
||||||
use JmesPath\DebugRuntime;
|
|
||||||
|
|
||||||
$description = <<<EOT
|
$GLOBALS['_composer_bin_dir'] = __DIR__;
|
||||||
Runs a JMESPath expression on the provided input or a test case.
|
$GLOBALS['_composer_autoload_path'] = __DIR__ . '/..'.'/autoload.php';
|
||||||
|
|
||||||
Provide the JSON input and expression:
|
if (PHP_VERSION_ID < 80000) {
|
||||||
echo '{}' | jp.php expression
|
if (!class_exists('Composer\BinProxyWrapper')) {
|
||||||
|
/**
|
||||||
|
* @internal
|
||||||
|
*/
|
||||||
|
final class BinProxyWrapper
|
||||||
|
{
|
||||||
|
private $handle;
|
||||||
|
private $position;
|
||||||
|
private $realpath;
|
||||||
|
|
||||||
Or provide the path to a compliance script, a suite, and test case number:
|
public function stream_open($path, $mode, $options, &$opened_path)
|
||||||
jp.php --script path_to_script --suite test_suite_number --case test_case_number [expression]
|
{
|
||||||
|
// get rid of phpvfscomposer:// prefix for __FILE__ & __DIR__ resolution
|
||||||
|
$opened_path = substr($path, 17);
|
||||||
|
$this->realpath = realpath($opened_path) ?: $opened_path;
|
||||||
|
$opened_path = $this->realpath;
|
||||||
|
$this->handle = fopen($this->realpath, $mode);
|
||||||
|
$this->position = 0;
|
||||||
|
|
||||||
EOT;
|
return (bool) $this->handle;
|
||||||
|
|
||||||
$args = [];
|
|
||||||
$currentKey = null;
|
|
||||||
for ($i = 1, $total = count($argv); $i < $total; $i++) {
|
|
||||||
if ($i % 2) {
|
|
||||||
if (substr($argv[$i], 0, 2) == '--') {
|
|
||||||
$currentKey = str_replace('--', '', $argv[$i]);
|
|
||||||
} else {
|
|
||||||
$currentKey = trim($argv[$i]);
|
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
$args[$currentKey] = $argv[$i];
|
public function stream_read($count)
|
||||||
$currentKey = null;
|
{
|
||||||
|
$data = fread($this->handle, $count);
|
||||||
|
|
||||||
|
if ($this->position === 0) {
|
||||||
|
$data = preg_replace('{^#!.*\r?\n}', '', $data);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->position += strlen($data);
|
||||||
|
|
||||||
|
return $data;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function stream_cast($castAs)
|
||||||
|
{
|
||||||
|
return $this->handle;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function stream_close()
|
||||||
|
{
|
||||||
|
fclose($this->handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function stream_lock($operation)
|
||||||
|
{
|
||||||
|
return $operation ? flock($this->handle, $operation) : true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function stream_seek($offset, $whence)
|
||||||
|
{
|
||||||
|
if (0 === fseek($this->handle, $offset, $whence)) {
|
||||||
|
$this->position = ftell($this->handle);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function stream_tell()
|
||||||
|
{
|
||||||
|
return $this->position;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function stream_eof()
|
||||||
|
{
|
||||||
|
return feof($this->handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function stream_stat()
|
||||||
|
{
|
||||||
|
return array();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function stream_set_option($option, $arg1, $arg2)
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function url_stat($path, $flags)
|
||||||
|
{
|
||||||
|
$path = substr($path, 17);
|
||||||
|
if (file_exists($path)) {
|
||||||
|
return stat($path);
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (
|
||||||
|
(function_exists('stream_get_wrappers') && in_array('phpvfscomposer', stream_get_wrappers(), true))
|
||||||
|
|| (function_exists('stream_wrapper_register') && stream_wrapper_register('phpvfscomposer', 'Composer\BinProxyWrapper'))
|
||||||
|
) {
|
||||||
|
return include("phpvfscomposer://" . __DIR__ . '/..'.'/mtdowling/jmespath.php/bin/jp.php');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$expression = $currentKey;
|
return include __DIR__ . '/..'.'/mtdowling/jmespath.php/bin/jp.php';
|
||||||
|
|
||||||
if (isset($args['file']) || isset($args['suite']) || isset($args['case'])) {
|
|
||||||
if (!isset($args['file']) || !isset($args['suite']) || !isset($args['case'])) {
|
|
||||||
die($description);
|
|
||||||
}
|
|
||||||
// Manually run a compliance test
|
|
||||||
$path = realpath($args['file']);
|
|
||||||
file_exists($path) or die('File not found at ' . $path);
|
|
||||||
$json = json_decode(file_get_contents($path), true);
|
|
||||||
$set = $json[$args['suite']];
|
|
||||||
$data = $set['given'];
|
|
||||||
if (!isset($expression)) {
|
|
||||||
$expression = $set['cases'][$args['case']]['expression'];
|
|
||||||
echo "Expects\n=======\n";
|
|
||||||
if (isset($set['cases'][$args['case']]['result'])) {
|
|
||||||
echo json_encode($set['cases'][$args['case']]['result'], JSON_PRETTY_PRINT) . "\n\n";
|
|
||||||
} elseif (isset($set['cases'][$args['case']]['error'])) {
|
|
||||||
echo "{$set['cases'][$argv['case']]['error']} error\n\n";
|
|
||||||
} else {
|
|
||||||
echo "NULL\n\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} elseif (isset($expression)) {
|
|
||||||
// Pass in an expression and STDIN as a standalone argument
|
|
||||||
$data = json_decode(stream_get_contents(STDIN), true);
|
|
||||||
} else {
|
|
||||||
die($description);
|
|
||||||
}
|
|
||||||
|
|
||||||
$runtime = new DebugRuntime(Env::createRuntime());
|
|
||||||
$runtime($expression, $data);
|
|
||||||
|
182
vendor/composer/ClassLoader.php
vendored
182
vendor/composer/ClassLoader.php
vendored
@ -37,57 +37,126 @@ namespace Composer\Autoload;
|
|||||||
*
|
*
|
||||||
* @author Fabien Potencier <fabien@symfony.com>
|
* @author Fabien Potencier <fabien@symfony.com>
|
||||||
* @author Jordi Boggiano <j.boggiano@seld.be>
|
* @author Jordi Boggiano <j.boggiano@seld.be>
|
||||||
* @see http://www.php-fig.org/psr/psr-0/
|
* @see https://www.php-fig.org/psr/psr-0/
|
||||||
* @see http://www.php-fig.org/psr/psr-4/
|
* @see https://www.php-fig.org/psr/psr-4/
|
||||||
*/
|
*/
|
||||||
class ClassLoader
|
class ClassLoader
|
||||||
{
|
{
|
||||||
|
/** @var \Closure(string):void */
|
||||||
|
private static $includeFile;
|
||||||
|
|
||||||
|
/** @var string|null */
|
||||||
|
private $vendorDir;
|
||||||
|
|
||||||
// PSR-4
|
// PSR-4
|
||||||
|
/**
|
||||||
|
* @var array<string, array<string, int>>
|
||||||
|
*/
|
||||||
private $prefixLengthsPsr4 = array();
|
private $prefixLengthsPsr4 = array();
|
||||||
|
/**
|
||||||
|
* @var array<string, list<string>>
|
||||||
|
*/
|
||||||
private $prefixDirsPsr4 = array();
|
private $prefixDirsPsr4 = array();
|
||||||
|
/**
|
||||||
|
* @var list<string>
|
||||||
|
*/
|
||||||
private $fallbackDirsPsr4 = array();
|
private $fallbackDirsPsr4 = array();
|
||||||
|
|
||||||
// PSR-0
|
// PSR-0
|
||||||
|
/**
|
||||||
|
* List of PSR-0 prefixes
|
||||||
|
*
|
||||||
|
* Structured as array('F (first letter)' => array('Foo\Bar (full prefix)' => array('path', 'path2')))
|
||||||
|
*
|
||||||
|
* @var array<string, array<string, list<string>>>
|
||||||
|
*/
|
||||||
private $prefixesPsr0 = array();
|
private $prefixesPsr0 = array();
|
||||||
|
/**
|
||||||
|
* @var list<string>
|
||||||
|
*/
|
||||||
private $fallbackDirsPsr0 = array();
|
private $fallbackDirsPsr0 = array();
|
||||||
|
|
||||||
|
/** @var bool */
|
||||||
private $useIncludePath = false;
|
private $useIncludePath = false;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var array<string, string>
|
||||||
|
*/
|
||||||
private $classMap = array();
|
private $classMap = array();
|
||||||
|
|
||||||
|
/** @var bool */
|
||||||
private $classMapAuthoritative = false;
|
private $classMapAuthoritative = false;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var array<string, bool>
|
||||||
|
*/
|
||||||
private $missingClasses = array();
|
private $missingClasses = array();
|
||||||
|
|
||||||
|
/** @var string|null */
|
||||||
private $apcuPrefix;
|
private $apcuPrefix;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var array<string, self>
|
||||||
|
*/
|
||||||
|
private static $registeredLoaders = array();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string|null $vendorDir
|
||||||
|
*/
|
||||||
|
public function __construct($vendorDir = null)
|
||||||
|
{
|
||||||
|
$this->vendorDir = $vendorDir;
|
||||||
|
self::initializeIncludeClosure();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, list<string>>
|
||||||
|
*/
|
||||||
public function getPrefixes()
|
public function getPrefixes()
|
||||||
{
|
{
|
||||||
if (!empty($this->prefixesPsr0)) {
|
if (!empty($this->prefixesPsr0)) {
|
||||||
return call_user_func_array('array_merge', $this->prefixesPsr0);
|
return call_user_func_array('array_merge', array_values($this->prefixesPsr0));
|
||||||
}
|
}
|
||||||
|
|
||||||
return array();
|
return array();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, list<string>>
|
||||||
|
*/
|
||||||
public function getPrefixesPsr4()
|
public function getPrefixesPsr4()
|
||||||
{
|
{
|
||||||
return $this->prefixDirsPsr4;
|
return $this->prefixDirsPsr4;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return list<string>
|
||||||
|
*/
|
||||||
public function getFallbackDirs()
|
public function getFallbackDirs()
|
||||||
{
|
{
|
||||||
return $this->fallbackDirsPsr0;
|
return $this->fallbackDirsPsr0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return list<string>
|
||||||
|
*/
|
||||||
public function getFallbackDirsPsr4()
|
public function getFallbackDirsPsr4()
|
||||||
{
|
{
|
||||||
return $this->fallbackDirsPsr4;
|
return $this->fallbackDirsPsr4;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, string> Array of classname => path
|
||||||
|
*/
|
||||||
public function getClassMap()
|
public function getClassMap()
|
||||||
{
|
{
|
||||||
return $this->classMap;
|
return $this->classMap;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param array $classMap Class to filename map
|
* @param array<string, string> $classMap Class to filename map
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function addClassMap(array $classMap)
|
public function addClassMap(array $classMap)
|
||||||
{
|
{
|
||||||
@ -103,21 +172,24 @@ class ClassLoader
|
|||||||
* appending or prepending to the ones previously set for this prefix.
|
* appending or prepending to the ones previously set for this prefix.
|
||||||
*
|
*
|
||||||
* @param string $prefix The prefix
|
* @param string $prefix The prefix
|
||||||
* @param array|string $paths The PSR-0 root directories
|
* @param list<string>|string $paths The PSR-0 root directories
|
||||||
* @param bool $prepend Whether to prepend the directories
|
* @param bool $prepend Whether to prepend the directories
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function add($prefix, $paths, $prepend = false)
|
public function add($prefix, $paths, $prepend = false)
|
||||||
{
|
{
|
||||||
|
$paths = (array) $paths;
|
||||||
if (!$prefix) {
|
if (!$prefix) {
|
||||||
if ($prepend) {
|
if ($prepend) {
|
||||||
$this->fallbackDirsPsr0 = array_merge(
|
$this->fallbackDirsPsr0 = array_merge(
|
||||||
(array) $paths,
|
$paths,
|
||||||
$this->fallbackDirsPsr0
|
$this->fallbackDirsPsr0
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
$this->fallbackDirsPsr0 = array_merge(
|
$this->fallbackDirsPsr0 = array_merge(
|
||||||
$this->fallbackDirsPsr0,
|
$this->fallbackDirsPsr0,
|
||||||
(array) $paths
|
$paths
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -126,19 +198,19 @@ class ClassLoader
|
|||||||
|
|
||||||
$first = $prefix[0];
|
$first = $prefix[0];
|
||||||
if (!isset($this->prefixesPsr0[$first][$prefix])) {
|
if (!isset($this->prefixesPsr0[$first][$prefix])) {
|
||||||
$this->prefixesPsr0[$first][$prefix] = (array) $paths;
|
$this->prefixesPsr0[$first][$prefix] = $paths;
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if ($prepend) {
|
if ($prepend) {
|
||||||
$this->prefixesPsr0[$first][$prefix] = array_merge(
|
$this->prefixesPsr0[$first][$prefix] = array_merge(
|
||||||
(array) $paths,
|
$paths,
|
||||||
$this->prefixesPsr0[$first][$prefix]
|
$this->prefixesPsr0[$first][$prefix]
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
$this->prefixesPsr0[$first][$prefix] = array_merge(
|
$this->prefixesPsr0[$first][$prefix] = array_merge(
|
||||||
$this->prefixesPsr0[$first][$prefix],
|
$this->prefixesPsr0[$first][$prefix],
|
||||||
(array) $paths
|
$paths
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -148,24 +220,27 @@ class ClassLoader
|
|||||||
* appending or prepending to the ones previously set for this namespace.
|
* appending or prepending to the ones previously set for this namespace.
|
||||||
*
|
*
|
||||||
* @param string $prefix The prefix/namespace, with trailing '\\'
|
* @param string $prefix The prefix/namespace, with trailing '\\'
|
||||||
* @param array|string $paths The PSR-4 base directories
|
* @param list<string>|string $paths The PSR-4 base directories
|
||||||
* @param bool $prepend Whether to prepend the directories
|
* @param bool $prepend Whether to prepend the directories
|
||||||
*
|
*
|
||||||
* @throws \InvalidArgumentException
|
* @throws \InvalidArgumentException
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function addPsr4($prefix, $paths, $prepend = false)
|
public function addPsr4($prefix, $paths, $prepend = false)
|
||||||
{
|
{
|
||||||
|
$paths = (array) $paths;
|
||||||
if (!$prefix) {
|
if (!$prefix) {
|
||||||
// Register directories for the root namespace.
|
// Register directories for the root namespace.
|
||||||
if ($prepend) {
|
if ($prepend) {
|
||||||
$this->fallbackDirsPsr4 = array_merge(
|
$this->fallbackDirsPsr4 = array_merge(
|
||||||
(array) $paths,
|
$paths,
|
||||||
$this->fallbackDirsPsr4
|
$this->fallbackDirsPsr4
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
$this->fallbackDirsPsr4 = array_merge(
|
$this->fallbackDirsPsr4 = array_merge(
|
||||||
$this->fallbackDirsPsr4,
|
$this->fallbackDirsPsr4,
|
||||||
(array) $paths
|
$paths
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
} elseif (!isset($this->prefixDirsPsr4[$prefix])) {
|
} elseif (!isset($this->prefixDirsPsr4[$prefix])) {
|
||||||
@ -175,18 +250,18 @@ class ClassLoader
|
|||||||
throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator.");
|
throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator.");
|
||||||
}
|
}
|
||||||
$this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length;
|
$this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length;
|
||||||
$this->prefixDirsPsr4[$prefix] = (array) $paths;
|
$this->prefixDirsPsr4[$prefix] = $paths;
|
||||||
} elseif ($prepend) {
|
} elseif ($prepend) {
|
||||||
// Prepend directories for an already registered namespace.
|
// Prepend directories for an already registered namespace.
|
||||||
$this->prefixDirsPsr4[$prefix] = array_merge(
|
$this->prefixDirsPsr4[$prefix] = array_merge(
|
||||||
(array) $paths,
|
$paths,
|
||||||
$this->prefixDirsPsr4[$prefix]
|
$this->prefixDirsPsr4[$prefix]
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
// Append directories for an already registered namespace.
|
// Append directories for an already registered namespace.
|
||||||
$this->prefixDirsPsr4[$prefix] = array_merge(
|
$this->prefixDirsPsr4[$prefix] = array_merge(
|
||||||
$this->prefixDirsPsr4[$prefix],
|
$this->prefixDirsPsr4[$prefix],
|
||||||
(array) $paths
|
$paths
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -196,7 +271,9 @@ class ClassLoader
|
|||||||
* replacing any others previously set for this prefix.
|
* replacing any others previously set for this prefix.
|
||||||
*
|
*
|
||||||
* @param string $prefix The prefix
|
* @param string $prefix The prefix
|
||||||
* @param array|string $paths The PSR-0 base directories
|
* @param list<string>|string $paths The PSR-0 base directories
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function set($prefix, $paths)
|
public function set($prefix, $paths)
|
||||||
{
|
{
|
||||||
@ -212,9 +289,11 @@ class ClassLoader
|
|||||||
* replacing any others previously set for this namespace.
|
* replacing any others previously set for this namespace.
|
||||||
*
|
*
|
||||||
* @param string $prefix The prefix/namespace, with trailing '\\'
|
* @param string $prefix The prefix/namespace, with trailing '\\'
|
||||||
* @param array|string $paths The PSR-4 base directories
|
* @param list<string>|string $paths The PSR-4 base directories
|
||||||
*
|
*
|
||||||
* @throws \InvalidArgumentException
|
* @throws \InvalidArgumentException
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function setPsr4($prefix, $paths)
|
public function setPsr4($prefix, $paths)
|
||||||
{
|
{
|
||||||
@ -234,6 +313,8 @@ class ClassLoader
|
|||||||
* Turns on searching the include path for class files.
|
* Turns on searching the include path for class files.
|
||||||
*
|
*
|
||||||
* @param bool $useIncludePath
|
* @param bool $useIncludePath
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function setUseIncludePath($useIncludePath)
|
public function setUseIncludePath($useIncludePath)
|
||||||
{
|
{
|
||||||
@ -256,6 +337,8 @@ class ClassLoader
|
|||||||
* that have not been registered with the class map.
|
* that have not been registered with the class map.
|
||||||
*
|
*
|
||||||
* @param bool $classMapAuthoritative
|
* @param bool $classMapAuthoritative
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function setClassMapAuthoritative($classMapAuthoritative)
|
public function setClassMapAuthoritative($classMapAuthoritative)
|
||||||
{
|
{
|
||||||
@ -276,6 +359,8 @@ class ClassLoader
|
|||||||
* APCu prefix to use to cache found/not-found classes, if the extension is enabled.
|
* APCu prefix to use to cache found/not-found classes, if the extension is enabled.
|
||||||
*
|
*
|
||||||
* @param string|null $apcuPrefix
|
* @param string|null $apcuPrefix
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function setApcuPrefix($apcuPrefix)
|
public function setApcuPrefix($apcuPrefix)
|
||||||
{
|
{
|
||||||
@ -296,33 +381,55 @@ class ClassLoader
|
|||||||
* Registers this instance as an autoloader.
|
* Registers this instance as an autoloader.
|
||||||
*
|
*
|
||||||
* @param bool $prepend Whether to prepend the autoloader or not
|
* @param bool $prepend Whether to prepend the autoloader or not
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function register($prepend = false)
|
public function register($prepend = false)
|
||||||
{
|
{
|
||||||
spl_autoload_register(array($this, 'loadClass'), true, $prepend);
|
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.
|
* Unregisters this instance as an autoloader.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function unregister()
|
public function unregister()
|
||||||
{
|
{
|
||||||
spl_autoload_unregister(array($this, 'loadClass'));
|
spl_autoload_unregister(array($this, 'loadClass'));
|
||||||
|
|
||||||
|
if (null !== $this->vendorDir) {
|
||||||
|
unset(self::$registeredLoaders[$this->vendorDir]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Loads the given class or interface.
|
* Loads the given class or interface.
|
||||||
*
|
*
|
||||||
* @param string $class The name of the class
|
* @param string $class The name of the class
|
||||||
* @return bool|null True if loaded, null otherwise
|
* @return true|null True if loaded, null otherwise
|
||||||
*/
|
*/
|
||||||
public function loadClass($class)
|
public function loadClass($class)
|
||||||
{
|
{
|
||||||
if ($file = $this->findFile($class)) {
|
if ($file = $this->findFile($class)) {
|
||||||
includeFile($file);
|
$includeFile = self::$includeFile;
|
||||||
|
$includeFile($file);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -367,6 +474,21 @@ class ClassLoader
|
|||||||
return $file;
|
return $file;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the currently registered loaders keyed by their corresponding vendor directories.
|
||||||
|
*
|
||||||
|
* @return array<string, self>
|
||||||
|
*/
|
||||||
|
public static function getRegisteredLoaders()
|
||||||
|
{
|
||||||
|
return self::$registeredLoaders;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $class
|
||||||
|
* @param string $ext
|
||||||
|
* @return string|false
|
||||||
|
*/
|
||||||
private function findFileWithExtension($class, $ext)
|
private function findFileWithExtension($class, $ext)
|
||||||
{
|
{
|
||||||
// PSR-4 lookup
|
// PSR-4 lookup
|
||||||
@ -432,14 +554,26 @@ class ClassLoader
|
|||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
private static function initializeIncludeClosure()
|
||||||
|
{
|
||||||
|
if (self::$includeFile !== null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
* Scope isolated include.
|
* Scope isolated include.
|
||||||
*
|
*
|
||||||
* Prevents access to $this/self from included files.
|
* Prevents access to $this/self from included files.
|
||||||
|
*
|
||||||
|
* @param string $file
|
||||||
|
* @return void
|
||||||
*/
|
*/
|
||||||
function includeFile($file)
|
self::$includeFile = \Closure::bind(static function($file) {
|
||||||
{
|
|
||||||
include $file;
|
include $file;
|
||||||
|
}, null, null);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
359
vendor/composer/InstalledVersions.php
vendored
Normal file
359
vendor/composer/InstalledVersions.php
vendored
Normal file
@ -0,0 +1,359 @@
|
|||||||
|
<?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 || !isset($installed['versions'][$packageName]['dev_requirement']) || $installed['versions'][$packageName]['dev_requirement'] === false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
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((string) $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')) {
|
||||||
|
/** @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[]}>} $required */
|
||||||
|
$required = require $vendorDir.'/composer/installed.php';
|
||||||
|
$installed[] = self::$installedByVendor[$vendorDir] = $required;
|
||||||
|
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') {
|
||||||
|
/** @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[]}>} $required */
|
||||||
|
$required = require __DIR__ . '/installed.php';
|
||||||
|
self::$installed = $required;
|
||||||
|
} else {
|
||||||
|
self::$installed = array();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (self::$installed !== array()) {
|
||||||
|
$installed[] = self::$installed;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $installed;
|
||||||
|
}
|
||||||
|
}
|
75
vendor/composer/autoload_classmap.php
vendored
75
vendor/composer/autoload_classmap.php
vendored
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
// autoload_classmap.php @generated by Composer
|
// autoload_classmap.php @generated by Composer
|
||||||
|
|
||||||
$vendorDir = dirname(dirname(__FILE__));
|
$vendorDir = dirname(__DIR__);
|
||||||
$baseDir = dirname($vendorDir);
|
$baseDir = dirname($vendorDir);
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
@ -812,6 +812,7 @@ return array(
|
|||||||
'Aws\\kendra\\kendraClient' => $vendorDir . '/aws/aws-sdk-php/src/kendra/kendraClient.php',
|
'Aws\\kendra\\kendraClient' => $vendorDir . '/aws/aws-sdk-php/src/kendra/kendraClient.php',
|
||||||
'Aws\\signer\\Exception\\signerException' => $vendorDir . '/aws/aws-sdk-php/src/signer/Exception/signerException.php',
|
'Aws\\signer\\Exception\\signerException' => $vendorDir . '/aws/aws-sdk-php/src/signer/Exception/signerException.php',
|
||||||
'Aws\\signer\\signerClient' => $vendorDir . '/aws/aws-sdk-php/src/signer/signerClient.php',
|
'Aws\\signer\\signerClient' => $vendorDir . '/aws/aws-sdk-php/src/signer/signerClient.php',
|
||||||
|
'Composer\\InstalledVersions' => $vendorDir . '/composer/InstalledVersions.php',
|
||||||
'Datamatrix' => $vendorDir . '/tecnickcom/tcpdf/include/barcodes/datamatrix.php',
|
'Datamatrix' => $vendorDir . '/tecnickcom/tcpdf/include/barcodes/datamatrix.php',
|
||||||
'Datto\\JsonRpc\\Client' => $vendorDir . '/datto/json-rpc/src/Client.php',
|
'Datto\\JsonRpc\\Client' => $vendorDir . '/datto/json-rpc/src/Client.php',
|
||||||
'Datto\\JsonRpc\\Evaluator' => $vendorDir . '/datto/json-rpc/src/Evaluator.php',
|
'Datto\\JsonRpc\\Evaluator' => $vendorDir . '/datto/json-rpc/src/Evaluator.php',
|
||||||
@ -1116,9 +1117,6 @@ return array(
|
|||||||
'HTMLPurifier_Printer' => $vendorDir . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer.php',
|
'HTMLPurifier_Printer' => $vendorDir . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer.php',
|
||||||
'HTMLPurifier_Printer_CSSDefinition' => $vendorDir . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer/CSSDefinition.php',
|
'HTMLPurifier_Printer_CSSDefinition' => $vendorDir . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer/CSSDefinition.php',
|
||||||
'HTMLPurifier_Printer_ConfigForm' => $vendorDir . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer/ConfigForm.php',
|
'HTMLPurifier_Printer_ConfigForm' => $vendorDir . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer/ConfigForm.php',
|
||||||
'HTMLPurifier_Printer_ConfigForm_NullDecorator' => $vendorDir . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer/ConfigForm.php',
|
|
||||||
'HTMLPurifier_Printer_ConfigForm_bool' => $vendorDir . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer/ConfigForm.php',
|
|
||||||
'HTMLPurifier_Printer_ConfigForm_default' => $vendorDir . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer/ConfigForm.php',
|
|
||||||
'HTMLPurifier_Printer_HTMLDefinition' => $vendorDir . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer/HTMLDefinition.php',
|
'HTMLPurifier_Printer_HTMLDefinition' => $vendorDir . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer/HTMLDefinition.php',
|
||||||
'HTMLPurifier_PropertyList' => $vendorDir . '/ezyang/htmlpurifier/library/HTMLPurifier/PropertyList.php',
|
'HTMLPurifier_PropertyList' => $vendorDir . '/ezyang/htmlpurifier/library/HTMLPurifier/PropertyList.php',
|
||||||
'HTMLPurifier_PropertyListIterator' => $vendorDir . '/ezyang/htmlpurifier/library/HTMLPurifier/PropertyListIterator.php',
|
'HTMLPurifier_PropertyListIterator' => $vendorDir . '/ezyang/htmlpurifier/library/HTMLPurifier/PropertyListIterator.php',
|
||||||
@ -2190,6 +2188,57 @@ return array(
|
|||||||
'TrueBV\\Exception\\LabelOutOfBoundsException' => $vendorDir . '/true/punycode/src/Exception/LabelOutOfBoundsException.php',
|
'TrueBV\\Exception\\LabelOutOfBoundsException' => $vendorDir . '/true/punycode/src/Exception/LabelOutOfBoundsException.php',
|
||||||
'TrueBV\\Exception\\OutOfBoundsException' => $vendorDir . '/true/punycode/src/Exception/OutOfBoundsException.php',
|
'TrueBV\\Exception\\OutOfBoundsException' => $vendorDir . '/true/punycode/src/Exception/OutOfBoundsException.php',
|
||||||
'TrueBV\\Punycode' => $vendorDir . '/true/punycode/src/Punycode.php',
|
'TrueBV\\Punycode' => $vendorDir . '/true/punycode/src/Punycode.php',
|
||||||
|
'Versandart_dhl' => $baseDir . '/www/lib/versandarten/dhl.php',
|
||||||
|
'Versandart_sendcloud' => $baseDir . '/www/lib/versandarten/sendcloud.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Bank' => $baseDir . '/classes/Carrier/Dhl/Data/Bank.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Communication' => $baseDir . '/classes/Carrier/Dhl/Data/Communication.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Contact' => $baseDir . '/classes/Carrier/Dhl/Data/Contact.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Country' => $baseDir . '/classes/Carrier/Dhl/Data/Country.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\CreateShipmentOrderRequest' => $baseDir . '/classes/Carrier/Dhl/Data/CreateShipmentOrderRequest.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\CreateShipmentOrderResponse' => $baseDir . '/classes/Carrier/Dhl/Data/CreateShipmentOrderResponse.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\CreationState' => $baseDir . '/classes/Carrier/Dhl/Data/CreationState.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Customer' => $baseDir . '/classes/Carrier/Dhl/Data/Customer.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\DeleteShipmentOrderRequest' => $baseDir . '/classes/Carrier/Dhl/Data/DeleteShipmentOrderRequest.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\DeleteShipmentOrderResponse' => $baseDir . '/classes/Carrier/Dhl/Data/DeleteShipmentOrderResponse.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\DeletionState' => $baseDir . '/classes/Carrier/Dhl/Data/DeletionState.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\DeliveryAddress' => $baseDir . '/classes/Carrier/Dhl/Data/DeliveryAddress.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Dimension' => $baseDir . '/classes/Carrier/Dhl/Data/Dimension.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\ExportDocPosition' => $baseDir . '/classes/Carrier/Dhl/Data/ExportDocPosition.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\ExportDocument' => $baseDir . '/classes/Carrier/Dhl/Data/ExportDocument.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\LabelData' => $baseDir . '/classes/Carrier/Dhl/Data/LabelData.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Name' => $baseDir . '/classes/Carrier/Dhl/Data/Name.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\NativeAddress' => $baseDir . '/classes/Carrier/Dhl/Data/NativeAddress.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\NativeAddressNew' => $baseDir . '/classes/Carrier/Dhl/Data/NativeAddressNew.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\PackStation' => $baseDir . '/classes/Carrier/Dhl/Data/PackStation.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Postfiliale' => $baseDir . '/classes/Carrier/Dhl/Data/Postfiliale.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Receiver' => $baseDir . '/classes/Carrier/Dhl/Data/Receiver.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\ReceiverNativeAddress' => $baseDir . '/classes/Carrier/Dhl/Data/ReceiverNativeAddress.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Shipment' => $baseDir . '/classes/Carrier/Dhl/Data/Shipment.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\ShipmentDetails' => $baseDir . '/classes/Carrier/Dhl/Data/ShipmentDetails.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\ShipmentItem' => $baseDir . '/classes/Carrier/Dhl/Data/ShipmentItem.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\ShipmentNotification' => $baseDir . '/classes/Carrier/Dhl/Data/ShipmentNotification.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\ShipmentOrder' => $baseDir . '/classes/Carrier/Dhl/Data/ShipmentOrder.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\ShipmentService' => $baseDir . '/classes/Carrier/Dhl/Data/ShipmentService.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Shipper' => $baseDir . '/classes/Carrier/Dhl/Data/Shipper.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Status' => $baseDir . '/classes/Carrier/Dhl/Data/Status.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\StatusElement' => $baseDir . '/classes/Carrier/Dhl/Data/StatusElement.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Statusinformation' => $baseDir . '/classes/Carrier/Dhl/Data/Statusinformation.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Version' => $baseDir . '/classes/Carrier/Dhl/Data/Version.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\DhlApi' => $baseDir . '/classes/Carrier/Dhl/DhlApi.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\Document' => $baseDir . '/classes/Carrier/SendCloud/Data/Document.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\Label' => $baseDir . '/classes/Carrier/SendCloud/Data/Label.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\ParcelBase' => $baseDir . '/classes/Carrier/SendCloud/Data/ParcelBase.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\ParcelCreation' => $baseDir . '/classes/Carrier/SendCloud/Data/ParcelCreation.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\ParcelCreationError' => $baseDir . '/classes/Carrier/SendCloud/Data/ParcelCreationError.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\ParcelItem' => $baseDir . '/classes/Carrier/SendCloud/Data/ParcelItem.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\ParcelResponse' => $baseDir . '/classes/Carrier/SendCloud/Data/ParcelResponse.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\SenderAddress' => $baseDir . '/classes/Carrier/SendCloud/Data/SenderAddress.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\Shipment' => $baseDir . '/classes/Carrier/SendCloud/Data/Shipment.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\ShippingMethod' => $baseDir . '/classes/Carrier/SendCloud/Data/ShippingMethod.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\ShippingProduct' => $baseDir . '/classes/Carrier/SendCloud/Data/ShippingProduct.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\Status' => $baseDir . '/classes/Carrier/SendCloud/Data/Status.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\SendCloudApi' => $baseDir . '/classes/Carrier/SendCloud/SendCloudApi.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\SendcloudApiException' => $baseDir . '/classes/Carrier/SendCloud/SendcloudApiException.php',
|
||||||
'Xentral\\Components\\Backup\\Adapter\\AdapterInterface' => $baseDir . '/classes/Components/Backup/Adapter/AdapterInterface.php',
|
'Xentral\\Components\\Backup\\Adapter\\AdapterInterface' => $baseDir . '/classes/Components/Backup/Adapter/AdapterInterface.php',
|
||||||
'Xentral\\Components\\Backup\\Adapter\\ExecAdapter' => $baseDir . '/classes/Components/Backup/Adapter/ExecAdapter.php',
|
'Xentral\\Components\\Backup\\Adapter\\ExecAdapter' => $baseDir . '/classes/Components/Backup/Adapter/ExecAdapter.php',
|
||||||
'Xentral\\Components\\Backup\\Bootstrap' => $baseDir . '/classes/Components/Backup/Bootstrap.php',
|
'Xentral\\Components\\Backup\\Bootstrap' => $baseDir . '/classes/Components/Backup/Bootstrap.php',
|
||||||
@ -2726,6 +2775,7 @@ return array(
|
|||||||
'Xentral\\Modules\\Article\\Exception\\InvalidArgumentException' => $baseDir . '/classes/Modules/Article/Exception/InvalidArgumentException.php',
|
'Xentral\\Modules\\Article\\Exception\\InvalidArgumentException' => $baseDir . '/classes/Modules/Article/Exception/InvalidArgumentException.php',
|
||||||
'Xentral\\Modules\\Article\\Exception\\SellingPriceNotFoundException' => $baseDir . '/classes/Modules/Article/Exception/SellingPriceNotFoundException.php',
|
'Xentral\\Modules\\Article\\Exception\\SellingPriceNotFoundException' => $baseDir . '/classes/Modules/Article/Exception/SellingPriceNotFoundException.php',
|
||||||
'Xentral\\Modules\\Article\\Gateway\\ArticleGateway' => $baseDir . '/classes/Modules/Article/Gateway/ArticleGateway.php',
|
'Xentral\\Modules\\Article\\Gateway\\ArticleGateway' => $baseDir . '/classes/Modules/Article/Gateway/ArticleGateway.php',
|
||||||
|
'Xentral\\Modules\\Article\\Service\\ArticleService' => $baseDir . '/classes/Modules/Article/Service/ArticleService.php',
|
||||||
'Xentral\\Modules\\Article\\Service\\CurrencyConversionService' => $baseDir . '/classes/Modules/Article/Service/CurrencyConversionService.php',
|
'Xentral\\Modules\\Article\\Service\\CurrencyConversionService' => $baseDir . '/classes/Modules/Article/Service/CurrencyConversionService.php',
|
||||||
'Xentral\\Modules\\Article\\Service\\PurchasePriceService' => $baseDir . '/classes/Modules/Article/Service/PurchasePriceService.php',
|
'Xentral\\Modules\\Article\\Service\\PurchasePriceService' => $baseDir . '/classes/Modules/Article/Service/PurchasePriceService.php',
|
||||||
'Xentral\\Modules\\Article\\Service\\SellingPriceService' => $baseDir . '/classes/Modules/Article/Service/SellingPriceService.php',
|
'Xentral\\Modules\\Article\\Service\\SellingPriceService' => $baseDir . '/classes/Modules/Article/Service/SellingPriceService.php',
|
||||||
@ -2832,10 +2882,7 @@ return array(
|
|||||||
'Xentral\\Modules\\Datanorm\\Service\\DatanormIntermediateService' => $baseDir . '/classes/Modules/Datanorm/Service/DatanormIntermediateService.php',
|
'Xentral\\Modules\\Datanorm\\Service\\DatanormIntermediateService' => $baseDir . '/classes/Modules/Datanorm/Service/DatanormIntermediateService.php',
|
||||||
'Xentral\\Modules\\Datanorm\\Service\\DatanormReader' => $baseDir . '/classes/Modules/Datanorm/Service/DatanormReader.php',
|
'Xentral\\Modules\\Datanorm\\Service\\DatanormReader' => $baseDir . '/classes/Modules/Datanorm/Service/DatanormReader.php',
|
||||||
'Xentral\\Modules\\Datanorm\\Wrapper\\AddressWrapper' => $baseDir . '/classes/Modules/Datanorm/Wrapper/AddressWrapper.php',
|
'Xentral\\Modules\\Datanorm\\Wrapper\\AddressWrapper' => $baseDir . '/classes/Modules/Datanorm/Wrapper/AddressWrapper.php',
|
||||||
'Xentral\\Modules\\DatevApi\\Bootstrap' => $baseDir . '/classes/Modules/DatevApi/Bootstrap.php',
|
|
||||||
'Xentral\\Modules\\DatevApi\\DataTable\\DatevExportDataTable' => $baseDir . '/classes/Modules/DatevApi/DataTable/DatevExportDataTable.php',
|
'Xentral\\Modules\\DatevApi\\DataTable\\DatevExportDataTable' => $baseDir . '/classes/Modules/DatevApi/DataTable/DatevExportDataTable.php',
|
||||||
'Xentral\\Modules\\DatevApi\\DatevApiService' => $baseDir . '/classes/Modules/DatevApi/DatevApiService.php',
|
|
||||||
'Xentral\\Modules\\DatevApi\\DatevZipStream' => $baseDir . '/classes/Modules/DatevApi/DatevZipStream.php',
|
|
||||||
'Xentral\\Modules\\DemoExporter\\Bootstrap' => $baseDir . '/classes/Modules/DemoExporter/Bootstrap.php',
|
'Xentral\\Modules\\DemoExporter\\Bootstrap' => $baseDir . '/classes/Modules/DemoExporter/Bootstrap.php',
|
||||||
'Xentral\\Modules\\DemoExporter\\DemoExporterCleanerService' => $baseDir . '/classes/Modules/DemoExporter/DemoExporterCleanerService.php',
|
'Xentral\\Modules\\DemoExporter\\DemoExporterCleanerService' => $baseDir . '/classes/Modules/DemoExporter/DemoExporterCleanerService.php',
|
||||||
'Xentral\\Modules\\DemoExporter\\DemoExporterDateiService' => $baseDir . '/classes/Modules/DemoExporter/DemoExporterDateiService.php',
|
'Xentral\\Modules\\DemoExporter\\DemoExporterDateiService' => $baseDir . '/classes/Modules/DemoExporter/DemoExporterDateiService.php',
|
||||||
@ -3007,7 +3054,6 @@ return array(
|
|||||||
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyApi' => $baseDir . '/classes/Modules/FiskalyApi/Service/FiskalyApi.php',
|
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyApi' => $baseDir . '/classes/Modules/FiskalyApi/Service/FiskalyApi.php',
|
||||||
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyCashPointClosingDBInterface' => $baseDir . '/classes/Modules/FiskalyApi/Service/FiskalyCashPointClosingDBInterface.php',
|
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyCashPointClosingDBInterface' => $baseDir . '/classes/Modules/FiskalyApi/Service/FiskalyCashPointClosingDBInterface.php',
|
||||||
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyCashPointClosingDBService' => $baseDir . '/classes/Modules/FiskalyApi/Service/FiskalyCashPointClosingDBService.php',
|
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyCashPointClosingDBService' => $baseDir . '/classes/Modules/FiskalyApi/Service/FiskalyCashPointClosingDBService.php',
|
||||||
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyConfig' => $baseDir . '/classes/Modules/FiskalyApi/Service/FiskalyConfig.php',
|
|
||||||
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyDSFinVKApi' => $baseDir . '/classes/Modules/FiskalyApi/Service/FiskalyDSFinVKApi.php',
|
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyDSFinVKApi' => $baseDir . '/classes/Modules/FiskalyApi/Service/FiskalyDSFinVKApi.php',
|
||||||
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyEReceiptApi' => $baseDir . '/classes/Modules/FiskalyApi/Service/FiskalyEReceiptApi.php',
|
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyEReceiptApi' => $baseDir . '/classes/Modules/FiskalyApi/Service/FiskalyEReceiptApi.php',
|
||||||
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyKassenSichVApi' => $baseDir . '/classes/Modules/FiskalyApi/Service/FiskalyKassenSichVApi.php',
|
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyKassenSichVApi' => $baseDir . '/classes/Modules/FiskalyApi/Service/FiskalyKassenSichVApi.php',
|
||||||
@ -3188,6 +3234,15 @@ return array(
|
|||||||
'Xentral\\Modules\\MandatoryFields\\Service\\MandatoryFieldsGateway' => $baseDir . '/classes/Modules/MandatoryFields/Service/MandatoryFieldsGateway.php',
|
'Xentral\\Modules\\MandatoryFields\\Service\\MandatoryFieldsGateway' => $baseDir . '/classes/Modules/MandatoryFields/Service/MandatoryFieldsGateway.php',
|
||||||
'Xentral\\Modules\\MandatoryFields\\Service\\MandatoryFieldsService' => $baseDir . '/classes/Modules/MandatoryFields/Service/MandatoryFieldsService.php',
|
'Xentral\\Modules\\MandatoryFields\\Service\\MandatoryFieldsService' => $baseDir . '/classes/Modules/MandatoryFields/Service/MandatoryFieldsService.php',
|
||||||
'Xentral\\Modules\\MandatoryFields\\Service\\MandatoryFieldsValidator' => $baseDir . '/classes/Modules/MandatoryFields/Service/MandatoryFieldsValidator.php',
|
'Xentral\\Modules\\MandatoryFields\\Service\\MandatoryFieldsValidator' => $baseDir . '/classes/Modules/MandatoryFields/Service/MandatoryFieldsValidator.php',
|
||||||
|
'Xentral\\Modules\\MatrixProduct\\Bootstrap' => $baseDir . '/classes/Modules/MatrixProduct/Bootstrap.php',
|
||||||
|
'Xentral\\Modules\\MatrixProduct\\Data\\Group' => $baseDir . '/classes/Modules/MatrixProduct/Data/Group.php',
|
||||||
|
'Xentral\\Modules\\MatrixProduct\\Data\\Option' => $baseDir . '/classes/Modules/MatrixProduct/Data/Option.php',
|
||||||
|
'Xentral\\Modules\\MatrixProduct\\Data\\Translation' => $baseDir . '/classes/Modules/MatrixProduct/Data/Translation.php',
|
||||||
|
'Xentral\\Modules\\MatrixProduct\\MatrixProductGateway' => $baseDir . '/classes/Modules/MatrixProduct/MatrixProductGateway.php',
|
||||||
|
'Xentral\\Modules\\MatrixProduct\\MatrixProductService' => $baseDir . '/classes/Modules/MatrixProduct/MatrixProductService.php',
|
||||||
|
'Xentral\\Modules\\Onlineshop\\Data\\OrderStatus' => $baseDir . '/classes/Modules/Onlineshop/Data/OrderStatus.php',
|
||||||
|
'Xentral\\Modules\\Onlineshop\\Data\\OrderStatusUpdateRequest' => $baseDir . '/classes/Modules/Onlineshop/Data/OrderStatusUpdateRequest.php',
|
||||||
|
'Xentral\\Modules\\Onlineshop\\Data\\Shipment' => $baseDir . '/classes/Modules/Onlineshop/Data/Shipment.php',
|
||||||
'Xentral\\Modules\\Onlineshop\\Data\\ShopConnectorOrderStatusUpdateResponse' => $baseDir . '/classes/Modules/Onlineshop/Data/ShopConnectorOrderStatusUpdateResponse.php',
|
'Xentral\\Modules\\Onlineshop\\Data\\ShopConnectorOrderStatusUpdateResponse' => $baseDir . '/classes/Modules/Onlineshop/Data/ShopConnectorOrderStatusUpdateResponse.php',
|
||||||
'Xentral\\Modules\\Onlineshop\\Data\\ShopConnectorResponseInterface' => $baseDir . '/classes/Modules/Onlineshop/Data/ShopConnectorResponseInterface.php',
|
'Xentral\\Modules\\Onlineshop\\Data\\ShopConnectorResponseInterface' => $baseDir . '/classes/Modules/Onlineshop/Data/ShopConnectorResponseInterface.php',
|
||||||
'Xentral\\Modules\\PartialDelivery\\Bootstrap' => $baseDir . '/classes/Modules/PartialDelivery/Bootstrap.php',
|
'Xentral\\Modules\\PartialDelivery\\Bootstrap' => $baseDir . '/classes/Modules/PartialDelivery/Bootstrap.php',
|
||||||
@ -3345,6 +3400,9 @@ return array(
|
|||||||
'Xentral\\Modules\\ScanArticle\\Wrapper\\PriceWrapper' => $baseDir . '/classes/Modules/ScanArticle/Wrapper/PriceWrapper.php',
|
'Xentral\\Modules\\ScanArticle\\Wrapper\\PriceWrapper' => $baseDir . '/classes/Modules/ScanArticle/Wrapper/PriceWrapper.php',
|
||||||
'Xentral\\Modules\\ScanArticle\\Wrapper\\SavePositionWrapper' => $baseDir . '/classes/Modules/ScanArticle/Wrapper/SavePositionWrapper.php',
|
'Xentral\\Modules\\ScanArticle\\Wrapper\\SavePositionWrapper' => $baseDir . '/classes/Modules/ScanArticle/Wrapper/SavePositionWrapper.php',
|
||||||
'Xentral\\Modules\\Setting\\Bootstrap' => $baseDir . '/classes/Modules/Setting/Bootstrap.php',
|
'Xentral\\Modules\\Setting\\Bootstrap' => $baseDir . '/classes/Modules/Setting/Bootstrap.php',
|
||||||
|
'Xentral\\Modules\\ShippingMethod\\Model\\CreateShipmentResult' => $baseDir . '/classes/Modules/ShippingMethod/Model/CreateShipmentResult.php',
|
||||||
|
'Xentral\\Modules\\ShippingMethod\\Model\\CustomsInfo' => $baseDir . '/classes/Modules/ShippingMethod/Model/CustomsInfo.php',
|
||||||
|
'Xentral\\Modules\\ShippingMethod\\Model\\Product' => $baseDir . '/classes/Modules/ShippingMethod/Model/Product.php',
|
||||||
'Xentral\\Modules\\ShippingTaxSplit\\Bootstrap' => $baseDir . '/classes/Modules/ShippingTaxSplit/Bootstrap.php',
|
'Xentral\\Modules\\ShippingTaxSplit\\Bootstrap' => $baseDir . '/classes/Modules/ShippingTaxSplit/Bootstrap.php',
|
||||||
'Xentral\\Modules\\ShippingTaxSplit\\Exception\\InvalidArgumentException' => $baseDir . '/classes/Modules/ShippingTaxSplit/Exception/InvalidArgumentException.php',
|
'Xentral\\Modules\\ShippingTaxSplit\\Exception\\InvalidArgumentException' => $baseDir . '/classes/Modules/ShippingTaxSplit/Exception/InvalidArgumentException.php',
|
||||||
'Xentral\\Modules\\ShippingTaxSplit\\Exception\\ShippingTaxSplitExceptionInterface' => $baseDir . '/classes/Modules/ShippingTaxSplit/Exception/ShippingTaxSplitExceptionInterface.php',
|
'Xentral\\Modules\\ShippingTaxSplit\\Exception\\ShippingTaxSplitExceptionInterface' => $baseDir . '/classes/Modules/ShippingTaxSplit/Exception/ShippingTaxSplitExceptionInterface.php',
|
||||||
@ -3404,6 +3462,7 @@ return array(
|
|||||||
'Xentral\\Modules\\SubscriptionCycle\\Service\\SubscriptionCycleJobService' => $baseDir . '/classes/Modules/SubscriptionCycle/Service/SubscriptionCycleJobService.php',
|
'Xentral\\Modules\\SubscriptionCycle\\Service\\SubscriptionCycleJobService' => $baseDir . '/classes/Modules/SubscriptionCycle/Service/SubscriptionCycleJobService.php',
|
||||||
'Xentral\\Modules\\SubscriptionCycle\\SubscriptionCycleCacheFiller' => $baseDir . '/classes/Modules/SubscriptionCycle/SubscriptionCycleCacheFiller.php',
|
'Xentral\\Modules\\SubscriptionCycle\\SubscriptionCycleCacheFiller' => $baseDir . '/classes/Modules/SubscriptionCycle/SubscriptionCycleCacheFiller.php',
|
||||||
'Xentral\\Modules\\SubscriptionCycle\\SubscriptionCycleModuleInterface' => $baseDir . '/classes/Modules/SubscriptionCycle/SubscriptionCycleModuleInterface.php',
|
'Xentral\\Modules\\SubscriptionCycle\\SubscriptionCycleModuleInterface' => $baseDir . '/classes/Modules/SubscriptionCycle/SubscriptionCycleModuleInterface.php',
|
||||||
|
'Xentral\\Modules\\SubscriptionCycle\\SubscriptionModule' => $baseDir . '/classes/Modules/SubscriptionCycle/SubscriptionModule.php',
|
||||||
'Xentral\\Modules\\SubscriptionCycle\\SubscriptionModuleInterface' => $baseDir . '/classes/Modules/SubscriptionCycle/SubscriptionModuleInterface.php',
|
'Xentral\\Modules\\SubscriptionCycle\\SubscriptionModuleInterface' => $baseDir . '/classes/Modules/SubscriptionCycle/SubscriptionModuleInterface.php',
|
||||||
'Xentral\\Modules\\SubscriptionCycle\\Wrapper\\BusinessLetterWrapper' => $baseDir . '/classes/Modules/SubscriptionCycle/Wrapper/BusinessLetterWrapper.php',
|
'Xentral\\Modules\\SubscriptionCycle\\Wrapper\\BusinessLetterWrapper' => $baseDir . '/classes/Modules/SubscriptionCycle/Wrapper/BusinessLetterWrapper.php',
|
||||||
'Xentral\\Modules\\SuperSearch\\Bootstrap' => $baseDir . '/classes/Modules/SuperSearch/Bootstrap.php',
|
'Xentral\\Modules\\SuperSearch\\Bootstrap' => $baseDir . '/classes/Modules/SuperSearch/Bootstrap.php',
|
||||||
|
12
vendor/composer/autoload_files.php
vendored
12
vendor/composer/autoload_files.php
vendored
@ -2,24 +2,24 @@
|
|||||||
|
|
||||||
// autoload_files.php @generated by Composer
|
// autoload_files.php @generated by Composer
|
||||||
|
|
||||||
$vendorDir = dirname(dirname(__FILE__));
|
$vendorDir = dirname(__DIR__);
|
||||||
$baseDir = dirname($vendorDir);
|
$baseDir = dirname($vendorDir);
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
'7b11c4dc42b3b3023073cb14e519683c' => $vendorDir . '/ralouphie/getallheaders/src/getallheaders.php',
|
'7b11c4dc42b3b3023073cb14e519683c' => $vendorDir . '/ralouphie/getallheaders/src/getallheaders.php',
|
||||||
'383eaff206634a77a1be54e64e6459c7' => $vendorDir . '/sabre/uri/lib/functions.php',
|
'383eaff206634a77a1be54e64e6459c7' => $vendorDir . '/sabre/uri/lib/functions.php',
|
||||||
'0e6d7bf4a5811bfa5cf40c5ccd6fae6a' => $vendorDir . '/symfony/polyfill-mbstring/bootstrap.php',
|
|
||||||
'a0edc8309cc5e1d60e3047b5df6b7052' => $vendorDir . '/guzzlehttp/psr7/src/functions_include.php',
|
|
||||||
'c964ee0ededf28c96ebd9db5099ef910' => $vendorDir . '/guzzlehttp/promises/src/functions_include.php',
|
'c964ee0ededf28c96ebd9db5099ef910' => $vendorDir . '/guzzlehttp/promises/src/functions_include.php',
|
||||||
'25072dd6e2470089de65ae7bf11d3109' => $vendorDir . '/symfony/polyfill-php72/bootstrap.php',
|
'a0edc8309cc5e1d60e3047b5df6b7052' => $vendorDir . '/guzzlehttp/psr7/src/functions_include.php',
|
||||||
'e69f7f6ee287b969198c3c9d6777bd38' => $vendorDir . '/symfony/polyfill-intl-normalizer/bootstrap.php',
|
'e69f7f6ee287b969198c3c9d6777bd38' => $vendorDir . '/symfony/polyfill-intl-normalizer/bootstrap.php',
|
||||||
|
'25072dd6e2470089de65ae7bf11d3109' => $vendorDir . '/symfony/polyfill-php72/bootstrap.php',
|
||||||
'f598d06aa772fa33d905e87be6398fb1' => $vendorDir . '/symfony/polyfill-intl-idn/bootstrap.php',
|
'f598d06aa772fa33d905e87be6398fb1' => $vendorDir . '/symfony/polyfill-intl-idn/bootstrap.php',
|
||||||
'37a3dc5111fe8f707ab4c132ef1dbc62' => $vendorDir . '/guzzlehttp/guzzle/src/functions_include.php',
|
'37a3dc5111fe8f707ab4c132ef1dbc62' => $vendorDir . '/guzzlehttp/guzzle/src/functions_include.php',
|
||||||
'3569eecfeed3bcf0bad3c998a494ecb8' => $vendorDir . '/sabre/xml/lib/Deserializer/functions.php',
|
'0e6d7bf4a5811bfa5cf40c5ccd6fae6a' => $vendorDir . '/symfony/polyfill-mbstring/bootstrap.php',
|
||||||
'93aa591bc4ca510c520999e34229ee79' => $vendorDir . '/sabre/xml/lib/Serializer/functions.php',
|
|
||||||
'2b9d0f43f9552984cfa82fee95491826' => $vendorDir . '/sabre/event/lib/coroutine.php',
|
'2b9d0f43f9552984cfa82fee95491826' => $vendorDir . '/sabre/event/lib/coroutine.php',
|
||||||
'd81bab31d3feb45bfe2f283ea3c8fdf7' => $vendorDir . '/sabre/event/lib/Loop/functions.php',
|
'd81bab31d3feb45bfe2f283ea3c8fdf7' => $vendorDir . '/sabre/event/lib/Loop/functions.php',
|
||||||
'a1cce3d26cc15c00fcd0b3354bd72c88' => $vendorDir . '/sabre/event/lib/Promise/functions.php',
|
'a1cce3d26cc15c00fcd0b3354bd72c88' => $vendorDir . '/sabre/event/lib/Promise/functions.php',
|
||||||
|
'3569eecfeed3bcf0bad3c998a494ecb8' => $vendorDir . '/sabre/xml/lib/Deserializer/functions.php',
|
||||||
|
'93aa591bc4ca510c520999e34229ee79' => $vendorDir . '/sabre/xml/lib/Serializer/functions.php',
|
||||||
'b067bc7112e384b61c701452d53a14a8' => $vendorDir . '/mtdowling/jmespath.php/src/JmesPath.php',
|
'b067bc7112e384b61c701452d53a14a8' => $vendorDir . '/mtdowling/jmespath.php/src/JmesPath.php',
|
||||||
'ebdb698ed4152ae445614b69b5e4bb6a' => $vendorDir . '/sabre/http/lib/functions.php',
|
'ebdb698ed4152ae445614b69b5e4bb6a' => $vendorDir . '/sabre/http/lib/functions.php',
|
||||||
'8a9dc1de0ca7e01f3e08231539562f61' => $vendorDir . '/aws/aws-sdk-php/src/functions.php',
|
'8a9dc1de0ca7e01f3e08231539562f61' => $vendorDir . '/aws/aws-sdk-php/src/functions.php',
|
||||||
|
2
vendor/composer/autoload_namespaces.php
vendored
2
vendor/composer/autoload_namespaces.php
vendored
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
// autoload_namespaces.php @generated by Composer
|
// autoload_namespaces.php @generated by Composer
|
||||||
|
|
||||||
$vendorDir = dirname(dirname(__FILE__));
|
$vendorDir = dirname(__DIR__);
|
||||||
$baseDir = dirname($vendorDir);
|
$baseDir = dirname($vendorDir);
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
2
vendor/composer/autoload_psr4.php
vendored
2
vendor/composer/autoload_psr4.php
vendored
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
// autoload_psr4.php @generated by Composer
|
// autoload_psr4.php @generated by Composer
|
||||||
|
|
||||||
$vendorDir = dirname(dirname(__FILE__));
|
$vendorDir = dirname(__DIR__);
|
||||||
$baseDir = dirname($vendorDir);
|
$baseDir = dirname($vendorDir);
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
49
vendor/composer/autoload_real.php
vendored
49
vendor/composer/autoload_real.php
vendored
@ -22,52 +22,29 @@ class ComposerAutoloaderInit0c49a81c1214ef2f7493c6ce921b17ee
|
|||||||
return self::$loader;
|
return self::$loader;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
require __DIR__ . '/platform_check.php';
|
||||||
|
|
||||||
spl_autoload_register(array('ComposerAutoloaderInit0c49a81c1214ef2f7493c6ce921b17ee', 'loadClassLoader'), true, true);
|
spl_autoload_register(array('ComposerAutoloaderInit0c49a81c1214ef2f7493c6ce921b17ee', 'loadClassLoader'), true, true);
|
||||||
self::$loader = $loader = new \Composer\Autoload\ClassLoader();
|
self::$loader = $loader = new \Composer\Autoload\ClassLoader(\dirname(__DIR__));
|
||||||
spl_autoload_unregister(array('ComposerAutoloaderInit0c49a81c1214ef2f7493c6ce921b17ee', 'loadClassLoader'));
|
spl_autoload_unregister(array('ComposerAutoloaderInit0c49a81c1214ef2f7493c6ce921b17ee', 'loadClassLoader'));
|
||||||
|
|
||||||
$useStaticLoader = PHP_VERSION_ID >= 50600 && !defined('HHVM_VERSION') && (!function_exists('zend_loader_file_encoded') || !zend_loader_file_encoded());
|
require __DIR__ . '/autoload_static.php';
|
||||||
if ($useStaticLoader) {
|
|
||||||
require_once __DIR__ . '/autoload_static.php';
|
|
||||||
|
|
||||||
call_user_func(\Composer\Autoload\ComposerStaticInit0c49a81c1214ef2f7493c6ce921b17ee::getInitializer($loader));
|
call_user_func(\Composer\Autoload\ComposerStaticInit0c49a81c1214ef2f7493c6ce921b17ee::getInitializer($loader));
|
||||||
} else {
|
|
||||||
$map = require __DIR__ . '/autoload_namespaces.php';
|
|
||||||
foreach ($map as $namespace => $path) {
|
|
||||||
$loader->set($namespace, $path);
|
|
||||||
}
|
|
||||||
|
|
||||||
$map = require __DIR__ . '/autoload_psr4.php';
|
|
||||||
foreach ($map as $namespace => $path) {
|
|
||||||
$loader->setPsr4($namespace, $path);
|
|
||||||
}
|
|
||||||
|
|
||||||
$classMap = require __DIR__ . '/autoload_classmap.php';
|
|
||||||
if ($classMap) {
|
|
||||||
$loader->addClassMap($classMap);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$loader->register(true);
|
$loader->register(true);
|
||||||
|
|
||||||
if ($useStaticLoader) {
|
$filesToLoad = \Composer\Autoload\ComposerStaticInit0c49a81c1214ef2f7493c6ce921b17ee::$files;
|
||||||
$includeFiles = Composer\Autoload\ComposerStaticInit0c49a81c1214ef2f7493c6ce921b17ee::$files;
|
$requireFile = \Closure::bind(static function ($fileIdentifier, $file) {
|
||||||
} else {
|
if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) {
|
||||||
$includeFiles = require __DIR__ . '/autoload_files.php';
|
$GLOBALS['__composer_autoload_files'][$fileIdentifier] = true;
|
||||||
|
|
||||||
|
require $file;
|
||||||
}
|
}
|
||||||
foreach ($includeFiles as $fileIdentifier => $file) {
|
}, null, null);
|
||||||
composerRequire0c49a81c1214ef2f7493c6ce921b17ee($fileIdentifier, $file);
|
foreach ($filesToLoad as $fileIdentifier => $file) {
|
||||||
|
$requireFile($fileIdentifier, $file);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $loader;
|
return $loader;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function composerRequire0c49a81c1214ef2f7493c6ce921b17ee($fileIdentifier, $file)
|
|
||||||
{
|
|
||||||
if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) {
|
|
||||||
require $file;
|
|
||||||
|
|
||||||
$GLOBALS['__composer_autoload_files'][$fileIdentifier] = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
83
vendor/composer/autoload_static.php
vendored
83
vendor/composer/autoload_static.php
vendored
@ -9,18 +9,18 @@ class ComposerStaticInit0c49a81c1214ef2f7493c6ce921b17ee
|
|||||||
public static $files = array (
|
public static $files = array (
|
||||||
'7b11c4dc42b3b3023073cb14e519683c' => __DIR__ . '/..' . '/ralouphie/getallheaders/src/getallheaders.php',
|
'7b11c4dc42b3b3023073cb14e519683c' => __DIR__ . '/..' . '/ralouphie/getallheaders/src/getallheaders.php',
|
||||||
'383eaff206634a77a1be54e64e6459c7' => __DIR__ . '/..' . '/sabre/uri/lib/functions.php',
|
'383eaff206634a77a1be54e64e6459c7' => __DIR__ . '/..' . '/sabre/uri/lib/functions.php',
|
||||||
'0e6d7bf4a5811bfa5cf40c5ccd6fae6a' => __DIR__ . '/..' . '/symfony/polyfill-mbstring/bootstrap.php',
|
|
||||||
'a0edc8309cc5e1d60e3047b5df6b7052' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/functions_include.php',
|
|
||||||
'c964ee0ededf28c96ebd9db5099ef910' => __DIR__ . '/..' . '/guzzlehttp/promises/src/functions_include.php',
|
'c964ee0ededf28c96ebd9db5099ef910' => __DIR__ . '/..' . '/guzzlehttp/promises/src/functions_include.php',
|
||||||
'25072dd6e2470089de65ae7bf11d3109' => __DIR__ . '/..' . '/symfony/polyfill-php72/bootstrap.php',
|
'a0edc8309cc5e1d60e3047b5df6b7052' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/functions_include.php',
|
||||||
'e69f7f6ee287b969198c3c9d6777bd38' => __DIR__ . '/..' . '/symfony/polyfill-intl-normalizer/bootstrap.php',
|
'e69f7f6ee287b969198c3c9d6777bd38' => __DIR__ . '/..' . '/symfony/polyfill-intl-normalizer/bootstrap.php',
|
||||||
|
'25072dd6e2470089de65ae7bf11d3109' => __DIR__ . '/..' . '/symfony/polyfill-php72/bootstrap.php',
|
||||||
'f598d06aa772fa33d905e87be6398fb1' => __DIR__ . '/..' . '/symfony/polyfill-intl-idn/bootstrap.php',
|
'f598d06aa772fa33d905e87be6398fb1' => __DIR__ . '/..' . '/symfony/polyfill-intl-idn/bootstrap.php',
|
||||||
'37a3dc5111fe8f707ab4c132ef1dbc62' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/functions_include.php',
|
'37a3dc5111fe8f707ab4c132ef1dbc62' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/functions_include.php',
|
||||||
'3569eecfeed3bcf0bad3c998a494ecb8' => __DIR__ . '/..' . '/sabre/xml/lib/Deserializer/functions.php',
|
'0e6d7bf4a5811bfa5cf40c5ccd6fae6a' => __DIR__ . '/..' . '/symfony/polyfill-mbstring/bootstrap.php',
|
||||||
'93aa591bc4ca510c520999e34229ee79' => __DIR__ . '/..' . '/sabre/xml/lib/Serializer/functions.php',
|
|
||||||
'2b9d0f43f9552984cfa82fee95491826' => __DIR__ . '/..' . '/sabre/event/lib/coroutine.php',
|
'2b9d0f43f9552984cfa82fee95491826' => __DIR__ . '/..' . '/sabre/event/lib/coroutine.php',
|
||||||
'd81bab31d3feb45bfe2f283ea3c8fdf7' => __DIR__ . '/..' . '/sabre/event/lib/Loop/functions.php',
|
'd81bab31d3feb45bfe2f283ea3c8fdf7' => __DIR__ . '/..' . '/sabre/event/lib/Loop/functions.php',
|
||||||
'a1cce3d26cc15c00fcd0b3354bd72c88' => __DIR__ . '/..' . '/sabre/event/lib/Promise/functions.php',
|
'a1cce3d26cc15c00fcd0b3354bd72c88' => __DIR__ . '/..' . '/sabre/event/lib/Promise/functions.php',
|
||||||
|
'3569eecfeed3bcf0bad3c998a494ecb8' => __DIR__ . '/..' . '/sabre/xml/lib/Deserializer/functions.php',
|
||||||
|
'93aa591bc4ca510c520999e34229ee79' => __DIR__ . '/..' . '/sabre/xml/lib/Serializer/functions.php',
|
||||||
'b067bc7112e384b61c701452d53a14a8' => __DIR__ . '/..' . '/mtdowling/jmespath.php/src/JmesPath.php',
|
'b067bc7112e384b61c701452d53a14a8' => __DIR__ . '/..' . '/mtdowling/jmespath.php/src/JmesPath.php',
|
||||||
'ebdb698ed4152ae445614b69b5e4bb6a' => __DIR__ . '/..' . '/sabre/http/lib/functions.php',
|
'ebdb698ed4152ae445614b69b5e4bb6a' => __DIR__ . '/..' . '/sabre/http/lib/functions.php',
|
||||||
'8a9dc1de0ca7e01f3e08231539562f61' => __DIR__ . '/..' . '/aws/aws-sdk-php/src/functions.php',
|
'8a9dc1de0ca7e01f3e08231539562f61' => __DIR__ . '/..' . '/aws/aws-sdk-php/src/functions.php',
|
||||||
@ -1131,6 +1131,7 @@ class ComposerStaticInit0c49a81c1214ef2f7493c6ce921b17ee
|
|||||||
'Aws\\kendra\\kendraClient' => __DIR__ . '/..' . '/aws/aws-sdk-php/src/kendra/kendraClient.php',
|
'Aws\\kendra\\kendraClient' => __DIR__ . '/..' . '/aws/aws-sdk-php/src/kendra/kendraClient.php',
|
||||||
'Aws\\signer\\Exception\\signerException' => __DIR__ . '/..' . '/aws/aws-sdk-php/src/signer/Exception/signerException.php',
|
'Aws\\signer\\Exception\\signerException' => __DIR__ . '/..' . '/aws/aws-sdk-php/src/signer/Exception/signerException.php',
|
||||||
'Aws\\signer\\signerClient' => __DIR__ . '/..' . '/aws/aws-sdk-php/src/signer/signerClient.php',
|
'Aws\\signer\\signerClient' => __DIR__ . '/..' . '/aws/aws-sdk-php/src/signer/signerClient.php',
|
||||||
|
'Composer\\InstalledVersions' => __DIR__ . '/..' . '/composer/InstalledVersions.php',
|
||||||
'Datamatrix' => __DIR__ . '/..' . '/tecnickcom/tcpdf/include/barcodes/datamatrix.php',
|
'Datamatrix' => __DIR__ . '/..' . '/tecnickcom/tcpdf/include/barcodes/datamatrix.php',
|
||||||
'Datto\\JsonRpc\\Client' => __DIR__ . '/..' . '/datto/json-rpc/src/Client.php',
|
'Datto\\JsonRpc\\Client' => __DIR__ . '/..' . '/datto/json-rpc/src/Client.php',
|
||||||
'Datto\\JsonRpc\\Evaluator' => __DIR__ . '/..' . '/datto/json-rpc/src/Evaluator.php',
|
'Datto\\JsonRpc\\Evaluator' => __DIR__ . '/..' . '/datto/json-rpc/src/Evaluator.php',
|
||||||
@ -1435,9 +1436,6 @@ class ComposerStaticInit0c49a81c1214ef2f7493c6ce921b17ee
|
|||||||
'HTMLPurifier_Printer' => __DIR__ . '/..' . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer.php',
|
'HTMLPurifier_Printer' => __DIR__ . '/..' . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer.php',
|
||||||
'HTMLPurifier_Printer_CSSDefinition' => __DIR__ . '/..' . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer/CSSDefinition.php',
|
'HTMLPurifier_Printer_CSSDefinition' => __DIR__ . '/..' . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer/CSSDefinition.php',
|
||||||
'HTMLPurifier_Printer_ConfigForm' => __DIR__ . '/..' . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer/ConfigForm.php',
|
'HTMLPurifier_Printer_ConfigForm' => __DIR__ . '/..' . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer/ConfigForm.php',
|
||||||
'HTMLPurifier_Printer_ConfigForm_NullDecorator' => __DIR__ . '/..' . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer/ConfigForm.php',
|
|
||||||
'HTMLPurifier_Printer_ConfigForm_bool' => __DIR__ . '/..' . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer/ConfigForm.php',
|
|
||||||
'HTMLPurifier_Printer_ConfigForm_default' => __DIR__ . '/..' . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer/ConfigForm.php',
|
|
||||||
'HTMLPurifier_Printer_HTMLDefinition' => __DIR__ . '/..' . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer/HTMLDefinition.php',
|
'HTMLPurifier_Printer_HTMLDefinition' => __DIR__ . '/..' . '/ezyang/htmlpurifier/library/HTMLPurifier/Printer/HTMLDefinition.php',
|
||||||
'HTMLPurifier_PropertyList' => __DIR__ . '/..' . '/ezyang/htmlpurifier/library/HTMLPurifier/PropertyList.php',
|
'HTMLPurifier_PropertyList' => __DIR__ . '/..' . '/ezyang/htmlpurifier/library/HTMLPurifier/PropertyList.php',
|
||||||
'HTMLPurifier_PropertyListIterator' => __DIR__ . '/..' . '/ezyang/htmlpurifier/library/HTMLPurifier/PropertyListIterator.php',
|
'HTMLPurifier_PropertyListIterator' => __DIR__ . '/..' . '/ezyang/htmlpurifier/library/HTMLPurifier/PropertyListIterator.php',
|
||||||
@ -2509,6 +2507,57 @@ class ComposerStaticInit0c49a81c1214ef2f7493c6ce921b17ee
|
|||||||
'TrueBV\\Exception\\LabelOutOfBoundsException' => __DIR__ . '/..' . '/true/punycode/src/Exception/LabelOutOfBoundsException.php',
|
'TrueBV\\Exception\\LabelOutOfBoundsException' => __DIR__ . '/..' . '/true/punycode/src/Exception/LabelOutOfBoundsException.php',
|
||||||
'TrueBV\\Exception\\OutOfBoundsException' => __DIR__ . '/..' . '/true/punycode/src/Exception/OutOfBoundsException.php',
|
'TrueBV\\Exception\\OutOfBoundsException' => __DIR__ . '/..' . '/true/punycode/src/Exception/OutOfBoundsException.php',
|
||||||
'TrueBV\\Punycode' => __DIR__ . '/..' . '/true/punycode/src/Punycode.php',
|
'TrueBV\\Punycode' => __DIR__ . '/..' . '/true/punycode/src/Punycode.php',
|
||||||
|
'Versandart_dhl' => __DIR__ . '/../..' . '/www/lib/versandarten/dhl.php',
|
||||||
|
'Versandart_sendcloud' => __DIR__ . '/../..' . '/www/lib/versandarten/sendcloud.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Bank' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/Bank.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Communication' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/Communication.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Contact' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/Contact.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Country' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/Country.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\CreateShipmentOrderRequest' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/CreateShipmentOrderRequest.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\CreateShipmentOrderResponse' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/CreateShipmentOrderResponse.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\CreationState' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/CreationState.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Customer' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/Customer.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\DeleteShipmentOrderRequest' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/DeleteShipmentOrderRequest.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\DeleteShipmentOrderResponse' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/DeleteShipmentOrderResponse.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\DeletionState' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/DeletionState.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\DeliveryAddress' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/DeliveryAddress.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Dimension' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/Dimension.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\ExportDocPosition' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/ExportDocPosition.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\ExportDocument' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/ExportDocument.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\LabelData' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/LabelData.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Name' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/Name.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\NativeAddress' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/NativeAddress.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\NativeAddressNew' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/NativeAddressNew.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\PackStation' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/PackStation.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Postfiliale' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/Postfiliale.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Receiver' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/Receiver.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\ReceiverNativeAddress' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/ReceiverNativeAddress.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Shipment' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/Shipment.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\ShipmentDetails' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/ShipmentDetails.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\ShipmentItem' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/ShipmentItem.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\ShipmentNotification' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/ShipmentNotification.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\ShipmentOrder' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/ShipmentOrder.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\ShipmentService' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/ShipmentService.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Shipper' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/Shipper.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Status' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/Status.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\StatusElement' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/StatusElement.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Statusinformation' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/Statusinformation.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\Data\\Version' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/Data/Version.php',
|
||||||
|
'Xentral\\Carrier\\Dhl\\DhlApi' => __DIR__ . '/../..' . '/classes/Carrier/Dhl/DhlApi.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\Document' => __DIR__ . '/../..' . '/classes/Carrier/SendCloud/Data/Document.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\Label' => __DIR__ . '/../..' . '/classes/Carrier/SendCloud/Data/Label.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\ParcelBase' => __DIR__ . '/../..' . '/classes/Carrier/SendCloud/Data/ParcelBase.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\ParcelCreation' => __DIR__ . '/../..' . '/classes/Carrier/SendCloud/Data/ParcelCreation.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\ParcelCreationError' => __DIR__ . '/../..' . '/classes/Carrier/SendCloud/Data/ParcelCreationError.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\ParcelItem' => __DIR__ . '/../..' . '/classes/Carrier/SendCloud/Data/ParcelItem.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\ParcelResponse' => __DIR__ . '/../..' . '/classes/Carrier/SendCloud/Data/ParcelResponse.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\SenderAddress' => __DIR__ . '/../..' . '/classes/Carrier/SendCloud/Data/SenderAddress.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\Shipment' => __DIR__ . '/../..' . '/classes/Carrier/SendCloud/Data/Shipment.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\ShippingMethod' => __DIR__ . '/../..' . '/classes/Carrier/SendCloud/Data/ShippingMethod.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\ShippingProduct' => __DIR__ . '/../..' . '/classes/Carrier/SendCloud/Data/ShippingProduct.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\Data\\Status' => __DIR__ . '/../..' . '/classes/Carrier/SendCloud/Data/Status.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\SendCloudApi' => __DIR__ . '/../..' . '/classes/Carrier/SendCloud/SendCloudApi.php',
|
||||||
|
'Xentral\\Carrier\\SendCloud\\SendcloudApiException' => __DIR__ . '/../..' . '/classes/Carrier/SendCloud/SendcloudApiException.php',
|
||||||
'Xentral\\Components\\Backup\\Adapter\\AdapterInterface' => __DIR__ . '/../..' . '/classes/Components/Backup/Adapter/AdapterInterface.php',
|
'Xentral\\Components\\Backup\\Adapter\\AdapterInterface' => __DIR__ . '/../..' . '/classes/Components/Backup/Adapter/AdapterInterface.php',
|
||||||
'Xentral\\Components\\Backup\\Adapter\\ExecAdapter' => __DIR__ . '/../..' . '/classes/Components/Backup/Adapter/ExecAdapter.php',
|
'Xentral\\Components\\Backup\\Adapter\\ExecAdapter' => __DIR__ . '/../..' . '/classes/Components/Backup/Adapter/ExecAdapter.php',
|
||||||
'Xentral\\Components\\Backup\\Bootstrap' => __DIR__ . '/../..' . '/classes/Components/Backup/Bootstrap.php',
|
'Xentral\\Components\\Backup\\Bootstrap' => __DIR__ . '/../..' . '/classes/Components/Backup/Bootstrap.php',
|
||||||
@ -3045,6 +3094,7 @@ class ComposerStaticInit0c49a81c1214ef2f7493c6ce921b17ee
|
|||||||
'Xentral\\Modules\\Article\\Exception\\InvalidArgumentException' => __DIR__ . '/../..' . '/classes/Modules/Article/Exception/InvalidArgumentException.php',
|
'Xentral\\Modules\\Article\\Exception\\InvalidArgumentException' => __DIR__ . '/../..' . '/classes/Modules/Article/Exception/InvalidArgumentException.php',
|
||||||
'Xentral\\Modules\\Article\\Exception\\SellingPriceNotFoundException' => __DIR__ . '/../..' . '/classes/Modules/Article/Exception/SellingPriceNotFoundException.php',
|
'Xentral\\Modules\\Article\\Exception\\SellingPriceNotFoundException' => __DIR__ . '/../..' . '/classes/Modules/Article/Exception/SellingPriceNotFoundException.php',
|
||||||
'Xentral\\Modules\\Article\\Gateway\\ArticleGateway' => __DIR__ . '/../..' . '/classes/Modules/Article/Gateway/ArticleGateway.php',
|
'Xentral\\Modules\\Article\\Gateway\\ArticleGateway' => __DIR__ . '/../..' . '/classes/Modules/Article/Gateway/ArticleGateway.php',
|
||||||
|
'Xentral\\Modules\\Article\\Service\\ArticleService' => __DIR__ . '/../..' . '/classes/Modules/Article/Service/ArticleService.php',
|
||||||
'Xentral\\Modules\\Article\\Service\\CurrencyConversionService' => __DIR__ . '/../..' . '/classes/Modules/Article/Service/CurrencyConversionService.php',
|
'Xentral\\Modules\\Article\\Service\\CurrencyConversionService' => __DIR__ . '/../..' . '/classes/Modules/Article/Service/CurrencyConversionService.php',
|
||||||
'Xentral\\Modules\\Article\\Service\\PurchasePriceService' => __DIR__ . '/../..' . '/classes/Modules/Article/Service/PurchasePriceService.php',
|
'Xentral\\Modules\\Article\\Service\\PurchasePriceService' => __DIR__ . '/../..' . '/classes/Modules/Article/Service/PurchasePriceService.php',
|
||||||
'Xentral\\Modules\\Article\\Service\\SellingPriceService' => __DIR__ . '/../..' . '/classes/Modules/Article/Service/SellingPriceService.php',
|
'Xentral\\Modules\\Article\\Service\\SellingPriceService' => __DIR__ . '/../..' . '/classes/Modules/Article/Service/SellingPriceService.php',
|
||||||
@ -3151,10 +3201,7 @@ class ComposerStaticInit0c49a81c1214ef2f7493c6ce921b17ee
|
|||||||
'Xentral\\Modules\\Datanorm\\Service\\DatanormIntermediateService' => __DIR__ . '/../..' . '/classes/Modules/Datanorm/Service/DatanormIntermediateService.php',
|
'Xentral\\Modules\\Datanorm\\Service\\DatanormIntermediateService' => __DIR__ . '/../..' . '/classes/Modules/Datanorm/Service/DatanormIntermediateService.php',
|
||||||
'Xentral\\Modules\\Datanorm\\Service\\DatanormReader' => __DIR__ . '/../..' . '/classes/Modules/Datanorm/Service/DatanormReader.php',
|
'Xentral\\Modules\\Datanorm\\Service\\DatanormReader' => __DIR__ . '/../..' . '/classes/Modules/Datanorm/Service/DatanormReader.php',
|
||||||
'Xentral\\Modules\\Datanorm\\Wrapper\\AddressWrapper' => __DIR__ . '/../..' . '/classes/Modules/Datanorm/Wrapper/AddressWrapper.php',
|
'Xentral\\Modules\\Datanorm\\Wrapper\\AddressWrapper' => __DIR__ . '/../..' . '/classes/Modules/Datanorm/Wrapper/AddressWrapper.php',
|
||||||
'Xentral\\Modules\\DatevApi\\Bootstrap' => __DIR__ . '/../..' . '/classes/Modules/DatevApi/Bootstrap.php',
|
|
||||||
'Xentral\\Modules\\DatevApi\\DataTable\\DatevExportDataTable' => __DIR__ . '/../..' . '/classes/Modules/DatevApi/DataTable/DatevExportDataTable.php',
|
'Xentral\\Modules\\DatevApi\\DataTable\\DatevExportDataTable' => __DIR__ . '/../..' . '/classes/Modules/DatevApi/DataTable/DatevExportDataTable.php',
|
||||||
'Xentral\\Modules\\DatevApi\\DatevApiService' => __DIR__ . '/../..' . '/classes/Modules/DatevApi/DatevApiService.php',
|
|
||||||
'Xentral\\Modules\\DatevApi\\DatevZipStream' => __DIR__ . '/../..' . '/classes/Modules/DatevApi/DatevZipStream.php',
|
|
||||||
'Xentral\\Modules\\DemoExporter\\Bootstrap' => __DIR__ . '/../..' . '/classes/Modules/DemoExporter/Bootstrap.php',
|
'Xentral\\Modules\\DemoExporter\\Bootstrap' => __DIR__ . '/../..' . '/classes/Modules/DemoExporter/Bootstrap.php',
|
||||||
'Xentral\\Modules\\DemoExporter\\DemoExporterCleanerService' => __DIR__ . '/../..' . '/classes/Modules/DemoExporter/DemoExporterCleanerService.php',
|
'Xentral\\Modules\\DemoExporter\\DemoExporterCleanerService' => __DIR__ . '/../..' . '/classes/Modules/DemoExporter/DemoExporterCleanerService.php',
|
||||||
'Xentral\\Modules\\DemoExporter\\DemoExporterDateiService' => __DIR__ . '/../..' . '/classes/Modules/DemoExporter/DemoExporterDateiService.php',
|
'Xentral\\Modules\\DemoExporter\\DemoExporterDateiService' => __DIR__ . '/../..' . '/classes/Modules/DemoExporter/DemoExporterDateiService.php',
|
||||||
@ -3326,7 +3373,6 @@ class ComposerStaticInit0c49a81c1214ef2f7493c6ce921b17ee
|
|||||||
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyApi' => __DIR__ . '/../..' . '/classes/Modules/FiskalyApi/Service/FiskalyApi.php',
|
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyApi' => __DIR__ . '/../..' . '/classes/Modules/FiskalyApi/Service/FiskalyApi.php',
|
||||||
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyCashPointClosingDBInterface' => __DIR__ . '/../..' . '/classes/Modules/FiskalyApi/Service/FiskalyCashPointClosingDBInterface.php',
|
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyCashPointClosingDBInterface' => __DIR__ . '/../..' . '/classes/Modules/FiskalyApi/Service/FiskalyCashPointClosingDBInterface.php',
|
||||||
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyCashPointClosingDBService' => __DIR__ . '/../..' . '/classes/Modules/FiskalyApi/Service/FiskalyCashPointClosingDBService.php',
|
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyCashPointClosingDBService' => __DIR__ . '/../..' . '/classes/Modules/FiskalyApi/Service/FiskalyCashPointClosingDBService.php',
|
||||||
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyConfig' => __DIR__ . '/../..' . '/classes/Modules/FiskalyApi/Service/FiskalyConfig.php',
|
|
||||||
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyDSFinVKApi' => __DIR__ . '/../..' . '/classes/Modules/FiskalyApi/Service/FiskalyDSFinVKApi.php',
|
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyDSFinVKApi' => __DIR__ . '/../..' . '/classes/Modules/FiskalyApi/Service/FiskalyDSFinVKApi.php',
|
||||||
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyEReceiptApi' => __DIR__ . '/../..' . '/classes/Modules/FiskalyApi/Service/FiskalyEReceiptApi.php',
|
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyEReceiptApi' => __DIR__ . '/../..' . '/classes/Modules/FiskalyApi/Service/FiskalyEReceiptApi.php',
|
||||||
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyKassenSichVApi' => __DIR__ . '/../..' . '/classes/Modules/FiskalyApi/Service/FiskalyKassenSichVApi.php',
|
'Xentral\\Modules\\FiskalyApi\\Service\\FiskalyKassenSichVApi' => __DIR__ . '/../..' . '/classes/Modules/FiskalyApi/Service/FiskalyKassenSichVApi.php',
|
||||||
@ -3507,6 +3553,15 @@ class ComposerStaticInit0c49a81c1214ef2f7493c6ce921b17ee
|
|||||||
'Xentral\\Modules\\MandatoryFields\\Service\\MandatoryFieldsGateway' => __DIR__ . '/../..' . '/classes/Modules/MandatoryFields/Service/MandatoryFieldsGateway.php',
|
'Xentral\\Modules\\MandatoryFields\\Service\\MandatoryFieldsGateway' => __DIR__ . '/../..' . '/classes/Modules/MandatoryFields/Service/MandatoryFieldsGateway.php',
|
||||||
'Xentral\\Modules\\MandatoryFields\\Service\\MandatoryFieldsService' => __DIR__ . '/../..' . '/classes/Modules/MandatoryFields/Service/MandatoryFieldsService.php',
|
'Xentral\\Modules\\MandatoryFields\\Service\\MandatoryFieldsService' => __DIR__ . '/../..' . '/classes/Modules/MandatoryFields/Service/MandatoryFieldsService.php',
|
||||||
'Xentral\\Modules\\MandatoryFields\\Service\\MandatoryFieldsValidator' => __DIR__ . '/../..' . '/classes/Modules/MandatoryFields/Service/MandatoryFieldsValidator.php',
|
'Xentral\\Modules\\MandatoryFields\\Service\\MandatoryFieldsValidator' => __DIR__ . '/../..' . '/classes/Modules/MandatoryFields/Service/MandatoryFieldsValidator.php',
|
||||||
|
'Xentral\\Modules\\MatrixProduct\\Bootstrap' => __DIR__ . '/../..' . '/classes/Modules/MatrixProduct/Bootstrap.php',
|
||||||
|
'Xentral\\Modules\\MatrixProduct\\Data\\Group' => __DIR__ . '/../..' . '/classes/Modules/MatrixProduct/Data/Group.php',
|
||||||
|
'Xentral\\Modules\\MatrixProduct\\Data\\Option' => __DIR__ . '/../..' . '/classes/Modules/MatrixProduct/Data/Option.php',
|
||||||
|
'Xentral\\Modules\\MatrixProduct\\Data\\Translation' => __DIR__ . '/../..' . '/classes/Modules/MatrixProduct/Data/Translation.php',
|
||||||
|
'Xentral\\Modules\\MatrixProduct\\MatrixProductGateway' => __DIR__ . '/../..' . '/classes/Modules/MatrixProduct/MatrixProductGateway.php',
|
||||||
|
'Xentral\\Modules\\MatrixProduct\\MatrixProductService' => __DIR__ . '/../..' . '/classes/Modules/MatrixProduct/MatrixProductService.php',
|
||||||
|
'Xentral\\Modules\\Onlineshop\\Data\\OrderStatus' => __DIR__ . '/../..' . '/classes/Modules/Onlineshop/Data/OrderStatus.php',
|
||||||
|
'Xentral\\Modules\\Onlineshop\\Data\\OrderStatusUpdateRequest' => __DIR__ . '/../..' . '/classes/Modules/Onlineshop/Data/OrderStatusUpdateRequest.php',
|
||||||
|
'Xentral\\Modules\\Onlineshop\\Data\\Shipment' => __DIR__ . '/../..' . '/classes/Modules/Onlineshop/Data/Shipment.php',
|
||||||
'Xentral\\Modules\\Onlineshop\\Data\\ShopConnectorOrderStatusUpdateResponse' => __DIR__ . '/../..' . '/classes/Modules/Onlineshop/Data/ShopConnectorOrderStatusUpdateResponse.php',
|
'Xentral\\Modules\\Onlineshop\\Data\\ShopConnectorOrderStatusUpdateResponse' => __DIR__ . '/../..' . '/classes/Modules/Onlineshop/Data/ShopConnectorOrderStatusUpdateResponse.php',
|
||||||
'Xentral\\Modules\\Onlineshop\\Data\\ShopConnectorResponseInterface' => __DIR__ . '/../..' . '/classes/Modules/Onlineshop/Data/ShopConnectorResponseInterface.php',
|
'Xentral\\Modules\\Onlineshop\\Data\\ShopConnectorResponseInterface' => __DIR__ . '/../..' . '/classes/Modules/Onlineshop/Data/ShopConnectorResponseInterface.php',
|
||||||
'Xentral\\Modules\\PartialDelivery\\Bootstrap' => __DIR__ . '/../..' . '/classes/Modules/PartialDelivery/Bootstrap.php',
|
'Xentral\\Modules\\PartialDelivery\\Bootstrap' => __DIR__ . '/../..' . '/classes/Modules/PartialDelivery/Bootstrap.php',
|
||||||
@ -3664,6 +3719,9 @@ class ComposerStaticInit0c49a81c1214ef2f7493c6ce921b17ee
|
|||||||
'Xentral\\Modules\\ScanArticle\\Wrapper\\PriceWrapper' => __DIR__ . '/../..' . '/classes/Modules/ScanArticle/Wrapper/PriceWrapper.php',
|
'Xentral\\Modules\\ScanArticle\\Wrapper\\PriceWrapper' => __DIR__ . '/../..' . '/classes/Modules/ScanArticle/Wrapper/PriceWrapper.php',
|
||||||
'Xentral\\Modules\\ScanArticle\\Wrapper\\SavePositionWrapper' => __DIR__ . '/../..' . '/classes/Modules/ScanArticle/Wrapper/SavePositionWrapper.php',
|
'Xentral\\Modules\\ScanArticle\\Wrapper\\SavePositionWrapper' => __DIR__ . '/../..' . '/classes/Modules/ScanArticle/Wrapper/SavePositionWrapper.php',
|
||||||
'Xentral\\Modules\\Setting\\Bootstrap' => __DIR__ . '/../..' . '/classes/Modules/Setting/Bootstrap.php',
|
'Xentral\\Modules\\Setting\\Bootstrap' => __DIR__ . '/../..' . '/classes/Modules/Setting/Bootstrap.php',
|
||||||
|
'Xentral\\Modules\\ShippingMethod\\Model\\CreateShipmentResult' => __DIR__ . '/../..' . '/classes/Modules/ShippingMethod/Model/CreateShipmentResult.php',
|
||||||
|
'Xentral\\Modules\\ShippingMethod\\Model\\CustomsInfo' => __DIR__ . '/../..' . '/classes/Modules/ShippingMethod/Model/CustomsInfo.php',
|
||||||
|
'Xentral\\Modules\\ShippingMethod\\Model\\Product' => __DIR__ . '/../..' . '/classes/Modules/ShippingMethod/Model/Product.php',
|
||||||
'Xentral\\Modules\\ShippingTaxSplit\\Bootstrap' => __DIR__ . '/../..' . '/classes/Modules/ShippingTaxSplit/Bootstrap.php',
|
'Xentral\\Modules\\ShippingTaxSplit\\Bootstrap' => __DIR__ . '/../..' . '/classes/Modules/ShippingTaxSplit/Bootstrap.php',
|
||||||
'Xentral\\Modules\\ShippingTaxSplit\\Exception\\InvalidArgumentException' => __DIR__ . '/../..' . '/classes/Modules/ShippingTaxSplit/Exception/InvalidArgumentException.php',
|
'Xentral\\Modules\\ShippingTaxSplit\\Exception\\InvalidArgumentException' => __DIR__ . '/../..' . '/classes/Modules/ShippingTaxSplit/Exception/InvalidArgumentException.php',
|
||||||
'Xentral\\Modules\\ShippingTaxSplit\\Exception\\ShippingTaxSplitExceptionInterface' => __DIR__ . '/../..' . '/classes/Modules/ShippingTaxSplit/Exception/ShippingTaxSplitExceptionInterface.php',
|
'Xentral\\Modules\\ShippingTaxSplit\\Exception\\ShippingTaxSplitExceptionInterface' => __DIR__ . '/../..' . '/classes/Modules/ShippingTaxSplit/Exception/ShippingTaxSplitExceptionInterface.php',
|
||||||
@ -3723,6 +3781,7 @@ class ComposerStaticInit0c49a81c1214ef2f7493c6ce921b17ee
|
|||||||
'Xentral\\Modules\\SubscriptionCycle\\Service\\SubscriptionCycleJobService' => __DIR__ . '/../..' . '/classes/Modules/SubscriptionCycle/Service/SubscriptionCycleJobService.php',
|
'Xentral\\Modules\\SubscriptionCycle\\Service\\SubscriptionCycleJobService' => __DIR__ . '/../..' . '/classes/Modules/SubscriptionCycle/Service/SubscriptionCycleJobService.php',
|
||||||
'Xentral\\Modules\\SubscriptionCycle\\SubscriptionCycleCacheFiller' => __DIR__ . '/../..' . '/classes/Modules/SubscriptionCycle/SubscriptionCycleCacheFiller.php',
|
'Xentral\\Modules\\SubscriptionCycle\\SubscriptionCycleCacheFiller' => __DIR__ . '/../..' . '/classes/Modules/SubscriptionCycle/SubscriptionCycleCacheFiller.php',
|
||||||
'Xentral\\Modules\\SubscriptionCycle\\SubscriptionCycleModuleInterface' => __DIR__ . '/../..' . '/classes/Modules/SubscriptionCycle/SubscriptionCycleModuleInterface.php',
|
'Xentral\\Modules\\SubscriptionCycle\\SubscriptionCycleModuleInterface' => __DIR__ . '/../..' . '/classes/Modules/SubscriptionCycle/SubscriptionCycleModuleInterface.php',
|
||||||
|
'Xentral\\Modules\\SubscriptionCycle\\SubscriptionModule' => __DIR__ . '/../..' . '/classes/Modules/SubscriptionCycle/SubscriptionModule.php',
|
||||||
'Xentral\\Modules\\SubscriptionCycle\\SubscriptionModuleInterface' => __DIR__ . '/../..' . '/classes/Modules/SubscriptionCycle/SubscriptionModuleInterface.php',
|
'Xentral\\Modules\\SubscriptionCycle\\SubscriptionModuleInterface' => __DIR__ . '/../..' . '/classes/Modules/SubscriptionCycle/SubscriptionModuleInterface.php',
|
||||||
'Xentral\\Modules\\SubscriptionCycle\\Wrapper\\BusinessLetterWrapper' => __DIR__ . '/../..' . '/classes/Modules/SubscriptionCycle/Wrapper/BusinessLetterWrapper.php',
|
'Xentral\\Modules\\SubscriptionCycle\\Wrapper\\BusinessLetterWrapper' => __DIR__ . '/../..' . '/classes/Modules/SubscriptionCycle/Wrapper/BusinessLetterWrapper.php',
|
||||||
'Xentral\\Modules\\SuperSearch\\Bootstrap' => __DIR__ . '/../..' . '/classes/Modules/SuperSearch/Bootstrap.php',
|
'Xentral\\Modules\\SuperSearch\\Bootstrap' => __DIR__ . '/../..' . '/classes/Modules/SuperSearch/Bootstrap.php',
|
||||||
|
165
vendor/composer/installed.json
vendored
165
vendor/composer/installed.json
vendored
@ -1,4 +1,5 @@
|
|||||||
[
|
{
|
||||||
|
"packages": [
|
||||||
{
|
{
|
||||||
"name": "aura/sqlquery",
|
"name": "aura/sqlquery",
|
||||||
"version": "2.7.1",
|
"version": "2.7.1",
|
||||||
@ -67,7 +68,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/auraphp/Aura.SqlQuery/issues",
|
"issues": "https://github.com/auraphp/Aura.SqlQuery/issues",
|
||||||
"source": "https://github.com/auraphp/Aura.SqlQuery/tree/2.7.1"
|
"source": "https://github.com/auraphp/Aura.SqlQuery/tree/2.7.1"
|
||||||
}
|
},
|
||||||
|
"install-path": "../aura/sqlquery"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "aws/aws-sdk-php",
|
"name": "aws/aws-sdk-php",
|
||||||
@ -159,7 +161,8 @@
|
|||||||
"forum": "https://forums.aws.amazon.com/forum.jspa?forumID=80",
|
"forum": "https://forums.aws.amazon.com/forum.jspa?forumID=80",
|
||||||
"issues": "https://github.com/aws/aws-sdk-php/issues",
|
"issues": "https://github.com/aws/aws-sdk-php/issues",
|
||||||
"source": "https://github.com/aws/aws-sdk-php/tree/3.175.2"
|
"source": "https://github.com/aws/aws-sdk-php/tree/3.175.2"
|
||||||
}
|
},
|
||||||
|
"install-path": "../aws/aws-sdk-php"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "container-interop/container-interop",
|
"name": "container-interop/container-interop",
|
||||||
@ -197,7 +200,8 @@
|
|||||||
"issues": "https://github.com/container-interop/container-interop/issues",
|
"issues": "https://github.com/container-interop/container-interop/issues",
|
||||||
"source": "https://github.com/container-interop/container-interop/tree/master"
|
"source": "https://github.com/container-interop/container-interop/tree/master"
|
||||||
},
|
},
|
||||||
"abandoned": "psr/container"
|
"abandoned": "psr/container",
|
||||||
|
"install-path": "../container-interop/container-interop"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "datto/json-rpc",
|
"name": "datto/json-rpc",
|
||||||
@ -253,7 +257,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/datto/php-json-rpc/issues",
|
"issues": "https://github.com/datto/php-json-rpc/issues",
|
||||||
"source": "https://github.com/datto/php-json-rpc/tree/6.1.0"
|
"source": "https://github.com/datto/php-json-rpc/tree/6.1.0"
|
||||||
}
|
},
|
||||||
|
"install-path": "../datto/json-rpc"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "datto/json-rpc-http",
|
"name": "datto/json-rpc-http",
|
||||||
@ -311,7 +316,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/datto/php-json-rpc-http/issues",
|
"issues": "https://github.com/datto/php-json-rpc-http/issues",
|
||||||
"source": "https://github.com/datto/php-json-rpc-http/tree/master"
|
"source": "https://github.com/datto/php-json-rpc-http/tree/master"
|
||||||
}
|
},
|
||||||
|
"install-path": "../datto/json-rpc-http"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "ezyang/htmlpurifier",
|
"name": "ezyang/htmlpurifier",
|
||||||
@ -367,7 +373,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/ezyang/htmlpurifier/issues",
|
"issues": "https://github.com/ezyang/htmlpurifier/issues",
|
||||||
"source": "https://github.com/ezyang/htmlpurifier/tree/master"
|
"source": "https://github.com/ezyang/htmlpurifier/tree/master"
|
||||||
}
|
},
|
||||||
|
"install-path": "../ezyang/htmlpurifier"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "fiskaly/fiskaly-sdk-php",
|
"name": "fiskaly/fiskaly-sdk-php",
|
||||||
@ -415,7 +422,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/fiskaly/fiskaly-sdk-php/issues",
|
"issues": "https://github.com/fiskaly/fiskaly-sdk-php/issues",
|
||||||
"source": "https://github.com/fiskaly/fiskaly-sdk-php/tree/v1.2.100"
|
"source": "https://github.com/fiskaly/fiskaly-sdk-php/tree/v1.2.100"
|
||||||
}
|
},
|
||||||
|
"install-path": "../fiskaly/fiskaly-sdk-php"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "guzzlehttp/guzzle",
|
"name": "guzzlehttp/guzzle",
|
||||||
@ -488,7 +496,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/guzzle/guzzle/issues",
|
"issues": "https://github.com/guzzle/guzzle/issues",
|
||||||
"source": "https://github.com/guzzle/guzzle/tree/6.5"
|
"source": "https://github.com/guzzle/guzzle/tree/6.5"
|
||||||
}
|
},
|
||||||
|
"install-path": "../guzzlehttp/guzzle"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "guzzlehttp/promises",
|
"name": "guzzlehttp/promises",
|
||||||
@ -545,7 +554,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/guzzle/promises/issues",
|
"issues": "https://github.com/guzzle/promises/issues",
|
||||||
"source": "https://github.com/guzzle/promises/tree/1.4.1"
|
"source": "https://github.com/guzzle/promises/tree/1.4.1"
|
||||||
}
|
},
|
||||||
|
"install-path": "../guzzlehttp/promises"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "guzzlehttp/psr7",
|
"name": "guzzlehttp/psr7",
|
||||||
@ -622,7 +632,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/guzzle/psr7/issues",
|
"issues": "https://github.com/guzzle/psr7/issues",
|
||||||
"source": "https://github.com/guzzle/psr7/tree/1.8.1"
|
"source": "https://github.com/guzzle/psr7/tree/1.8.1"
|
||||||
}
|
},
|
||||||
|
"install-path": "../guzzlehttp/psr7"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "laminas/laminas-loader",
|
"name": "laminas/laminas-loader",
|
||||||
@ -681,7 +692,8 @@
|
|||||||
"issues": "https://github.com/laminas/laminas-loader/issues",
|
"issues": "https://github.com/laminas/laminas-loader/issues",
|
||||||
"rss": "https://github.com/laminas/laminas-loader/releases.atom",
|
"rss": "https://github.com/laminas/laminas-loader/releases.atom",
|
||||||
"source": "https://github.com/laminas/laminas-loader"
|
"source": "https://github.com/laminas/laminas-loader"
|
||||||
}
|
},
|
||||||
|
"install-path": "../laminas/laminas-loader"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "laminas/laminas-mail",
|
"name": "laminas/laminas-mail",
|
||||||
@ -759,7 +771,8 @@
|
|||||||
"url": "https://funding.communitybridge.org/projects/laminas-project",
|
"url": "https://funding.communitybridge.org/projects/laminas-project",
|
||||||
"type": "community_bridge"
|
"type": "community_bridge"
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
"install-path": "../laminas/laminas-mail"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "laminas/laminas-mime",
|
"name": "laminas/laminas-mime",
|
||||||
@ -823,7 +836,8 @@
|
|||||||
"issues": "https://github.com/laminas/laminas-mime/issues",
|
"issues": "https://github.com/laminas/laminas-mime/issues",
|
||||||
"rss": "https://github.com/laminas/laminas-mime/releases.atom",
|
"rss": "https://github.com/laminas/laminas-mime/releases.atom",
|
||||||
"source": "https://github.com/laminas/laminas-mime"
|
"source": "https://github.com/laminas/laminas-mime"
|
||||||
}
|
},
|
||||||
|
"install-path": "../laminas/laminas-mime"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "laminas/laminas-stdlib",
|
"name": "laminas/laminas-stdlib",
|
||||||
@ -883,7 +897,8 @@
|
|||||||
"issues": "https://github.com/laminas/laminas-stdlib/issues",
|
"issues": "https://github.com/laminas/laminas-stdlib/issues",
|
||||||
"rss": "https://github.com/laminas/laminas-stdlib/releases.atom",
|
"rss": "https://github.com/laminas/laminas-stdlib/releases.atom",
|
||||||
"source": "https://github.com/laminas/laminas-stdlib"
|
"source": "https://github.com/laminas/laminas-stdlib"
|
||||||
}
|
},
|
||||||
|
"install-path": "../laminas/laminas-stdlib"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "laminas/laminas-validator",
|
"name": "laminas/laminas-validator",
|
||||||
@ -974,7 +989,8 @@
|
|||||||
"url": "https://funding.communitybridge.org/projects/laminas-project",
|
"url": "https://funding.communitybridge.org/projects/laminas-project",
|
||||||
"type": "community_bridge"
|
"type": "community_bridge"
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
"install-path": "../laminas/laminas-validator"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "league/color-extractor",
|
"name": "league/color-extractor",
|
||||||
@ -1034,7 +1050,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/thephpleague/color-extractor/issues",
|
"issues": "https://github.com/thephpleague/color-extractor/issues",
|
||||||
"source": "https://github.com/thephpleague/color-extractor/tree/master"
|
"source": "https://github.com/thephpleague/color-extractor/tree/master"
|
||||||
}
|
},
|
||||||
|
"install-path": "../league/color-extractor"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "league/flysystem",
|
"name": "league/flysystem",
|
||||||
@ -1130,7 +1147,8 @@
|
|||||||
"url": "https://offset.earth/frankdejonge",
|
"url": "https://offset.earth/frankdejonge",
|
||||||
"type": "other"
|
"type": "other"
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
"install-path": "../league/flysystem"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "league/oauth1-client",
|
"name": "league/oauth1-client",
|
||||||
@ -1207,7 +1225,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/thephpleague/oauth1-client/issues",
|
"issues": "https://github.com/thephpleague/oauth1-client/issues",
|
||||||
"source": "https://github.com/thephpleague/oauth1-client/tree/v1.9.0"
|
"source": "https://github.com/thephpleague/oauth1-client/tree/v1.9.0"
|
||||||
}
|
},
|
||||||
|
"install-path": "../league/oauth1-client"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "league/oauth2-client",
|
"name": "league/oauth2-client",
|
||||||
@ -1279,7 +1298,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/thephpleague/oauth2-client/issues",
|
"issues": "https://github.com/thephpleague/oauth2-client/issues",
|
||||||
"source": "https://github.com/thephpleague/oauth2-client/tree/2.6.0"
|
"source": "https://github.com/thephpleague/oauth2-client/tree/2.6.0"
|
||||||
}
|
},
|
||||||
|
"install-path": "../league/oauth2-client"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "lfkeitel/phptotp",
|
"name": "lfkeitel/phptotp",
|
||||||
@ -1321,7 +1341,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/lfkeitel/php-totp/issues",
|
"issues": "https://github.com/lfkeitel/php-totp/issues",
|
||||||
"source": "https://github.com/lfkeitel/php-totp/tree/v1.0.0"
|
"source": "https://github.com/lfkeitel/php-totp/tree/v1.0.0"
|
||||||
}
|
},
|
||||||
|
"install-path": "../lfkeitel/phptotp"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "mtdowling/jmespath.php",
|
"name": "mtdowling/jmespath.php",
|
||||||
@ -1358,12 +1379,12 @@
|
|||||||
},
|
},
|
||||||
"installation-source": "dist",
|
"installation-source": "dist",
|
||||||
"autoload": {
|
"autoload": {
|
||||||
"psr-4": {
|
|
||||||
"JmesPath\\": "src/"
|
|
||||||
},
|
|
||||||
"files": [
|
"files": [
|
||||||
"src/JmesPath.php"
|
"src/JmesPath.php"
|
||||||
]
|
],
|
||||||
|
"psr-4": {
|
||||||
|
"JmesPath\\": "src/"
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"notification-url": "https://packagist.org/downloads/",
|
"notification-url": "https://packagist.org/downloads/",
|
||||||
"license": [
|
"license": [
|
||||||
@ -1384,7 +1405,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/jmespath/jmespath.php/issues",
|
"issues": "https://github.com/jmespath/jmespath.php/issues",
|
||||||
"source": "https://github.com/jmespath/jmespath.php/tree/2.6.0"
|
"source": "https://github.com/jmespath/jmespath.php/tree/2.6.0"
|
||||||
}
|
},
|
||||||
|
"install-path": "../mtdowling/jmespath.php"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "nikic/fast-route",
|
"name": "nikic/fast-route",
|
||||||
@ -1436,7 +1458,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/nikic/FastRoute/issues",
|
"issues": "https://github.com/nikic/FastRoute/issues",
|
||||||
"source": "https://github.com/nikic/FastRoute/tree/master"
|
"source": "https://github.com/nikic/FastRoute/tree/master"
|
||||||
}
|
},
|
||||||
|
"install-path": "../nikic/fast-route"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "paragonie/random_compat",
|
"name": "paragonie/random_compat",
|
||||||
@ -1488,7 +1511,8 @@
|
|||||||
"email": "info@paragonie.com",
|
"email": "info@paragonie.com",
|
||||||
"issues": "https://github.com/paragonie/random_compat/issues",
|
"issues": "https://github.com/paragonie/random_compat/issues",
|
||||||
"source": "https://github.com/paragonie/random_compat"
|
"source": "https://github.com/paragonie/random_compat"
|
||||||
}
|
},
|
||||||
|
"install-path": "../paragonie/random_compat"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "phpmailer/phpmailer",
|
"name": "phpmailer/phpmailer",
|
||||||
@ -1566,7 +1590,8 @@
|
|||||||
"url": "https://github.com/Synchro",
|
"url": "https://github.com/Synchro",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
"install-path": "../phpmailer/phpmailer"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "phpseclib/phpseclib",
|
"name": "phpseclib/phpseclib",
|
||||||
@ -1677,7 +1702,8 @@
|
|||||||
"url": "https://tidelift.com/funding/github/packagist/phpseclib/phpseclib",
|
"url": "https://tidelift.com/funding/github/packagist/phpseclib/phpseclib",
|
||||||
"type": "tidelift"
|
"type": "tidelift"
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
"install-path": "../phpseclib/phpseclib"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "psr/container",
|
"name": "psr/container",
|
||||||
@ -1727,7 +1753,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/php-fig/container/issues",
|
"issues": "https://github.com/php-fig/container/issues",
|
||||||
"source": "https://github.com/php-fig/container/tree/1.1.1"
|
"source": "https://github.com/php-fig/container/tree/1.1.1"
|
||||||
}
|
},
|
||||||
|
"install-path": "../psr/container"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "psr/http-message",
|
"name": "psr/http-message",
|
||||||
@ -1782,7 +1809,8 @@
|
|||||||
],
|
],
|
||||||
"support": {
|
"support": {
|
||||||
"source": "https://github.com/php-fig/http-message/tree/master"
|
"source": "https://github.com/php-fig/http-message/tree/master"
|
||||||
}
|
},
|
||||||
|
"install-path": "../psr/http-message"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "psr/log",
|
"name": "psr/log",
|
||||||
@ -1834,7 +1862,8 @@
|
|||||||
],
|
],
|
||||||
"support": {
|
"support": {
|
||||||
"source": "https://github.com/php-fig/log/tree/1.1.3"
|
"source": "https://github.com/php-fig/log/tree/1.1.3"
|
||||||
}
|
},
|
||||||
|
"install-path": "../psr/log"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "rakit/validation",
|
"name": "rakit/validation",
|
||||||
@ -1880,7 +1909,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/rakit/validation/issues",
|
"issues": "https://github.com/rakit/validation/issues",
|
||||||
"source": "https://github.com/rakit/validation/tree/master"
|
"source": "https://github.com/rakit/validation/tree/master"
|
||||||
}
|
},
|
||||||
|
"install-path": "../rakit/validation"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "ralouphie/getallheaders",
|
"name": "ralouphie/getallheaders",
|
||||||
@ -1926,7 +1956,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/ralouphie/getallheaders/issues",
|
"issues": "https://github.com/ralouphie/getallheaders/issues",
|
||||||
"source": "https://github.com/ralouphie/getallheaders/tree/develop"
|
"source": "https://github.com/ralouphie/getallheaders/tree/develop"
|
||||||
}
|
},
|
||||||
|
"install-path": "../ralouphie/getallheaders"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "sabre/dav",
|
"name": "sabre/dav",
|
||||||
@ -2016,7 +2047,8 @@
|
|||||||
"forum": "https://groups.google.com/group/sabredav-discuss",
|
"forum": "https://groups.google.com/group/sabredav-discuss",
|
||||||
"issues": "https://github.com/sabre-io/dav/issues",
|
"issues": "https://github.com/sabre-io/dav/issues",
|
||||||
"source": "https://github.com/fruux/sabre-dav"
|
"source": "https://github.com/fruux/sabre-dav"
|
||||||
}
|
},
|
||||||
|
"install-path": "../sabre/dav"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "sabre/event",
|
"name": "sabre/event",
|
||||||
@ -2080,7 +2112,8 @@
|
|||||||
"forum": "https://groups.google.com/group/sabredav-discuss",
|
"forum": "https://groups.google.com/group/sabredav-discuss",
|
||||||
"issues": "https://github.com/sabre-io/event/issues",
|
"issues": "https://github.com/sabre-io/event/issues",
|
||||||
"source": "https://github.com/fruux/sabre-event"
|
"source": "https://github.com/fruux/sabre-event"
|
||||||
}
|
},
|
||||||
|
"install-path": "../sabre/event"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "sabre/http",
|
"name": "sabre/http",
|
||||||
@ -2143,7 +2176,8 @@
|
|||||||
"forum": "https://groups.google.com/group/sabredav-discuss",
|
"forum": "https://groups.google.com/group/sabredav-discuss",
|
||||||
"issues": "https://github.com/sabre-io/http/issues",
|
"issues": "https://github.com/sabre-io/http/issues",
|
||||||
"source": "https://github.com/fruux/sabre-http"
|
"source": "https://github.com/fruux/sabre-http"
|
||||||
}
|
},
|
||||||
|
"install-path": "../sabre/http"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "sabre/uri",
|
"name": "sabre/uri",
|
||||||
@ -2201,7 +2235,8 @@
|
|||||||
"forum": "https://groups.google.com/group/sabredav-discuss",
|
"forum": "https://groups.google.com/group/sabredav-discuss",
|
||||||
"issues": "https://github.com/sabre-io/uri/issues",
|
"issues": "https://github.com/sabre-io/uri/issues",
|
||||||
"source": "https://github.com/fruux/sabre-uri"
|
"source": "https://github.com/fruux/sabre-uri"
|
||||||
}
|
},
|
||||||
|
"install-path": "../sabre/uri"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "sabre/vobject",
|
"name": "sabre/vobject",
|
||||||
@ -2304,7 +2339,8 @@
|
|||||||
"forum": "https://groups.google.com/group/sabredav-discuss",
|
"forum": "https://groups.google.com/group/sabredav-discuss",
|
||||||
"issues": "https://github.com/sabre-io/vobject/issues",
|
"issues": "https://github.com/sabre-io/vobject/issues",
|
||||||
"source": "https://github.com/fruux/sabre-vobject"
|
"source": "https://github.com/fruux/sabre-vobject"
|
||||||
}
|
},
|
||||||
|
"install-path": "../sabre/vobject"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "sabre/xml",
|
"name": "sabre/xml",
|
||||||
@ -2374,7 +2410,8 @@
|
|||||||
"forum": "https://groups.google.com/group/sabredav-discuss",
|
"forum": "https://groups.google.com/group/sabredav-discuss",
|
||||||
"issues": "https://github.com/sabre-io/xml/issues",
|
"issues": "https://github.com/sabre-io/xml/issues",
|
||||||
"source": "https://github.com/fruux/sabre-xml"
|
"source": "https://github.com/fruux/sabre-xml"
|
||||||
}
|
},
|
||||||
|
"install-path": "../sabre/xml"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "smarty/smarty",
|
"name": "smarty/smarty",
|
||||||
@ -2439,7 +2476,8 @@
|
|||||||
"irc": "irc://irc.freenode.org/smarty",
|
"irc": "irc://irc.freenode.org/smarty",
|
||||||
"issues": "https://github.com/smarty-php/smarty/issues",
|
"issues": "https://github.com/smarty-php/smarty/issues",
|
||||||
"source": "https://github.com/smarty-php/smarty/tree/v3.1.39"
|
"source": "https://github.com/smarty-php/smarty/tree/v3.1.39"
|
||||||
}
|
},
|
||||||
|
"install-path": "../smarty/smarty"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "swiss-payment-slip/swiss-payment-slip",
|
"name": "swiss-payment-slip/swiss-payment-slip",
|
||||||
@ -2506,7 +2544,8 @@
|
|||||||
"email": "ravage@bluewin.ch",
|
"email": "ravage@bluewin.ch",
|
||||||
"issues": "https://github.com/ravage84/SwissPaymentSlip/issues",
|
"issues": "https://github.com/ravage84/SwissPaymentSlip/issues",
|
||||||
"source": "https://github.com/ravage84/SwissPaymentSlip"
|
"source": "https://github.com/ravage84/SwissPaymentSlip"
|
||||||
}
|
},
|
||||||
|
"install-path": "../swiss-payment-slip/swiss-payment-slip"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "swiss-payment-slip/swiss-payment-slip-fpdf",
|
"name": "swiss-payment-slip/swiss-payment-slip-fpdf",
|
||||||
@ -2579,7 +2618,8 @@
|
|||||||
"email": "ravage@bluewin.ch",
|
"email": "ravage@bluewin.ch",
|
||||||
"issues": "https://github.com/ravage84/SwissPaymentSlipFpdf/issues",
|
"issues": "https://github.com/ravage84/SwissPaymentSlipFpdf/issues",
|
||||||
"source": "https://github.com/ravage84/SwissPaymentSlipFpdf"
|
"source": "https://github.com/ravage84/SwissPaymentSlipFpdf"
|
||||||
}
|
},
|
||||||
|
"install-path": "../swiss-payment-slip/swiss-payment-slip-fpdf"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "swiss-payment-slip/swiss-payment-slip-pdf",
|
"name": "swiss-payment-slip/swiss-payment-slip-pdf",
|
||||||
@ -2649,7 +2689,8 @@
|
|||||||
"email": "ravage@bluewin.ch",
|
"email": "ravage@bluewin.ch",
|
||||||
"issues": "https://github.com/ravage84/SwissPaymentSlipPdf/issues",
|
"issues": "https://github.com/ravage84/SwissPaymentSlipPdf/issues",
|
||||||
"source": "https://github.com/ravage84/SwissPaymentSlipPdf"
|
"source": "https://github.com/ravage84/SwissPaymentSlipPdf"
|
||||||
}
|
},
|
||||||
|
"install-path": "../swiss-payment-slip/swiss-payment-slip-pdf"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "symfony/polyfill-intl-idn",
|
"name": "symfony/polyfill-intl-idn",
|
||||||
@ -2687,12 +2728,12 @@
|
|||||||
},
|
},
|
||||||
"installation-source": "dist",
|
"installation-source": "dist",
|
||||||
"autoload": {
|
"autoload": {
|
||||||
"psr-4": {
|
|
||||||
"Symfony\\Polyfill\\Intl\\Idn\\": ""
|
|
||||||
},
|
|
||||||
"files": [
|
"files": [
|
||||||
"bootstrap.php"
|
"bootstrap.php"
|
||||||
]
|
],
|
||||||
|
"psr-4": {
|
||||||
|
"Symfony\\Polyfill\\Intl\\Idn\\": ""
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"notification-url": "https://packagist.org/downloads/",
|
"notification-url": "https://packagist.org/downloads/",
|
||||||
"license": [
|
"license": [
|
||||||
@ -2738,7 +2779,8 @@
|
|||||||
"url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
|
"url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
|
||||||
"type": "tidelift"
|
"type": "tidelift"
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
"install-path": "../symfony/polyfill-intl-idn"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "symfony/polyfill-intl-normalizer",
|
"name": "symfony/polyfill-intl-normalizer",
|
||||||
@ -2824,7 +2866,8 @@
|
|||||||
"url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
|
"url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
|
||||||
"type": "tidelift"
|
"type": "tidelift"
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
"install-path": "../symfony/polyfill-intl-normalizer"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "symfony/polyfill-mbstring",
|
"name": "symfony/polyfill-mbstring",
|
||||||
@ -2906,7 +2949,8 @@
|
|||||||
"url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
|
"url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
|
||||||
"type": "tidelift"
|
"type": "tidelift"
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
"install-path": "../symfony/polyfill-mbstring"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "symfony/polyfill-php72",
|
"name": "symfony/polyfill-php72",
|
||||||
@ -2984,7 +3028,8 @@
|
|||||||
"url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
|
"url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
|
||||||
"type": "tidelift"
|
"type": "tidelift"
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
"install-path": "../symfony/polyfill-php72"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "tecnickcom/tcpdf",
|
"name": "tecnickcom/tcpdf",
|
||||||
@ -3052,7 +3097,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/tecnickcom/TCPDF/issues",
|
"issues": "https://github.com/tecnickcom/TCPDF/issues",
|
||||||
"source": "https://github.com/tecnickcom/TCPDF/tree/6.3.5"
|
"source": "https://github.com/tecnickcom/TCPDF/tree/6.3.5"
|
||||||
}
|
},
|
||||||
|
"install-path": "../tecnickcom/tcpdf"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "true/punycode",
|
"name": "true/punycode",
|
||||||
@ -3104,7 +3150,8 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/true/php-punycode/issues",
|
"issues": "https://github.com/true/php-punycode/issues",
|
||||||
"source": "https://github.com/true/php-punycode/tree/master"
|
"source": "https://github.com/true/php-punycode/tree/master"
|
||||||
}
|
},
|
||||||
|
"install-path": "../true/punycode"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "y0lk/oauth1-etsy",
|
"name": "y0lk/oauth1-etsy",
|
||||||
@ -3159,6 +3206,10 @@
|
|||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/Y0lk/oauth1-etsy/issues",
|
"issues": "https://github.com/Y0lk/oauth1-etsy/issues",
|
||||||
"source": "https://github.com/Y0lk/oauth1-etsy/tree/1.1.0"
|
"source": "https://github.com/Y0lk/oauth1-etsy/tree/1.1.0"
|
||||||
|
},
|
||||||
|
"install-path": "../y0lk/oauth1-etsy"
|
||||||
}
|
}
|
||||||
}
|
],
|
||||||
]
|
"dev": true,
|
||||||
|
"dev-package-names": []
|
||||||
|
}
|
||||||
|
502
vendor/composer/installed.php
vendored
Normal file
502
vendor/composer/installed.php
vendored
Normal file
@ -0,0 +1,502 @@
|
|||||||
|
<?php return array(
|
||||||
|
'root' => array(
|
||||||
|
'name' => '__root__',
|
||||||
|
'pretty_version' => 'dev-master',
|
||||||
|
'version' => 'dev-master',
|
||||||
|
'reference' => '95cb03f43b1395537a50c081cd9287e4f5ea50c1',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../../',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev' => true,
|
||||||
|
),
|
||||||
|
'versions' => array(
|
||||||
|
'__root__' => array(
|
||||||
|
'pretty_version' => 'dev-master',
|
||||||
|
'version' => 'dev-master',
|
||||||
|
'reference' => '95cb03f43b1395537a50c081cd9287e4f5ea50c1',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../../',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'aura/sqlquery' => array(
|
||||||
|
'pretty_version' => '2.7.1',
|
||||||
|
'version' => '2.7.1.0',
|
||||||
|
'reference' => 'dd81b57aeb43628180a9c70a4df58d872024d7f2',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../aura/sqlquery',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'aws/aws-sdk-php' => array(
|
||||||
|
'pretty_version' => '3.175.2',
|
||||||
|
'version' => '3.175.2.0',
|
||||||
|
'reference' => 'a8e88eac60b403ed76643327e74f55831570a64b',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../aws/aws-sdk-php',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'container-interop/container-interop' => array(
|
||||||
|
'pretty_version' => '1.2.0',
|
||||||
|
'version' => '1.2.0.0',
|
||||||
|
'reference' => '79cbf1341c22ec75643d841642dd5d6acd83bdb8',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../container-interop/container-interop',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'datto/json-rpc' => array(
|
||||||
|
'pretty_version' => '6.1.0',
|
||||||
|
'version' => '6.1.0.0',
|
||||||
|
'reference' => 'ad4d735f48d80c6b53f7405e5007d97c996533f6',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../datto/json-rpc',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'datto/json-rpc-http' => array(
|
||||||
|
'pretty_version' => '5.0.6',
|
||||||
|
'version' => '5.0.6.0',
|
||||||
|
'reference' => 'db15a075f3562c4e8d297b9082acc5b2869bd4b4',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../datto/json-rpc-http',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'ezyang/htmlpurifier' => array(
|
||||||
|
'pretty_version' => 'v4.13.0',
|
||||||
|
'version' => '4.13.0.0',
|
||||||
|
'reference' => '08e27c97e4c6ed02f37c5b2b20488046c8d90d75',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../ezyang/htmlpurifier',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'fiskaly/fiskaly-sdk-php' => array(
|
||||||
|
'pretty_version' => '1.2.100',
|
||||||
|
'version' => '1.2.100.0',
|
||||||
|
'reference' => 'f2598d32f51ca18f81615df2b63deff7d9569097',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../fiskaly/fiskaly-sdk-php',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'guzzlehttp/guzzle' => array(
|
||||||
|
'pretty_version' => '6.5.5',
|
||||||
|
'version' => '6.5.5.0',
|
||||||
|
'reference' => '9d4290de1cfd701f38099ef7e183b64b4b7b0c5e',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../guzzlehttp/guzzle',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'guzzlehttp/promises' => array(
|
||||||
|
'pretty_version' => '1.4.1',
|
||||||
|
'version' => '1.4.1.0',
|
||||||
|
'reference' => '8e7d04f1f6450fef59366c399cfad4b9383aa30d',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../guzzlehttp/promises',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'guzzlehttp/psr7' => array(
|
||||||
|
'pretty_version' => '1.8.1',
|
||||||
|
'version' => '1.8.1.0',
|
||||||
|
'reference' => '35ea11d335fd638b5882ff1725228b3d35496ab1',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../guzzlehttp/psr7',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'itbz/fpdf' => array(
|
||||||
|
'dev_requirement' => false,
|
||||||
|
'replaced' => array(
|
||||||
|
0 => '*',
|
||||||
|
),
|
||||||
|
),
|
||||||
|
'laminas/laminas-loader' => array(
|
||||||
|
'pretty_version' => '2.6.1',
|
||||||
|
'version' => '2.6.1.0',
|
||||||
|
'reference' => '5d01c2c237ae9e68bec262f339947e2ea18979bc',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../laminas/laminas-loader',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'laminas/laminas-mail' => array(
|
||||||
|
'pretty_version' => '2.12.5',
|
||||||
|
'version' => '2.12.5.0',
|
||||||
|
'reference' => 'ed5b36a0deef4ffafe6138c2ae9cafcffafab856',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../laminas/laminas-mail',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'laminas/laminas-mime' => array(
|
||||||
|
'pretty_version' => '2.7.4',
|
||||||
|
'version' => '2.7.4.0',
|
||||||
|
'reference' => 'e45a7d856bf7b4a7b5bd00d6371f9961dc233add',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../laminas/laminas-mime',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'laminas/laminas-stdlib' => array(
|
||||||
|
'pretty_version' => '3.2.1',
|
||||||
|
'version' => '3.2.1.0',
|
||||||
|
'reference' => '2b18347625a2f06a1a485acfbc870f699dbe51c6',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../laminas/laminas-stdlib',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'laminas/laminas-validator' => array(
|
||||||
|
'pretty_version' => '2.13.5',
|
||||||
|
'version' => '2.13.5.0',
|
||||||
|
'reference' => 'd334dddda43af263d6a7e5024fd2b013cb6981f7',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../laminas/laminas-validator',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'laminas/laminas-zendframework-bridge' => array(
|
||||||
|
'dev_requirement' => false,
|
||||||
|
'replaced' => array(
|
||||||
|
0 => '*',
|
||||||
|
),
|
||||||
|
),
|
||||||
|
'league/color-extractor' => array(
|
||||||
|
'pretty_version' => '0.3.2',
|
||||||
|
'version' => '0.3.2.0',
|
||||||
|
'reference' => '837086ec60f50c84c611c613963e4ad2e2aec806',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../league/color-extractor',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'league/flysystem' => array(
|
||||||
|
'pretty_version' => '1.0.70',
|
||||||
|
'version' => '1.0.70.0',
|
||||||
|
'reference' => '585824702f534f8d3cf7fab7225e8466cc4b7493',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../league/flysystem',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'league/oauth1-client' => array(
|
||||||
|
'pretty_version' => 'v1.9.0',
|
||||||
|
'version' => '1.9.0.0',
|
||||||
|
'reference' => '1e7e6be2dc543bf466236fb171e5b20e1b06aee6',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../league/oauth1-client',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'league/oauth2-client' => array(
|
||||||
|
'pretty_version' => '2.6.0',
|
||||||
|
'version' => '2.6.0.0',
|
||||||
|
'reference' => 'badb01e62383430706433191b82506b6df24ad98',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../league/oauth2-client',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'lfkeitel/phptotp' => array(
|
||||||
|
'pretty_version' => 'v1.0.0',
|
||||||
|
'version' => '1.0.0.0',
|
||||||
|
'reference' => '2211fb6e025d3c10362771c54c9a9ad5593a3469',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../lfkeitel/phptotp',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'matthecat/colorextractor' => array(
|
||||||
|
'dev_requirement' => false,
|
||||||
|
'replaced' => array(
|
||||||
|
0 => '*',
|
||||||
|
),
|
||||||
|
),
|
||||||
|
'mtdowling/jmespath.php' => array(
|
||||||
|
'pretty_version' => '2.6.0',
|
||||||
|
'version' => '2.6.0.0',
|
||||||
|
'reference' => '42dae2cbd13154083ca6d70099692fef8ca84bfb',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../mtdowling/jmespath.php',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'nikic/fast-route' => array(
|
||||||
|
'pretty_version' => 'v1.3.0',
|
||||||
|
'version' => '1.3.0.0',
|
||||||
|
'reference' => '181d480e08d9476e61381e04a71b34dc0432e812',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../nikic/fast-route',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'paragonie/random_compat' => array(
|
||||||
|
'pretty_version' => 'v9.99.100',
|
||||||
|
'version' => '9.99.100.0',
|
||||||
|
'reference' => '996434e5492cb4c3edcb9168db6fbb1359ef965a',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../paragonie/random_compat',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'phpmailer/phpmailer' => array(
|
||||||
|
'pretty_version' => 'v6.3.0',
|
||||||
|
'version' => '6.3.0.0',
|
||||||
|
'reference' => '4a08cf4cdd2c38d12ee2b9fa69e5d235f37a6dcb',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../phpmailer/phpmailer',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'phpseclib/phpseclib' => array(
|
||||||
|
'pretty_version' => '2.0.30',
|
||||||
|
'version' => '2.0.30.0',
|
||||||
|
'reference' => '136b9ca7eebef78be14abf90d65c5e57b6bc5d36',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../phpseclib/phpseclib',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'psr/container' => array(
|
||||||
|
'pretty_version' => '1.1.1',
|
||||||
|
'version' => '1.1.1.0',
|
||||||
|
'reference' => '8622567409010282b7aeebe4bb841fe98b58dcaf',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../psr/container',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'psr/http-message' => array(
|
||||||
|
'pretty_version' => '1.0.1',
|
||||||
|
'version' => '1.0.1.0',
|
||||||
|
'reference' => 'f6561bf28d520154e4b0ec72be95418abe6d9363',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../psr/http-message',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'psr/http-message-implementation' => array(
|
||||||
|
'dev_requirement' => false,
|
||||||
|
'provided' => array(
|
||||||
|
0 => '1.0',
|
||||||
|
),
|
||||||
|
),
|
||||||
|
'psr/log' => array(
|
||||||
|
'pretty_version' => '1.1.3',
|
||||||
|
'version' => '1.1.3.0',
|
||||||
|
'reference' => '0f73288fd15629204f9d42b7055f72dacbe811fc',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../psr/log',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'rakit/validation' => array(
|
||||||
|
'pretty_version' => 'v0.22.3',
|
||||||
|
'version' => '0.22.3.0',
|
||||||
|
'reference' => '61ed77b772c214faa67aaf1c4adf81502b06cd4b',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../rakit/validation',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'ralouphie/getallheaders' => array(
|
||||||
|
'pretty_version' => '3.0.3',
|
||||||
|
'version' => '3.0.3.0',
|
||||||
|
'reference' => '120b605dfeb996808c31b6477290a714d356e822',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../ralouphie/getallheaders',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'sabre/dav' => array(
|
||||||
|
'pretty_version' => '3.2.3',
|
||||||
|
'version' => '3.2.3.0',
|
||||||
|
'reference' => 'a9780ce4f35560ecbd0af524ad32d9d2c8954b80',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../sabre/dav',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'sabre/event' => array(
|
||||||
|
'pretty_version' => '3.0.0',
|
||||||
|
'version' => '3.0.0.0',
|
||||||
|
'reference' => '831d586f5a442dceacdcf5e9c4c36a4db99a3534',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../sabre/event',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'sabre/http' => array(
|
||||||
|
'pretty_version' => 'v4.2.4',
|
||||||
|
'version' => '4.2.4.0',
|
||||||
|
'reference' => 'acccec4ba863959b2d10c1fa0fb902736c5c8956',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../sabre/http',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'sabre/uri' => array(
|
||||||
|
'pretty_version' => '1.2.1',
|
||||||
|
'version' => '1.2.1.0',
|
||||||
|
'reference' => 'ada354d83579565949d80b2e15593c2371225e61',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../sabre/uri',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'sabre/vobject' => array(
|
||||||
|
'pretty_version' => '4.2.2',
|
||||||
|
'version' => '4.2.2.0',
|
||||||
|
'reference' => '449616b2d45b95c8973975de23f34a3d14f63b4b',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../sabre/vobject',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'sabre/xml' => array(
|
||||||
|
'pretty_version' => '1.5.1',
|
||||||
|
'version' => '1.5.1.0',
|
||||||
|
'reference' => 'a367665f1df614c3b8fefc30a54de7cd295e444e',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../sabre/xml',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'smarty/smarty' => array(
|
||||||
|
'pretty_version' => 'v3.1.39',
|
||||||
|
'version' => '3.1.39.0',
|
||||||
|
'reference' => 'e27da524f7bcd7361e3ea5cdfa99c4378a7b5419',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../smarty/smarty',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'swiss-payment-slip/swiss-payment-slip' => array(
|
||||||
|
'pretty_version' => '0.13.0',
|
||||||
|
'version' => '0.13.0.0',
|
||||||
|
'reference' => '3f5e23552e59ff486318c3af66b0374fa61a176f',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../swiss-payment-slip/swiss-payment-slip',
|
||||||
|
'aliases' => array(
|
||||||
|
0 => '0.11.1',
|
||||||
|
),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'swiss-payment-slip/swiss-payment-slip-fpdf' => array(
|
||||||
|
'pretty_version' => '0.6.0',
|
||||||
|
'version' => '0.6.0.0',
|
||||||
|
'reference' => '72f722188d89b2651d4751ab812146cb1f165061',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../swiss-payment-slip/swiss-payment-slip-fpdf',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'swiss-payment-slip/swiss-payment-slip-pdf' => array(
|
||||||
|
'pretty_version' => '0.13.1',
|
||||||
|
'version' => '0.13.1.0',
|
||||||
|
'reference' => '4355743b2406875e9fed2117d8df445ba6848be4',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../swiss-payment-slip/swiss-payment-slip-pdf',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'symfony/polyfill-intl-idn' => array(
|
||||||
|
'pretty_version' => 'v1.22.1',
|
||||||
|
'version' => '1.22.1.0',
|
||||||
|
'reference' => '2d63434d922daf7da8dd863e7907e67ee3031483',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../symfony/polyfill-intl-idn',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'symfony/polyfill-intl-normalizer' => array(
|
||||||
|
'pretty_version' => 'v1.22.1',
|
||||||
|
'version' => '1.22.1.0',
|
||||||
|
'reference' => '43a0283138253ed1d48d352ab6d0bdb3f809f248',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../symfony/polyfill-intl-normalizer',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'symfony/polyfill-mbstring' => array(
|
||||||
|
'pretty_version' => 'v1.22.1',
|
||||||
|
'version' => '1.22.1.0',
|
||||||
|
'reference' => '5232de97ee3b75b0360528dae24e73db49566ab1',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../symfony/polyfill-mbstring',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'symfony/polyfill-php72' => array(
|
||||||
|
'pretty_version' => 'v1.22.1',
|
||||||
|
'version' => '1.22.1.0',
|
||||||
|
'reference' => 'cc6e6f9b39fe8075b3dabfbaf5b5f645ae1340c9',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../symfony/polyfill-php72',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'tecnickcom/tcpdf' => array(
|
||||||
|
'pretty_version' => '6.3.5',
|
||||||
|
'version' => '6.3.5.0',
|
||||||
|
'reference' => '19a535eaa7fb1c1cac499109deeb1a7a201b4549',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../tecnickcom/tcpdf',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'true/punycode' => array(
|
||||||
|
'pretty_version' => 'v2.1.1',
|
||||||
|
'version' => '2.1.1.0',
|
||||||
|
'reference' => 'a4d0c11a36dd7f4e7cd7096076cab6d3378a071e',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../true/punycode',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'y0lk/oauth1-etsy' => array(
|
||||||
|
'pretty_version' => '1.1.0',
|
||||||
|
'version' => '1.1.0.0',
|
||||||
|
'reference' => '3fef9d03787e01a72ef19cdcbbc243c166a5d425',
|
||||||
|
'type' => 'library',
|
||||||
|
'install_path' => __DIR__ . '/../y0lk/oauth1-etsy',
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => false,
|
||||||
|
),
|
||||||
|
'zendframework/zend-loader' => array(
|
||||||
|
'dev_requirement' => false,
|
||||||
|
'replaced' => array(
|
||||||
|
0 => '2.6.1',
|
||||||
|
),
|
||||||
|
),
|
||||||
|
'zendframework/zend-mail' => array(
|
||||||
|
'dev_requirement' => false,
|
||||||
|
'replaced' => array(
|
||||||
|
0 => '^2.10.0',
|
||||||
|
),
|
||||||
|
),
|
||||||
|
'zendframework/zend-mime' => array(
|
||||||
|
'dev_requirement' => false,
|
||||||
|
'replaced' => array(
|
||||||
|
0 => '^2.7.2',
|
||||||
|
),
|
||||||
|
),
|
||||||
|
'zendframework/zend-stdlib' => array(
|
||||||
|
'dev_requirement' => false,
|
||||||
|
'replaced' => array(
|
||||||
|
0 => '3.2.1',
|
||||||
|
),
|
||||||
|
),
|
||||||
|
'zendframework/zend-validator' => array(
|
||||||
|
'dev_requirement' => false,
|
||||||
|
'replaced' => array(
|
||||||
|
0 => '^2.13.0',
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
26
vendor/composer/platform_check.php
vendored
Normal file
26
vendor/composer/platform_check.php
vendored
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
// platform_check.php @generated by Composer
|
||||||
|
|
||||||
|
$issues = array();
|
||||||
|
|
||||||
|
if (!(PHP_VERSION_ID >= 70400)) {
|
||||||
|
$issues[] = 'Your Composer dependencies require a PHP version ">= 7.4.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
|
||||||
|
);
|
||||||
|
}
|
58
vendor/laminas/laminas-loader/composer.json
vendored
Normal file
58
vendor/laminas/laminas-loader/composer.json
vendored
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
{
|
||||||
|
"name": "laminas/laminas-loader",
|
||||||
|
"description": "Autoloading and plugin loading strategies",
|
||||||
|
"license": "BSD-3-Clause",
|
||||||
|
"keywords": [
|
||||||
|
"laminas",
|
||||||
|
"loader"
|
||||||
|
],
|
||||||
|
"homepage": "https://laminas.dev",
|
||||||
|
"support": {
|
||||||
|
"docs": "https://docs.laminas.dev/laminas-loader/",
|
||||||
|
"issues": "https://github.com/laminas/laminas-loader/issues",
|
||||||
|
"source": "https://github.com/laminas/laminas-loader",
|
||||||
|
"rss": "https://github.com/laminas/laminas-loader/releases.atom",
|
||||||
|
"chat": "https://laminas.dev/chat",
|
||||||
|
"forum": "https://discourse.laminas.dev"
|
||||||
|
},
|
||||||
|
"config": {
|
||||||
|
"sort-packages": true
|
||||||
|
},
|
||||||
|
"extra": {
|
||||||
|
"branch-alias": {
|
||||||
|
"dev-master": "2.6.x-dev",
|
||||||
|
"dev-develop": "2.7.x-dev"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"php": "^5.6 || ^7.0",
|
||||||
|
"laminas/laminas-zendframework-bridge": "^1.0"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"laminas/laminas-coding-standard": "~1.0.0",
|
||||||
|
"phpunit/phpunit": "^5.7.27 || ^6.5.8 || ^7.1.4"
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"Laminas\\Loader\\": "src/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"autoload-dev": {
|
||||||
|
"psr-4": {
|
||||||
|
"LaminasTest\\Loader\\": "test/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"check": [
|
||||||
|
"@cs-check",
|
||||||
|
"@test"
|
||||||
|
],
|
||||||
|
"cs-check": "phpcs",
|
||||||
|
"cs-fix": "phpcbf",
|
||||||
|
"test": "phpunit --colors=always",
|
||||||
|
"test-coverage": "phpunit --colors=always --coverage-clover clover.xml"
|
||||||
|
},
|
||||||
|
"replace": {
|
||||||
|
"zendframework/zend-loader": "self.version"
|
||||||
|
}
|
||||||
|
}
|
63
vendor/laminas/laminas-mime/composer.json
vendored
Normal file
63
vendor/laminas/laminas-mime/composer.json
vendored
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
{
|
||||||
|
"name": "laminas/laminas-mime",
|
||||||
|
"description": "Create and parse MIME messages and parts",
|
||||||
|
"license": "BSD-3-Clause",
|
||||||
|
"keywords": [
|
||||||
|
"laminas",
|
||||||
|
"mime"
|
||||||
|
],
|
||||||
|
"homepage": "https://laminas.dev",
|
||||||
|
"support": {
|
||||||
|
"docs": "https://docs.laminas.dev/laminas-mime/",
|
||||||
|
"issues": "https://github.com/laminas/laminas-mime/issues",
|
||||||
|
"source": "https://github.com/laminas/laminas-mime",
|
||||||
|
"rss": "https://github.com/laminas/laminas-mime/releases.atom",
|
||||||
|
"chat": "https://laminas.dev/chat",
|
||||||
|
"forum": "https://discourse.laminas.dev"
|
||||||
|
},
|
||||||
|
"config": {
|
||||||
|
"sort-packages": true
|
||||||
|
},
|
||||||
|
"extra": {
|
||||||
|
"branch-alias": {
|
||||||
|
"dev-master": "2.7.x-dev",
|
||||||
|
"dev-develop": "2.8.x-dev"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"php": "^5.6 || ^7.0",
|
||||||
|
"laminas/laminas-stdlib": "^2.7 || ^3.0",
|
||||||
|
"laminas/laminas-zendframework-bridge": "^1.0"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"laminas/laminas-coding-standard": "~1.0.0",
|
||||||
|
"laminas/laminas-mail": "^2.6",
|
||||||
|
"phpunit/phpunit": "^5.7.27 || ^6.5.14 || ^7.5.20"
|
||||||
|
},
|
||||||
|
"suggest": {
|
||||||
|
"laminas/laminas-mail": "Laminas\\Mail component"
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"Laminas\\Mime\\": "src/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"autoload-dev": {
|
||||||
|
"psr-4": {
|
||||||
|
"LaminasTest\\Mime\\": "test/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"check": [
|
||||||
|
"@cs-check",
|
||||||
|
"@test"
|
||||||
|
],
|
||||||
|
"cs-check": "phpcs",
|
||||||
|
"cs-fix": "phpcbf",
|
||||||
|
"test": "phpunit --colors=always",
|
||||||
|
"test-coverage": "phpunit --colors=always --coverage-clover clover.xml"
|
||||||
|
},
|
||||||
|
"replace": {
|
||||||
|
"zendframework/zend-mime": "^2.7.2"
|
||||||
|
}
|
||||||
|
}
|
60
vendor/laminas/laminas-stdlib/composer.json
vendored
Normal file
60
vendor/laminas/laminas-stdlib/composer.json
vendored
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
{
|
||||||
|
"name": "laminas/laminas-stdlib",
|
||||||
|
"description": "SPL extensions, array utilities, error handlers, and more",
|
||||||
|
"license": "BSD-3-Clause",
|
||||||
|
"keywords": [
|
||||||
|
"laminas",
|
||||||
|
"stdlib"
|
||||||
|
],
|
||||||
|
"homepage": "https://laminas.dev",
|
||||||
|
"support": {
|
||||||
|
"docs": "https://docs.laminas.dev/laminas-stdlib/",
|
||||||
|
"issues": "https://github.com/laminas/laminas-stdlib/issues",
|
||||||
|
"source": "https://github.com/laminas/laminas-stdlib",
|
||||||
|
"rss": "https://github.com/laminas/laminas-stdlib/releases.atom",
|
||||||
|
"chat": "https://laminas.dev/chat",
|
||||||
|
"forum": "https://discourse.laminas.dev"
|
||||||
|
},
|
||||||
|
"config": {
|
||||||
|
"sort-packages": true
|
||||||
|
},
|
||||||
|
"extra": {
|
||||||
|
"branch-alias": {
|
||||||
|
"dev-master": "3.2.x-dev",
|
||||||
|
"dev-develop": "3.3.x-dev"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"php": "^5.6 || ^7.0",
|
||||||
|
"laminas/laminas-zendframework-bridge": "^1.0"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"laminas/laminas-coding-standard": "~1.0.0",
|
||||||
|
"phpbench/phpbench": "^0.13",
|
||||||
|
"phpunit/phpunit": "^5.7.27 || ^6.5.8 || ^7.1.2"
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"Laminas\\Stdlib\\": "src/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"autoload-dev": {
|
||||||
|
"psr-4": {
|
||||||
|
"LaminasTest\\Stdlib\\": "test/",
|
||||||
|
"LaminasBench\\Stdlib\\": "benchmark/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"check": [
|
||||||
|
"@cs-check",
|
||||||
|
"@test"
|
||||||
|
],
|
||||||
|
"cs-check": "phpcs",
|
||||||
|
"cs-fix": "phpcbf",
|
||||||
|
"test": "phpunit --colors=always",
|
||||||
|
"test-coverage": "phpunit --colors=always --coverage-clover clover.xml"
|
||||||
|
},
|
||||||
|
"replace": {
|
||||||
|
"zendframework/zend-stdlib": "self.version"
|
||||||
|
}
|
||||||
|
}
|
84
vendor/laminas/laminas-validator/composer.json
vendored
Normal file
84
vendor/laminas/laminas-validator/composer.json
vendored
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
{
|
||||||
|
"name": "laminas/laminas-validator",
|
||||||
|
"description": "Validation classes for a wide range of domains, and the ability to chain validators to create complex validation criteria",
|
||||||
|
"license": "BSD-3-Clause",
|
||||||
|
"keywords": [
|
||||||
|
"laminas",
|
||||||
|
"validator"
|
||||||
|
],
|
||||||
|
"homepage": "https://laminas.dev",
|
||||||
|
"support": {
|
||||||
|
"docs": "https://docs.laminas.dev/laminas-validator/",
|
||||||
|
"issues": "https://github.com/laminas/laminas-validator/issues",
|
||||||
|
"source": "https://github.com/laminas/laminas-validator",
|
||||||
|
"rss": "https://github.com/laminas/laminas-validator/releases.atom",
|
||||||
|
"chat": "https://laminas.dev/chat",
|
||||||
|
"forum": "https://discourse.laminas.dev"
|
||||||
|
},
|
||||||
|
"config": {
|
||||||
|
"sort-packages": true
|
||||||
|
},
|
||||||
|
"extra": {
|
||||||
|
"laminas": {
|
||||||
|
"component": "Laminas\\Validator",
|
||||||
|
"config-provider": "Laminas\\Validator\\ConfigProvider"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"php": "^7.1",
|
||||||
|
"container-interop/container-interop": "^1.1",
|
||||||
|
"laminas/laminas-stdlib": "^3.2.1",
|
||||||
|
"laminas/laminas-zendframework-bridge": "^1.0"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"laminas/laminas-cache": "^2.6.1",
|
||||||
|
"laminas/laminas-coding-standard": "~1.0.0",
|
||||||
|
"laminas/laminas-config": "^2.6",
|
||||||
|
"laminas/laminas-db": "^2.7",
|
||||||
|
"laminas/laminas-filter": "^2.6",
|
||||||
|
"laminas/laminas-http": "^2.5.4",
|
||||||
|
"laminas/laminas-i18n": "^2.6",
|
||||||
|
"laminas/laminas-math": "^2.6",
|
||||||
|
"laminas/laminas-servicemanager": "^2.7.5 || ^3.0.3",
|
||||||
|
"laminas/laminas-session": "^2.8",
|
||||||
|
"laminas/laminas-uri": "^2.5",
|
||||||
|
"phpunit/phpunit": "^7.5.20 || ^8.5.2",
|
||||||
|
"psr/http-client": "^1.0",
|
||||||
|
"psr/http-factory": "^1.0",
|
||||||
|
"psr/http-message": "^1.0"
|
||||||
|
},
|
||||||
|
"suggest": {
|
||||||
|
"laminas/laminas-db": "Laminas\\Db component, required by the (No)RecordExists validator",
|
||||||
|
"laminas/laminas-filter": "Laminas\\Filter component, required by the Digits validator",
|
||||||
|
"laminas/laminas-i18n": "Laminas\\I18n component to allow translation of validation error messages",
|
||||||
|
"laminas/laminas-i18n-resources": "Translations of validator messages",
|
||||||
|
"laminas/laminas-math": "Laminas\\Math component, required by the Csrf validator",
|
||||||
|
"laminas/laminas-servicemanager": "Laminas\\ServiceManager component to allow using the ValidatorPluginManager and validator chains",
|
||||||
|
"laminas/laminas-session": "Laminas\\Session component, ^2.8; required by the Csrf validator",
|
||||||
|
"laminas/laminas-uri": "Laminas\\Uri component, required by the Uri and Sitemap\\Loc validators",
|
||||||
|
"psr/http-message": "psr/http-message, required when validating PSR-7 UploadedFileInterface instances via the Upload and UploadFile validators"
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"Laminas\\Validator\\": "src/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"autoload-dev": {
|
||||||
|
"psr-4": {
|
||||||
|
"LaminasTest\\Validator\\": "test/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"check": [
|
||||||
|
"@cs-check",
|
||||||
|
"@test"
|
||||||
|
],
|
||||||
|
"cs-check": "phpcs",
|
||||||
|
"cs-fix": "phpcbf",
|
||||||
|
"test": "phpunit --colors=always",
|
||||||
|
"test-coverage": "phpunit --colors=always --coverage-clover clover.xml"
|
||||||
|
},
|
||||||
|
"replace": {
|
||||||
|
"zendframework/zend-validator": "^2.13.0"
|
||||||
|
}
|
||||||
|
}
|
0
vendor/laminas/laminas-validator/src/Db/AbstractDb.php
vendored
Normal file → Executable file
0
vendor/laminas/laminas-validator/src/Db/AbstractDb.php
vendored
Normal file → Executable file
0
vendor/laminas/laminas-validator/src/Isbn/Isbn10.php
vendored
Normal file → Executable file
0
vendor/laminas/laminas-validator/src/Isbn/Isbn10.php
vendored
Normal file → Executable file
0
vendor/laminas/laminas-validator/src/Isbn/Isbn13.php
vendored
Normal file → Executable file
0
vendor/laminas/laminas-validator/src/Isbn/Isbn13.php
vendored
Normal file → Executable file
7
vendor/league/oauth1-client/.gitignore
vendored
Normal file
7
vendor/league/oauth1-client/.gitignore
vendored
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
/build
|
||||||
|
/vendor
|
||||||
|
/composer.lock
|
||||||
|
/coverage.xml
|
||||||
|
/.phpunit.result.cache
|
||||||
|
/.php_cs.cache
|
||||||
|
.DS_Store
|
29
vendor/league/oauth1-client/.php_cs.dist
vendored
Normal file
29
vendor/league/oauth1-client/.php_cs.dist
vendored
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
$finder = PhpCsFixer\Finder::create()->in([__DIR__ . '/src', __DIR__ . '/tests']);
|
||||||
|
|
||||||
|
return PhpCsFixer\Config::create()
|
||||||
|
->setRules([
|
||||||
|
'@PSR2' => true,
|
||||||
|
'array_syntax' => ['syntax' => 'short'],
|
||||||
|
'binary_operator_spaces' => true,
|
||||||
|
'blank_line_before_return' => true,
|
||||||
|
'cast_spaces' => true,
|
||||||
|
'concat_space' => ['spacing' => 'one'],
|
||||||
|
'no_singleline_whitespace_before_semicolons' => true,
|
||||||
|
'not_operator_with_space' => true,
|
||||||
|
'ordered_imports' => true,
|
||||||
|
'phpdoc_align' => true,
|
||||||
|
'phpdoc_indent' => true,
|
||||||
|
'phpdoc_no_access' => true,
|
||||||
|
'phpdoc_no_alias_tag' => true,
|
||||||
|
'phpdoc_no_package' => true,
|
||||||
|
'phpdoc_scalar' => true,
|
||||||
|
'phpdoc_separation' => true,
|
||||||
|
'phpdoc_summary' => true,
|
||||||
|
'phpdoc_to_comment' => true,
|
||||||
|
'phpdoc_trim' => true,
|
||||||
|
'single_blank_line_at_eof' => true,
|
||||||
|
'ternary_operator_spaces' => true,
|
||||||
|
])
|
||||||
|
->setFinder($finder);
|
35
vendor/league/oauth1-client/.scrutinizer.yml
vendored
Normal file
35
vendor/league/oauth1-client/.scrutinizer.yml
vendored
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
filter:
|
||||||
|
excluded_paths: [tests/*]
|
||||||
|
checks:
|
||||||
|
php:
|
||||||
|
code_rating: true
|
||||||
|
remove_extra_empty_lines: true
|
||||||
|
remove_php_closing_tag: true
|
||||||
|
remove_trailing_whitespace: true
|
||||||
|
fix_use_statements:
|
||||||
|
remove_unused: true
|
||||||
|
preserve_multiple: false
|
||||||
|
preserve_blanklines: true
|
||||||
|
order_alphabetically: true
|
||||||
|
fix_php_opening_tag: true
|
||||||
|
fix_linefeed: true
|
||||||
|
fix_line_ending: true
|
||||||
|
fix_identation_4spaces: true
|
||||||
|
fix_doc_comments: true
|
||||||
|
tools:
|
||||||
|
external_code_coverage:
|
||||||
|
timeout: 600
|
||||||
|
runs: 4
|
||||||
|
php_analyzer: true
|
||||||
|
php_code_coverage: false
|
||||||
|
php_code_sniffer:
|
||||||
|
config:
|
||||||
|
standard: PSR2
|
||||||
|
filter:
|
||||||
|
paths: ['src']
|
||||||
|
php_loc:
|
||||||
|
enabled: true
|
||||||
|
excluded_dirs: [vendor, tests]
|
||||||
|
php_cpd:
|
||||||
|
enabled: true
|
||||||
|
excluded_dirs: [vendor, tests]
|
57
vendor/league/oauth1-client/.travis.yml
vendored
Normal file
57
vendor/league/oauth1-client/.travis.yml
vendored
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
language: php
|
||||||
|
|
||||||
|
matrix:
|
||||||
|
include:
|
||||||
|
- php: 7.1
|
||||||
|
dist: bionic
|
||||||
|
env: COMPOSER_OPTS=""
|
||||||
|
- php: 7.1
|
||||||
|
dist: bionic
|
||||||
|
env: COMPOSER_OPTS="--prefer-lowest"
|
||||||
|
- php: 7.2
|
||||||
|
dist: bionic
|
||||||
|
env: COMPOSER_OPTS=""
|
||||||
|
- php: 7.2
|
||||||
|
dist: bionic
|
||||||
|
env: COMPOSER_OPTS="--prefer-lowest"
|
||||||
|
- php: 7.3
|
||||||
|
dist: bionic
|
||||||
|
env: COMPOSER_OPTS=""
|
||||||
|
- php: 7.3
|
||||||
|
dist: bionic
|
||||||
|
env: COMPOSER_OPTS="--prefer-lowest"
|
||||||
|
- php: 7.4
|
||||||
|
dist: bionic
|
||||||
|
env: COMPOSER_OPTS=""
|
||||||
|
- php: 7.4
|
||||||
|
dist: bionic
|
||||||
|
env: COMPOSER_OPTS="--prefer-lowest"
|
||||||
|
- php: 8.0
|
||||||
|
dist: bionic
|
||||||
|
env: COMPOSER_OPTS=""
|
||||||
|
- php: 8.0
|
||||||
|
dist: bionic
|
||||||
|
env: COMPOSER_OPTS="--prefer-lowest"
|
||||||
|
- php: nightly
|
||||||
|
dist: bionic
|
||||||
|
env: COMPOSER_OPTS="--ignore-platform-reqs"
|
||||||
|
- php: nightly
|
||||||
|
dist: bionic
|
||||||
|
env: COMPOSER_OPTS="--ignore-platform-reqs --prefer-lowest"
|
||||||
|
allow_failures:
|
||||||
|
- php: nightly
|
||||||
|
env: COMPOSER_OPTS="--ignore-platform-reqs"
|
||||||
|
- php: nightly
|
||||||
|
env: COMPOSER_OPTS="--ignore-platform-reqs --prefer-lowest"
|
||||||
|
|
||||||
|
install:
|
||||||
|
- travis_retry composer update --prefer-dist $COMPOSER_OPTS
|
||||||
|
|
||||||
|
script:
|
||||||
|
- composer php-cs-fixer:lint
|
||||||
|
- composer test:unit
|
||||||
|
- composer analyze
|
||||||
|
|
||||||
|
after_script:
|
||||||
|
- wget https://scrutinizer-ci.com/ocular.phar
|
||||||
|
- php ocular.phar code-coverage:upload --format=php-clover coverage.xml
|
65
vendor/league/oauth1-client/composer.json
vendored
Normal file
65
vendor/league/oauth1-client/composer.json
vendored
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
{
|
||||||
|
"name": "league/oauth1-client",
|
||||||
|
"description": "OAuth 1.0 Client Library",
|
||||||
|
"license": "MIT",
|
||||||
|
"require": {
|
||||||
|
"php": ">=7.1||>=8.0",
|
||||||
|
"ext-json": "*",
|
||||||
|
"ext-openssl": "*",
|
||||||
|
"guzzlehttp/guzzle": "^6.0|^7.0"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"ext-simplexml": "*",
|
||||||
|
"phpunit/phpunit": "^7.5||9.5",
|
||||||
|
"mockery/mockery": "^1.3.3",
|
||||||
|
"phpstan/phpstan": "^0.12.42",
|
||||||
|
"friendsofphp/php-cs-fixer": "^2.17"
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"analyze": "vendor/bin/phpstan analyse -l 6 src/",
|
||||||
|
"php-cs-fixer:lint": "PHP_CS_FIXER_IGNORE_ENV=1 vendor/bin/php-cs-fixer fix --verbose --dry-run",
|
||||||
|
"php-cs-fixer:format": "PHP_CS_FIXER_IGNORE_ENV=1 vendor/bin/php-cs-fixer fix",
|
||||||
|
"test:unit": "vendor/bin/phpunit --coverage-text --coverage-clover coverage.xml"
|
||||||
|
},
|
||||||
|
"suggest": {
|
||||||
|
"ext-simplexml": "For decoding XML-based responses."
|
||||||
|
},
|
||||||
|
"keywords": [
|
||||||
|
"oauth",
|
||||||
|
"oauth1",
|
||||||
|
"authorization",
|
||||||
|
"authentication",
|
||||||
|
"idp",
|
||||||
|
"identity",
|
||||||
|
"sso",
|
||||||
|
"single sign on",
|
||||||
|
"bitbucket",
|
||||||
|
"trello",
|
||||||
|
"tumblr",
|
||||||
|
"twitter"
|
||||||
|
],
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Ben Corlett",
|
||||||
|
"email": "bencorlett@me.com",
|
||||||
|
"homepage": "http://www.webcomm.com.au",
|
||||||
|
"role": "Developer"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"League\\OAuth1\\Client\\": "src/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"autoload-dev": {
|
||||||
|
"psr-4": {
|
||||||
|
"League\\OAuth1\\Client\\Tests\\": "tests/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"extra": {
|
||||||
|
"branch-alias": {
|
||||||
|
"dev-master": "1.0-dev",
|
||||||
|
"dev-develop": "2.0-dev"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
28
vendor/league/oauth1-client/tests/ClientCredentialsTest.php
vendored
Normal file
28
vendor/league/oauth1-client/tests/ClientCredentialsTest.php
vendored
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace League\OAuth1\Client\Tests;
|
||||||
|
|
||||||
|
use League\OAuth1\Client\Credentials\ClientCredentials;
|
||||||
|
use Mockery as m;
|
||||||
|
use PHPUnit\Framework\TestCase;
|
||||||
|
|
||||||
|
class ClientCredentialsTest extends TestCase
|
||||||
|
{
|
||||||
|
protected function tearDown(): void
|
||||||
|
{
|
||||||
|
m::close();
|
||||||
|
|
||||||
|
parent::tearDown();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testManipulating()
|
||||||
|
{
|
||||||
|
$credentials = new ClientCredentials;
|
||||||
|
$this->assertNull($credentials->getIdentifier());
|
||||||
|
$credentials->setIdentifier('foo');
|
||||||
|
$this->assertEquals('foo', $credentials->getIdentifier());
|
||||||
|
$this->assertNull($credentials->getSecret());
|
||||||
|
$credentials->setSecret('foo');
|
||||||
|
$this->assertEquals('foo', $credentials->getSecret());
|
||||||
|
}
|
||||||
|
}
|
156
vendor/league/oauth1-client/tests/HmacSha1SignatureTest.php
vendored
Normal file
156
vendor/league/oauth1-client/tests/HmacSha1SignatureTest.php
vendored
Normal file
@ -0,0 +1,156 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace League\OAuth1\Client\Tests;
|
||||||
|
|
||||||
|
use League\OAuth1\Client\Signature\HmacSha1Signature;
|
||||||
|
use Mockery as m;
|
||||||
|
use PHPUnit\Framework\TestCase;
|
||||||
|
|
||||||
|
class HmacSha1SignatureTest extends TestCase
|
||||||
|
{
|
||||||
|
protected function tearDown(): void
|
||||||
|
{
|
||||||
|
m::close();
|
||||||
|
|
||||||
|
parent::tearDown();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSigningRequest()
|
||||||
|
{
|
||||||
|
$signature = new HmacSha1Signature($this->getMockClientCredentials());
|
||||||
|
|
||||||
|
$uri = 'http://www.example.com/?qux=corge';
|
||||||
|
$parameters = ['foo' => 'bar', 'baz' => null];
|
||||||
|
|
||||||
|
$this->assertEquals('A3Y7C1SUHXR1EBYIUlT3d6QT1cQ=', $signature->sign($uri, $parameters));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSigningRequestWhereThePortIsNotStandard()
|
||||||
|
{
|
||||||
|
$signature = new HmacSha1Signature($this->getMockClientCredentials());
|
||||||
|
|
||||||
|
$uri = 'http://www.example.com:8080/?qux=corge';
|
||||||
|
$parameters = ['foo' => 'bar', 'baz' => null];
|
||||||
|
|
||||||
|
$this->assertEquals('ECcWxyi5UOC1G0MxH0ygm6Pd6JE=', $signature->sign($uri, $parameters));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testQueryStringFromArray()
|
||||||
|
{
|
||||||
|
$array = ['a' => 'b'];
|
||||||
|
$res = $this->invokeQueryStringFromData($array);
|
||||||
|
|
||||||
|
$this->assertSame(
|
||||||
|
'a%3Db',
|
||||||
|
$res
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testQueryStringFromIndexedArray()
|
||||||
|
{
|
||||||
|
$array = ['a', 'b'];
|
||||||
|
$res = $this->invokeQueryStringFromData($array);
|
||||||
|
|
||||||
|
$this->assertSame(
|
||||||
|
'0%3Da%261%3Db',
|
||||||
|
$res
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testQueryStringFromMultiDimensionalArray()
|
||||||
|
{
|
||||||
|
$array = [
|
||||||
|
'a' => [
|
||||||
|
'b' => [
|
||||||
|
'c' => 'd',
|
||||||
|
],
|
||||||
|
'e' => [
|
||||||
|
'f' => 'g',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'h' => 'i',
|
||||||
|
'empty' => '',
|
||||||
|
'null' => null,
|
||||||
|
'false' => false,
|
||||||
|
];
|
||||||
|
|
||||||
|
// Convert to query string.
|
||||||
|
$res = $this->invokeQueryStringFromData($array);
|
||||||
|
|
||||||
|
$this->assertSame(
|
||||||
|
'a%5Bb%5D%5Bc%5D%3Dd%26a%5Be%5D%5Bf%5D%3Dg%26h%3Di%26empty%3D%26null%3D%26false%3D',
|
||||||
|
$res
|
||||||
|
);
|
||||||
|
|
||||||
|
// Reverse engineer the string.
|
||||||
|
$res = urldecode($res);
|
||||||
|
|
||||||
|
$this->assertSame(
|
||||||
|
'a[b][c]=d&a[e][f]=g&h=i&empty=&null=&false=',
|
||||||
|
$res
|
||||||
|
);
|
||||||
|
|
||||||
|
// Finally, parse the string back to an array.
|
||||||
|
parse_str($res, $original_array);
|
||||||
|
|
||||||
|
// And ensure it matches the orignal array (approximately).
|
||||||
|
$this->assertSame(
|
||||||
|
[
|
||||||
|
'a' => [
|
||||||
|
'b' => [
|
||||||
|
'c' => 'd',
|
||||||
|
],
|
||||||
|
'e' => [
|
||||||
|
'f' => 'g',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'h' => 'i',
|
||||||
|
'empty' => '',
|
||||||
|
'null' => '', // null value gets lost in string translation
|
||||||
|
'false' => '', // false value gets lost in string translation
|
||||||
|
],
|
||||||
|
$original_array
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSigningRequestWithMultiDimensionalParams()
|
||||||
|
{
|
||||||
|
$signature = new HmacSha1Signature($this->getMockClientCredentials());
|
||||||
|
|
||||||
|
$uri = 'http://www.example.com/';
|
||||||
|
$parameters = [
|
||||||
|
'a' => [
|
||||||
|
'b' => [
|
||||||
|
'c' => 'd',
|
||||||
|
],
|
||||||
|
'e' => [
|
||||||
|
'f' => 'g',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'h' => 'i',
|
||||||
|
'empty' => '',
|
||||||
|
'null' => null,
|
||||||
|
'false' => false,
|
||||||
|
];
|
||||||
|
|
||||||
|
$this->assertEquals('ZUxiJKugeEplaZm9e4hshN0I70U=', $signature->sign($uri, $parameters));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function invokeQueryStringFromData(array $args)
|
||||||
|
{
|
||||||
|
$signature = new HmacSha1Signature(m::mock('League\OAuth1\Client\Credentials\ClientCredentialsInterface'));
|
||||||
|
$refl = new \ReflectionObject($signature);
|
||||||
|
$method = $refl->getMethod('queryStringFromData');
|
||||||
|
$method->setAccessible(true);
|
||||||
|
|
||||||
|
return $method->invokeArgs($signature, [$args]);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getMockClientCredentials()
|
||||||
|
{
|
||||||
|
$clientCredentials = m::mock('League\OAuth1\Client\Credentials\ClientCredentialsInterface');
|
||||||
|
$clientCredentials->shouldReceive('getSecret')->andReturn('clientsecret');
|
||||||
|
|
||||||
|
return $clientCredentials;
|
||||||
|
}
|
||||||
|
}
|
43
vendor/league/oauth1-client/tests/PlainTextSignatureTest.php
vendored
Normal file
43
vendor/league/oauth1-client/tests/PlainTextSignatureTest.php
vendored
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace League\OAuth1\Client\Tests;
|
||||||
|
|
||||||
|
use League\OAuth1\Client\Signature\PlainTextSignature;
|
||||||
|
use Mockery as m;
|
||||||
|
use PHPUnit\Framework\TestCase;
|
||||||
|
|
||||||
|
class PlainTextSignatureTest extends TestCase
|
||||||
|
{
|
||||||
|
protected function tearDown(): void
|
||||||
|
{
|
||||||
|
m::close();
|
||||||
|
|
||||||
|
parent::tearDown();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSigningRequest()
|
||||||
|
{
|
||||||
|
$signature = new PlainTextSignature($this->getMockClientCredentials());
|
||||||
|
$this->assertEquals('clientsecret&', $signature->sign($uri = 'http://www.example.com/'));
|
||||||
|
|
||||||
|
$signature->setCredentials($this->getMockCredentials());
|
||||||
|
$this->assertEquals('clientsecret&tokensecret', $signature->sign($uri));
|
||||||
|
$this->assertEquals('PLAINTEXT', $signature->method());
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getMockClientCredentials()
|
||||||
|
{
|
||||||
|
$clientCredentials = m::mock('League\OAuth1\Client\Credentials\ClientCredentialsInterface');
|
||||||
|
$clientCredentials->shouldReceive('getSecret')->andReturn('clientsecret');
|
||||||
|
|
||||||
|
return $clientCredentials;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getMockCredentials()
|
||||||
|
{
|
||||||
|
$credentials = m::mock('League\OAuth1\Client\Credentials\CredentialsInterface');
|
||||||
|
$credentials->shouldReceive('getSecret')->andReturn('tokensecret');
|
||||||
|
|
||||||
|
return $credentials;
|
||||||
|
}
|
||||||
|
}
|
75
vendor/league/oauth1-client/tests/RsaClientCredentialsTest.php
vendored
Normal file
75
vendor/league/oauth1-client/tests/RsaClientCredentialsTest.php
vendored
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace League\OAuth1\Client\Tests;
|
||||||
|
|
||||||
|
use League\OAuth1\Client\Credentials\CredentialsException;
|
||||||
|
use League\OAuth1\Client\Credentials\RsaClientCredentials;
|
||||||
|
use OpenSSLAsymmetricKey;
|
||||||
|
use PHPUnit\Framework\TestCase;
|
||||||
|
|
||||||
|
class RsaClientCredentialsTest extends TestCase
|
||||||
|
{
|
||||||
|
public function testGetRsaPublicKey()
|
||||||
|
{
|
||||||
|
$credentials = new RsaClientCredentials();
|
||||||
|
$credentials->setRsaPublicKey(__DIR__ . '/test_rsa_publickey.pem');
|
||||||
|
|
||||||
|
/** @var resource|OpenSSLAsymmetricKey $key */
|
||||||
|
$key = $credentials->getRsaPublicKey();
|
||||||
|
$this->assertFalse(is_null($key));
|
||||||
|
|
||||||
|
$this->assertEquals($key, $credentials->getRsaPublicKey());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetRsaPublicKeyNotExists()
|
||||||
|
{
|
||||||
|
$this->expectException(CredentialsException::class);
|
||||||
|
|
||||||
|
$credentials = new RsaClientCredentials();
|
||||||
|
$credentials->setRsaPublicKey('fail');
|
||||||
|
|
||||||
|
$credentials->getRsaPublicKey();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetRsaPublicKeyInvalid()
|
||||||
|
{
|
||||||
|
$this->expectException(CredentialsException::class);
|
||||||
|
|
||||||
|
$credentials = new RsaClientCredentials();
|
||||||
|
$credentials->setRsaPublicKey(__DIR__ . '/test_rsa_invalidkey.pem');
|
||||||
|
|
||||||
|
$credentials->getRsaPublicKey();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetRsaPrivateKey()
|
||||||
|
{
|
||||||
|
$credentials = new RsaClientCredentials();
|
||||||
|
$credentials->setRsaPrivateKey(__DIR__ . '/test_rsa_privatekey.pem');
|
||||||
|
|
||||||
|
/** @var resource|OpenSSLAsymmetricKey $key */
|
||||||
|
$key = $credentials->getRsaPrivateKey();
|
||||||
|
$this->assertFalse(is_null($key));
|
||||||
|
|
||||||
|
$this->assertEquals($key, $credentials->getRsaPrivateKey());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetRsaPrivateKeyNotExists()
|
||||||
|
{
|
||||||
|
$this->expectException(CredentialsException::class);
|
||||||
|
|
||||||
|
$credentials = new RsaClientCredentials();
|
||||||
|
$credentials->setRsaPrivateKey('fail');
|
||||||
|
|
||||||
|
$credentials->getRsaPrivateKey();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetRsaPrivateKeyInvalid()
|
||||||
|
{
|
||||||
|
$this->expectException(CredentialsException::class);
|
||||||
|
|
||||||
|
$credentials = new RsaClientCredentials();
|
||||||
|
$credentials->setRsaPrivateKey(__DIR__ . '/test_rsa_invalidkey.pem');
|
||||||
|
|
||||||
|
$credentials->getRsaPrivateKey();
|
||||||
|
}
|
||||||
|
}
|
148
vendor/league/oauth1-client/tests/RsaSha1SignatureTest.php
vendored
Normal file
148
vendor/league/oauth1-client/tests/RsaSha1SignatureTest.php
vendored
Normal file
@ -0,0 +1,148 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace League\OAuth1\Client\Tests;
|
||||||
|
|
||||||
|
use League\OAuth1\Client\Credentials\ClientCredentialsInterface;
|
||||||
|
use League\OAuth1\Client\Credentials\RsaClientCredentials;
|
||||||
|
use League\OAuth1\Client\Signature\RsaSha1Signature;
|
||||||
|
use Mockery;
|
||||||
|
use PHPUnit\Framework\TestCase;
|
||||||
|
|
||||||
|
class RsaSha1SignatureTest extends TestCase
|
||||||
|
{
|
||||||
|
public function testMethod()
|
||||||
|
{
|
||||||
|
$signature = new RsaSha1Signature($this->getClientCredentials());
|
||||||
|
$this->assertEquals('RSA-SHA1', $signature->method());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSigningRequest()
|
||||||
|
{
|
||||||
|
$signature = new RsaSha1Signature($this->getClientCredentials());
|
||||||
|
|
||||||
|
$uri = 'http://www.example.com/?qux=corge';
|
||||||
|
$parameters = ['foo' => 'bar', 'baz' => null];
|
||||||
|
|
||||||
|
$this->assertEquals('h8vpV4CYnLwss+rWicKE4sY6AiW2+DT6Fe7qB8jA7LSLhX5jvLEeX1D8E2ynSePSksAY48j+OSLu9vo5juS2duwNK8UA2Rtnnvuj6UFxpx70dpjHAsQg6EbycGptL/SChDkxfpG8LhuwX1FlFa+H0jLYXI5Dy8j90g51GRJbj48=', $signature->sign($uri, $parameters));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testQueryStringFromArray()
|
||||||
|
{
|
||||||
|
$array = ['a' => 'b'];
|
||||||
|
$res = $this->invokeQueryStringFromData($array);
|
||||||
|
|
||||||
|
$this->assertSame(
|
||||||
|
'a%3Db',
|
||||||
|
$res
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testQueryStringFromIndexedArray()
|
||||||
|
{
|
||||||
|
$array = ['a', 'b'];
|
||||||
|
$res = $this->invokeQueryStringFromData($array);
|
||||||
|
|
||||||
|
$this->assertSame(
|
||||||
|
'0%3Da%261%3Db',
|
||||||
|
$res
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testQueryStringFromMultiDimensionalArray()
|
||||||
|
{
|
||||||
|
$array = [
|
||||||
|
'a' => [
|
||||||
|
'b' => [
|
||||||
|
'c' => 'd',
|
||||||
|
],
|
||||||
|
'e' => [
|
||||||
|
'f' => 'g',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'h' => 'i',
|
||||||
|
'empty' => '',
|
||||||
|
'null' => null,
|
||||||
|
'false' => false,
|
||||||
|
];
|
||||||
|
|
||||||
|
// Convert to query string.
|
||||||
|
$res = $this->invokeQueryStringFromData($array);
|
||||||
|
|
||||||
|
$this->assertSame(
|
||||||
|
'a%5Bb%5D%5Bc%5D%3Dd%26a%5Be%5D%5Bf%5D%3Dg%26h%3Di%26empty%3D%26null%3D%26false%3D',
|
||||||
|
$res
|
||||||
|
);
|
||||||
|
|
||||||
|
// Reverse engineer the string.
|
||||||
|
$res = urldecode($res);
|
||||||
|
|
||||||
|
$this->assertSame(
|
||||||
|
'a[b][c]=d&a[e][f]=g&h=i&empty=&null=&false=',
|
||||||
|
$res
|
||||||
|
);
|
||||||
|
|
||||||
|
// Finally, parse the string back to an array.
|
||||||
|
parse_str($res, $original_array);
|
||||||
|
|
||||||
|
// And ensure it matches the orignal array (approximately).
|
||||||
|
$this->assertSame(
|
||||||
|
[
|
||||||
|
'a' => [
|
||||||
|
'b' => [
|
||||||
|
'c' => 'd',
|
||||||
|
],
|
||||||
|
'e' => [
|
||||||
|
'f' => 'g',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'h' => 'i',
|
||||||
|
'empty' => '',
|
||||||
|
'null' => '', // null value gets lost in string translation
|
||||||
|
'false' => '', // false value gets lost in string translation
|
||||||
|
],
|
||||||
|
$original_array
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSigningRequestWithMultiDimensionalParams()
|
||||||
|
{
|
||||||
|
$signature = new RsaSha1Signature($this->getClientCredentials());
|
||||||
|
|
||||||
|
$uri = 'http://www.example.com/';
|
||||||
|
$parameters = [
|
||||||
|
'a' => [
|
||||||
|
'b' => [
|
||||||
|
'c' => 'd',
|
||||||
|
],
|
||||||
|
'e' => [
|
||||||
|
'f' => 'g',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'h' => 'i',
|
||||||
|
'empty' => '',
|
||||||
|
'null' => null,
|
||||||
|
'false' => false,
|
||||||
|
];
|
||||||
|
|
||||||
|
$this->assertEquals('X9EkmOEbA5CoF2Hicf3ciAumpp1zkKxnVZkh/mEwWyF2DDcrfou9XF11WvbBu3G4loJGeX4GY1FsIrQpsjEILbn0e7Alyii/x8VA9mBwdqMhQVl49jF0pdowocc03M04cAbAOMNObT7tMmDs+YTFgRxEGCiUkq9AizP1cW3+eBo=', $signature->sign($uri, $parameters));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function invokeQueryStringFromData(array $args)
|
||||||
|
{
|
||||||
|
$signature = new RsaSha1Signature(Mockery::mock(ClientCredentialsInterface::class));
|
||||||
|
$refl = new \ReflectionObject($signature);
|
||||||
|
$method = $refl->getMethod('queryStringFromData');
|
||||||
|
$method->setAccessible(true);
|
||||||
|
|
||||||
|
return $method->invokeArgs($signature, [$args]);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getClientCredentials()
|
||||||
|
{
|
||||||
|
$credentials = new RsaClientCredentials();
|
||||||
|
$credentials->setRsaPublicKey(__DIR__ . '/test_rsa_publickey.pem');
|
||||||
|
$credentials->setRsaPrivateKey(__DIR__ . '/test_rsa_privatekey.pem');
|
||||||
|
|
||||||
|
return $credentials;
|
||||||
|
}
|
||||||
|
}
|
313
vendor/league/oauth1-client/tests/ServerTest.php
vendored
Normal file
313
vendor/league/oauth1-client/tests/ServerTest.php
vendored
Normal file
@ -0,0 +1,313 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace League\OAuth1\Client\Tests;
|
||||||
|
|
||||||
|
use InvalidArgumentException;
|
||||||
|
use League\OAuth1\Client\Credentials\ClientCredentials;
|
||||||
|
use League\OAuth1\Client\Credentials\RsaClientCredentials;
|
||||||
|
use League\OAuth1\Client\Signature\RsaSha1Signature;
|
||||||
|
use Mockery as m;
|
||||||
|
use PHPUnit\Framework\TestCase;
|
||||||
|
use Psr\Http\Message\ResponseInterface;
|
||||||
|
|
||||||
|
class ServerTest extends TestCase
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Setup resources and dependencies.
|
||||||
|
*/
|
||||||
|
public static function setUpBeforeClass(): void
|
||||||
|
{
|
||||||
|
parent::setUpBeforeClass();
|
||||||
|
|
||||||
|
require_once __DIR__ . '/stubs/ServerStub.php';
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function tearDown(): void
|
||||||
|
{
|
||||||
|
m::close();
|
||||||
|
|
||||||
|
parent::tearDown();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCreatingWithArray()
|
||||||
|
{
|
||||||
|
$server = new ServerStub($this->getMockClientCredentials());
|
||||||
|
|
||||||
|
$credentials = $server->getClientCredentials();
|
||||||
|
$this->assertInstanceOf('League\OAuth1\Client\Credentials\ClientCredentialsInterface', $credentials);
|
||||||
|
$this->assertEquals('myidentifier', $credentials->getIdentifier());
|
||||||
|
$this->assertEquals('mysecret', $credentials->getSecret());
|
||||||
|
$this->assertEquals('http://app.dev/', $credentials->getCallbackUri());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCreatingWithArrayRsa()
|
||||||
|
{
|
||||||
|
$config = [
|
||||||
|
'identifier' => 'app_key',
|
||||||
|
'secret' => 'secret',
|
||||||
|
'callback_uri' => 'https://example.com/callback',
|
||||||
|
'rsa_public_key' => __DIR__ . '/test_rsa_publickey.pem',
|
||||||
|
'rsa_private_key' => __DIR__ . '/test_rsa_privatekey.pem',
|
||||||
|
];
|
||||||
|
$server = new ServerStub($config);
|
||||||
|
|
||||||
|
$credentials = $server->getClientCredentials();
|
||||||
|
$this->assertInstanceOf(RsaClientCredentials::class, $credentials);
|
||||||
|
|
||||||
|
$signature = $server->getSignature();
|
||||||
|
$this->assertInstanceOf(RsaSha1Signature::class, $signature);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCreatingWithObject()
|
||||||
|
{
|
||||||
|
$credentials = new ClientCredentials;
|
||||||
|
$credentials->setIdentifier('myidentifier');
|
||||||
|
$credentials->setSecret('mysecret');
|
||||||
|
$credentials->setCallbackUri('http://app.dev/');
|
||||||
|
|
||||||
|
$server = new ServerStub($credentials);
|
||||||
|
|
||||||
|
$this->assertEquals($credentials, $server->getClientCredentials());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCreatingWithInvalidInput()
|
||||||
|
{
|
||||||
|
$this->expectException(InvalidArgumentException::class);
|
||||||
|
|
||||||
|
new ServerStub(uniqid());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingTemporaryCredentials()
|
||||||
|
{
|
||||||
|
$server = m::mock('League\OAuth1\Client\Tests\ServerStub[createHttpClient]', [$this->getMockClientCredentials()]);
|
||||||
|
|
||||||
|
$server->shouldReceive('createHttpClient')->andReturn($client = m::mock('stdClass'));
|
||||||
|
|
||||||
|
$me = $this;
|
||||||
|
$client->shouldReceive('post')->with('http://www.example.com/temporary', m::on(function ($options) use ($me) {
|
||||||
|
$headers = $options['headers'];
|
||||||
|
|
||||||
|
$me->assertTrue(isset($headers['Authorization']));
|
||||||
|
|
||||||
|
// OAuth protocol specifies a strict number of
|
||||||
|
// headers should be sent, in the correct order.
|
||||||
|
// We'll validate that here.
|
||||||
|
$pattern
|
||||||
|
= '/OAuth oauth_consumer_key=".*?", oauth_nonce="[a-zA-Z0-9]+", oauth_signature_method="HMAC-SHA1", oauth_timestamp="\d{10}", oauth_version="1.0", oauth_callback="'
|
||||||
|
. preg_quote('http%3A%2F%2Fapp.dev%2F', '/') . '", oauth_signature=".*?"/';
|
||||||
|
|
||||||
|
$matches = preg_match($pattern, $headers['Authorization']);
|
||||||
|
$me->assertEquals(1, $matches, 'Asserting that the authorization header contains the correct expression.');
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}))->once()->andReturn($response = m::mock('stdClass'));
|
||||||
|
$response->shouldReceive('getBody')
|
||||||
|
->andReturn('oauth_token=temporarycredentialsidentifier&oauth_token_secret=temporarycredentialssecret&oauth_callback_confirmed=true');
|
||||||
|
|
||||||
|
$credentials = $server->getTemporaryCredentials();
|
||||||
|
$this->assertInstanceOf('League\OAuth1\Client\Credentials\TemporaryCredentials', $credentials);
|
||||||
|
$this->assertEquals('temporarycredentialsidentifier', $credentials->getIdentifier());
|
||||||
|
$this->assertEquals('temporarycredentialssecret', $credentials->getSecret());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingAuthorizationUrl()
|
||||||
|
{
|
||||||
|
$server = new ServerStub($this->getMockClientCredentials());
|
||||||
|
|
||||||
|
$expected = 'http://www.example.com/authorize?oauth_token=foo';
|
||||||
|
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl('foo'));
|
||||||
|
|
||||||
|
$credentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
|
||||||
|
$credentials->shouldReceive('getIdentifier')->andReturn('foo');
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl($credentials));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingAuthorizationUrlWithOptions()
|
||||||
|
{
|
||||||
|
$server = new ServerStub($this->getMockClientCredentials());
|
||||||
|
$expected = 'http://www.example.com/authorize?oauth_token=foo';
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl('foo', ['oauth_token' => 'bar']));
|
||||||
|
|
||||||
|
$expected = 'http://www.example.com/authorize?test=bar&oauth_token=foo';
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl('foo', ['test' => 'bar']));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingTokenCredentialsFailsWithManInTheMiddle()
|
||||||
|
{
|
||||||
|
$server = new ServerStub($this->getMockClientCredentials());
|
||||||
|
|
||||||
|
$credentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
|
||||||
|
$credentials->shouldReceive('getIdentifier')->andReturn('foo');
|
||||||
|
|
||||||
|
$this->expectException(InvalidArgumentException::class);
|
||||||
|
|
||||||
|
$server->getTokenCredentials($credentials, 'bar', 'verifier');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingTokenCredentials()
|
||||||
|
{
|
||||||
|
$server = m::mock('League\OAuth1\Client\Tests\ServerStub[createHttpClient]', [$this->getMockClientCredentials()]);
|
||||||
|
|
||||||
|
$temporaryCredentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
|
||||||
|
$temporaryCredentials->shouldReceive('getIdentifier')->andReturn('temporarycredentialsidentifier');
|
||||||
|
$temporaryCredentials->shouldReceive('getSecret')->andReturn('temporarycredentialssecret');
|
||||||
|
|
||||||
|
$server->shouldReceive('createHttpClient')->andReturn($client = m::mock('stdClass'));
|
||||||
|
|
||||||
|
$me = $this;
|
||||||
|
$client->shouldReceive('post')->with('http://www.example.com/token', m::on(function ($options) use ($me) {
|
||||||
|
$headers = $options['headers'];
|
||||||
|
$body = $options['form_params'];
|
||||||
|
|
||||||
|
$me->assertTrue(isset($headers['Authorization']));
|
||||||
|
$me->assertFalse(isset($headers['User-Agent']));
|
||||||
|
|
||||||
|
// OAuth protocol specifies a strict number of
|
||||||
|
// headers should be sent, in the correct order.
|
||||||
|
// We'll validate that here.
|
||||||
|
$pattern
|
||||||
|
= '/OAuth oauth_consumer_key=".*?", oauth_nonce="[a-zA-Z0-9]+", oauth_signature_method="HMAC-SHA1", oauth_timestamp="\d{10}", oauth_version="1.0", oauth_token="temporarycredentialsidentifier", oauth_signature=".*?"/';
|
||||||
|
|
||||||
|
$matches = preg_match($pattern, $headers['Authorization']);
|
||||||
|
$me->assertEquals(1, $matches, 'Asserting that the authorization header contains the correct expression.');
|
||||||
|
|
||||||
|
$me->assertSame($body, ['oauth_verifier' => 'myverifiercode']);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}))->once()->andReturn($response = m::mock('stdClass'));
|
||||||
|
$response->shouldReceive('getBody')
|
||||||
|
->andReturn('oauth_token=tokencredentialsidentifier&oauth_token_secret=tokencredentialssecret');
|
||||||
|
|
||||||
|
$credentials = $server->getTokenCredentials($temporaryCredentials, 'temporarycredentialsidentifier', 'myverifiercode');
|
||||||
|
$this->assertInstanceOf('League\OAuth1\Client\Credentials\TokenCredentials', $credentials);
|
||||||
|
$this->assertEquals('tokencredentialsidentifier', $credentials->getIdentifier());
|
||||||
|
$this->assertEquals('tokencredentialssecret', $credentials->getSecret());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingTokenCredentialsWithUserAgent()
|
||||||
|
{
|
||||||
|
$userAgent = 'FooBar';
|
||||||
|
$server = m::mock('League\OAuth1\Client\Tests\ServerStub[createHttpClient]', [$this->getMockClientCredentials()]);
|
||||||
|
|
||||||
|
$temporaryCredentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
|
||||||
|
$temporaryCredentials->shouldReceive('getIdentifier')->andReturn('temporarycredentialsidentifier');
|
||||||
|
$temporaryCredentials->shouldReceive('getSecret')->andReturn('temporarycredentialssecret');
|
||||||
|
|
||||||
|
$server->shouldReceive('createHttpClient')->andReturn($client = m::mock('stdClass'));
|
||||||
|
|
||||||
|
$me = $this;
|
||||||
|
$client->shouldReceive('post')->with('http://www.example.com/token', m::on(function ($options) use ($me, $userAgent) {
|
||||||
|
$headers = $options['headers'];
|
||||||
|
$body = $options['form_params'];
|
||||||
|
|
||||||
|
$me->assertTrue(isset($headers['Authorization']));
|
||||||
|
$me->assertTrue(isset($headers['User-Agent']));
|
||||||
|
$me->assertEquals($userAgent, $headers['User-Agent']);
|
||||||
|
|
||||||
|
// OAuth protocol specifies a strict number of
|
||||||
|
// headers should be sent, in the correct order.
|
||||||
|
// We'll validate that here.
|
||||||
|
$pattern
|
||||||
|
= '/OAuth oauth_consumer_key=".*?", oauth_nonce="[a-zA-Z0-9]+", oauth_signature_method="HMAC-SHA1", oauth_timestamp="\d{10}", oauth_version="1.0", oauth_token="temporarycredentialsidentifier", oauth_signature=".*?"/';
|
||||||
|
|
||||||
|
$matches = preg_match($pattern, $headers['Authorization']);
|
||||||
|
$me->assertEquals(1, $matches, 'Asserting that the authorization header contains the correct expression.');
|
||||||
|
|
||||||
|
$me->assertSame($body, ['oauth_verifier' => 'myverifiercode']);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}))->once()->andReturn($response = m::mock('stdClass'));
|
||||||
|
$response->shouldReceive('getBody')
|
||||||
|
->andReturn('oauth_token=tokencredentialsidentifier&oauth_token_secret=tokencredentialssecret');
|
||||||
|
|
||||||
|
$credentials = $server->setUserAgent($userAgent)
|
||||||
|
->getTokenCredentials($temporaryCredentials, 'temporarycredentialsidentifier', 'myverifiercode');
|
||||||
|
$this->assertInstanceOf('League\OAuth1\Client\Credentials\TokenCredentials', $credentials);
|
||||||
|
$this->assertEquals('tokencredentialsidentifier', $credentials->getIdentifier());
|
||||||
|
$this->assertEquals('tokencredentialssecret', $credentials->getSecret());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingUserDetails()
|
||||||
|
{
|
||||||
|
$server = m::mock(
|
||||||
|
'League\OAuth1\Client\Tests\ServerStub[createHttpClient,protocolHeader]',
|
||||||
|
[$this->getMockClientCredentials()]
|
||||||
|
);
|
||||||
|
|
||||||
|
$temporaryCredentials = m::mock('League\OAuth1\Client\Credentials\TokenCredentials');
|
||||||
|
$temporaryCredentials->shouldReceive('getIdentifier')->andReturn('tokencredentialsidentifier');
|
||||||
|
$temporaryCredentials->shouldReceive('getSecret')->andReturn('tokencredentialssecret');
|
||||||
|
|
||||||
|
$server->shouldReceive('createHttpClient')->andReturn($client = m::mock('stdClass'));
|
||||||
|
|
||||||
|
$me = $this;
|
||||||
|
$client->shouldReceive('get')->with('http://www.example.com/user', m::on(function ($options) use ($me) {
|
||||||
|
$headers = $options['headers'];
|
||||||
|
|
||||||
|
$me->assertTrue(isset($headers['Authorization']));
|
||||||
|
|
||||||
|
// OAuth protocol specifies a strict number of
|
||||||
|
// headers should be sent, in the correct order.
|
||||||
|
// We'll validate that here.
|
||||||
|
$pattern
|
||||||
|
= '/OAuth oauth_consumer_key=".*?", oauth_nonce="[a-zA-Z0-9]+", oauth_signature_method="HMAC-SHA1", oauth_timestamp="\d{10}", oauth_version="1.0", oauth_token="tokencredentialsidentifier", oauth_signature=".*?"/';
|
||||||
|
|
||||||
|
$matches = preg_match($pattern, $headers['Authorization']);
|
||||||
|
$me->assertEquals(1, $matches, 'Asserting that the authorization header contains the correct expression.');
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}))->once()->andReturn($response = m::mock(ResponseInterface::class));
|
||||||
|
$response->shouldReceive('getBody')->once()->andReturn(json_encode([
|
||||||
|
'foo' => 'bar',
|
||||||
|
'id' => 123,
|
||||||
|
'contact_email' => 'baz@qux.com',
|
||||||
|
'username' => 'fred',
|
||||||
|
]));
|
||||||
|
|
||||||
|
$user = $server->getUserDetails($temporaryCredentials);
|
||||||
|
$this->assertInstanceOf('League\OAuth1\Client\Server\User', $user);
|
||||||
|
$this->assertEquals('bar', $user->firstName);
|
||||||
|
$this->assertEquals(123, $server->getUserUid($temporaryCredentials));
|
||||||
|
$this->assertEquals('baz@qux.com', $server->getUserEmail($temporaryCredentials));
|
||||||
|
$this->assertEquals('fred', $server->getUserScreenName($temporaryCredentials));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingHeaders()
|
||||||
|
{
|
||||||
|
$server = new ServerStub($this->getMockClientCredentials());
|
||||||
|
|
||||||
|
$tokenCredentials = m::mock('League\OAuth1\Client\Credentials\TokenCredentials');
|
||||||
|
$tokenCredentials->shouldReceive('getIdentifier')->andReturn('mock_identifier');
|
||||||
|
$tokenCredentials->shouldReceive('getSecret')->andReturn('mock_secret');
|
||||||
|
|
||||||
|
// OAuth protocol specifies a strict number of
|
||||||
|
// headers should be sent, in the correct order.
|
||||||
|
// We'll validate that here.
|
||||||
|
$pattern
|
||||||
|
= '/OAuth oauth_consumer_key=".*?", oauth_nonce="[a-zA-Z0-9]+", oauth_signature_method="HMAC-SHA1", oauth_timestamp="\d{10}", oauth_version="1.0", oauth_token="mock_identifier", oauth_signature=".*?"/';
|
||||||
|
|
||||||
|
// With a GET request
|
||||||
|
$headers = $server->getHeaders($tokenCredentials, 'GET', 'http://example.com/');
|
||||||
|
$this->assertTrue(isset($headers['Authorization']));
|
||||||
|
|
||||||
|
$matches = preg_match($pattern, $headers['Authorization']);
|
||||||
|
$this->assertEquals(1, $matches, 'Asserting that the authorization header contains the correct expression.');
|
||||||
|
|
||||||
|
// With a POST request
|
||||||
|
$headers = $server->getHeaders($tokenCredentials, 'POST', 'http://example.com/', ['body' => 'params']);
|
||||||
|
$this->assertTrue(isset($headers['Authorization']));
|
||||||
|
|
||||||
|
$matches = preg_match($pattern, $headers['Authorization']);
|
||||||
|
$this->assertEquals(1, $matches, 'Asserting that the authorization header contains the correct expression.');
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getMockClientCredentials()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'identifier' => 'myidentifier',
|
||||||
|
'secret' => 'mysecret',
|
||||||
|
'callback_uri' => 'http://app.dev/',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
349
vendor/league/oauth1-client/tests/TrelloServerTest.php
vendored
Normal file
349
vendor/league/oauth1-client/tests/TrelloServerTest.php
vendored
Normal file
@ -0,0 +1,349 @@
|
|||||||
|
<?php namespace League\OAuth1\Client\Tests;
|
||||||
|
|
||||||
|
use InvalidArgumentException;
|
||||||
|
use League\OAuth1\Client\Credentials\ClientCredentials;
|
||||||
|
use League\OAuth1\Client\Server\Trello;
|
||||||
|
use Mockery as m;
|
||||||
|
use PHPUnit\Framework\TestCase;
|
||||||
|
|
||||||
|
|
||||||
|
use Psr\Http\Message\ResponseInterface;
|
||||||
|
|
||||||
|
class TrelloTest extends TestCase
|
||||||
|
{
|
||||||
|
protected function tearDown(): void
|
||||||
|
{
|
||||||
|
m::close();
|
||||||
|
|
||||||
|
parent::tearDown();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCreatingWithArray()
|
||||||
|
{
|
||||||
|
$server = new Trello($this->getMockClientCredentials());
|
||||||
|
|
||||||
|
$credentials = $server->getClientCredentials();
|
||||||
|
$this->assertInstanceOf('League\OAuth1\Client\Credentials\ClientCredentialsInterface', $credentials);
|
||||||
|
$this->assertEquals($this->getApplicationKey(), $credentials->getIdentifier());
|
||||||
|
$this->assertEquals('mysecret', $credentials->getSecret());
|
||||||
|
$this->assertEquals('http://app.dev/', $credentials->getCallbackUri());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCreatingWithObject()
|
||||||
|
{
|
||||||
|
$credentials = new ClientCredentials;
|
||||||
|
$credentials->setIdentifier('myidentifier');
|
||||||
|
$credentials->setSecret('mysecret');
|
||||||
|
$credentials->setCallbackUri('http://app.dev/');
|
||||||
|
|
||||||
|
$server = new Trello($credentials);
|
||||||
|
|
||||||
|
$this->assertEquals($credentials, $server->getClientCredentials());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingTemporaryCredentials()
|
||||||
|
{
|
||||||
|
$server = m::mock('League\OAuth1\Client\Server\Trello[createHttpClient]', [$this->getMockClientCredentials()]);
|
||||||
|
|
||||||
|
$server->shouldReceive('createHttpClient')->andReturn($client = m::mock('stdClass'));
|
||||||
|
|
||||||
|
$me = $this;
|
||||||
|
$client->shouldReceive('post')->with('https://trello.com/1/OAuthGetRequestToken', m::on(function ($options) use ($me) {
|
||||||
|
$headers = $options['headers'];
|
||||||
|
|
||||||
|
$me->assertTrue(isset($headers['Authorization']));
|
||||||
|
|
||||||
|
// OAuth protocol specifies a strict number of
|
||||||
|
// headers should be sent, in the correct order.
|
||||||
|
// We'll validate that here.
|
||||||
|
$pattern = '/OAuth oauth_consumer_key=".*?", oauth_nonce="[a-zA-Z0-9]+", oauth_signature_method="HMAC-SHA1", oauth_timestamp="\d{10}", oauth_version="1.0", oauth_callback="' . preg_quote('http%3A%2F%2Fapp.dev%2F', '/') . '", oauth_signature=".*?"/';
|
||||||
|
|
||||||
|
$matches = preg_match($pattern, $headers['Authorization']);
|
||||||
|
$me->assertEquals(1, $matches, 'Asserting that the authorization header contains the correct expression.');
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}))->once()->andReturn($response = m::mock(ResponseInterface::class));
|
||||||
|
$response->shouldReceive('getBody')->andReturn('oauth_token=temporarycredentialsidentifier&oauth_token_secret=temporarycredentialssecret&oauth_callback_confirmed=true');
|
||||||
|
|
||||||
|
$credentials = $server->getTemporaryCredentials();
|
||||||
|
$this->assertInstanceOf('League\OAuth1\Client\Credentials\TemporaryCredentials', $credentials);
|
||||||
|
$this->assertEquals('temporarycredentialsidentifier', $credentials->getIdentifier());
|
||||||
|
$this->assertEquals('temporarycredentialssecret', $credentials->getSecret());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingDefaultAuthorizationUrl()
|
||||||
|
{
|
||||||
|
$server = new Trello($this->getMockClientCredentials());
|
||||||
|
|
||||||
|
$expected = 'https://trello.com/1/OAuthAuthorizeToken?response_type=fragment&scope=read&expiration=1day&oauth_token=foo';
|
||||||
|
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl('foo'));
|
||||||
|
|
||||||
|
$credentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
|
||||||
|
$credentials->shouldReceive('getIdentifier')->andReturn('foo');
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl($credentials));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingAuthorizationUrlWithExpirationAfterConstructingWithExpiration()
|
||||||
|
{
|
||||||
|
$credentials = $this->getMockClientCredentials();
|
||||||
|
$expiration = $this->getApplicationExpiration(2);
|
||||||
|
$credentials['expiration'] = $expiration;
|
||||||
|
$server = new Trello($credentials);
|
||||||
|
|
||||||
|
$expected = 'https://trello.com/1/OAuthAuthorizeToken?response_type=fragment&scope=read&expiration=' . urlencode($expiration) . '&oauth_token=foo';
|
||||||
|
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl('foo'));
|
||||||
|
|
||||||
|
$credentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
|
||||||
|
$credentials->shouldReceive('getIdentifier')->andReturn('foo');
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl($credentials));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingAuthorizationUrlWithExpirationAfterSettingExpiration()
|
||||||
|
{
|
||||||
|
$expiration = $this->getApplicationExpiration(2);
|
||||||
|
$server = new Trello($this->getMockClientCredentials());
|
||||||
|
$server->setApplicationExpiration($expiration);
|
||||||
|
|
||||||
|
$expected = 'https://trello.com/1/OAuthAuthorizeToken?response_type=fragment&scope=read&expiration=' . urlencode($expiration) . '&oauth_token=foo';
|
||||||
|
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl('foo'));
|
||||||
|
|
||||||
|
$credentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
|
||||||
|
$credentials->shouldReceive('getIdentifier')->andReturn('foo');
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl($credentials));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingAuthorizationUrlWithNameAfterConstructingWithName()
|
||||||
|
{
|
||||||
|
$credentials = $this->getMockClientCredentials();
|
||||||
|
$name = $this->getApplicationName();
|
||||||
|
$credentials['name'] = $name;
|
||||||
|
$server = new Trello($credentials);
|
||||||
|
|
||||||
|
$expected = 'https://trello.com/1/OAuthAuthorizeToken?response_type=fragment&scope=read&expiration=1day&name=' . urlencode($name) . '&oauth_token=foo';
|
||||||
|
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl('foo'));
|
||||||
|
|
||||||
|
$credentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
|
||||||
|
$credentials->shouldReceive('getIdentifier')->andReturn('foo');
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl($credentials));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingAuthorizationUrlWithNameAfterSettingName()
|
||||||
|
{
|
||||||
|
$name = $this->getApplicationName();
|
||||||
|
$server = new Trello($this->getMockClientCredentials());
|
||||||
|
$server->setApplicationName($name);
|
||||||
|
|
||||||
|
$expected = 'https://trello.com/1/OAuthAuthorizeToken?response_type=fragment&scope=read&expiration=1day&name=' . urlencode($name) . '&oauth_token=foo';
|
||||||
|
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl('foo'));
|
||||||
|
|
||||||
|
$credentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
|
||||||
|
$credentials->shouldReceive('getIdentifier')->andReturn('foo');
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl($credentials));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingAuthorizationUrlWithScopeAfterConstructingWithScope()
|
||||||
|
{
|
||||||
|
$credentials = $this->getMockClientCredentials();
|
||||||
|
$scope = $this->getApplicationScope(false);
|
||||||
|
$credentials['scope'] = $scope;
|
||||||
|
$server = new Trello($credentials);
|
||||||
|
|
||||||
|
$expected = 'https://trello.com/1/OAuthAuthorizeToken?response_type=fragment&scope=' . urlencode($scope) . '&expiration=1day&oauth_token=foo';
|
||||||
|
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl('foo'));
|
||||||
|
|
||||||
|
$credentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
|
||||||
|
$credentials->shouldReceive('getIdentifier')->andReturn('foo');
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl($credentials));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingAuthorizationUrlWithScopeAfterSettingScope()
|
||||||
|
{
|
||||||
|
$scope = $this->getApplicationScope(false);
|
||||||
|
$server = new Trello($this->getMockClientCredentials());
|
||||||
|
$server->setApplicationScope($scope);
|
||||||
|
|
||||||
|
$expected = 'https://trello.com/1/OAuthAuthorizeToken?response_type=fragment&scope=' . urlencode($scope) . '&expiration=1day&oauth_token=foo';
|
||||||
|
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl('foo'));
|
||||||
|
|
||||||
|
$credentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
|
||||||
|
$credentials->shouldReceive('getIdentifier')->andReturn('foo');
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl($credentials));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingTokenCredentialsFailsWithManInTheMiddle()
|
||||||
|
{
|
||||||
|
$server = new Trello($this->getMockClientCredentials());
|
||||||
|
|
||||||
|
$credentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
|
||||||
|
$credentials->shouldReceive('getIdentifier')->andReturn('foo');
|
||||||
|
|
||||||
|
$this->expectException(InvalidArgumentException::class);
|
||||||
|
|
||||||
|
$server->getTokenCredentials($credentials, 'bar', 'verifier');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingTokenCredentials()
|
||||||
|
{
|
||||||
|
$server = m::mock('League\OAuth1\Client\Server\Trello[createHttpClient]', [$this->getMockClientCredentials()]);
|
||||||
|
|
||||||
|
$temporaryCredentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
|
||||||
|
$temporaryCredentials->shouldReceive('getIdentifier')->andReturn('temporarycredentialsidentifier');
|
||||||
|
$temporaryCredentials->shouldReceive('getSecret')->andReturn('temporarycredentialssecret');
|
||||||
|
|
||||||
|
$server->shouldReceive('createHttpClient')->andReturn($client = m::mock('stdClass'));
|
||||||
|
|
||||||
|
$me = $this;
|
||||||
|
$client->shouldReceive('post')->with('https://trello.com/1/OAuthGetAccessToken', m::on(function ($options) use ($me) {
|
||||||
|
$headers = $options['headers'];
|
||||||
|
$body = $options['form_params'];
|
||||||
|
|
||||||
|
$me->assertTrue(isset($headers['Authorization']));
|
||||||
|
|
||||||
|
// OAuth protocol specifies a strict number of
|
||||||
|
// headers should be sent, in the correct order.
|
||||||
|
// We'll validate that here.
|
||||||
|
$pattern = '/OAuth oauth_consumer_key=".*?", oauth_nonce="[a-zA-Z0-9]+", oauth_signature_method="HMAC-SHA1", oauth_timestamp="\d{10}", oauth_version="1.0", oauth_token="temporarycredentialsidentifier", oauth_signature=".*?"/';
|
||||||
|
|
||||||
|
$matches = preg_match($pattern, $headers['Authorization']);
|
||||||
|
$me->assertEquals(1, $matches, 'Asserting that the authorization header contains the correct expression.');
|
||||||
|
|
||||||
|
$me->assertSame($body, ['oauth_verifier' => 'myverifiercode']);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}))->once()->andReturn($response = m::mock(ResponseInterface::class));
|
||||||
|
$response->shouldReceive('getBody')->andReturn('oauth_token=tokencredentialsidentifier&oauth_token_secret=tokencredentialssecret');
|
||||||
|
|
||||||
|
$credentials = $server->getTokenCredentials($temporaryCredentials, 'temporarycredentialsidentifier', 'myverifiercode');
|
||||||
|
$this->assertInstanceOf('League\OAuth1\Client\Credentials\TokenCredentials', $credentials);
|
||||||
|
$this->assertEquals('tokencredentialsidentifier', $credentials->getIdentifier());
|
||||||
|
$this->assertEquals('tokencredentialssecret', $credentials->getSecret());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingUserDetails()
|
||||||
|
{
|
||||||
|
$server = m::mock('League\OAuth1\Client\Server\Trello[createHttpClient,protocolHeader]', [$this->getMockClientCredentials()]);
|
||||||
|
|
||||||
|
$temporaryCredentials = m::mock('League\OAuth1\Client\Credentials\TokenCredentials');
|
||||||
|
$temporaryCredentials->shouldReceive('getIdentifier')->andReturn('tokencredentialsidentifier');
|
||||||
|
$temporaryCredentials->shouldReceive('getSecret')->andReturn('tokencredentialssecret');
|
||||||
|
|
||||||
|
$server->shouldReceive('createHttpClient')->andReturn($client = m::mock('stdClass'));
|
||||||
|
|
||||||
|
$me = $this;
|
||||||
|
$client->shouldReceive('get')->with('https://trello.com/1/members/me?key=' . $this->getApplicationKey() . '&token=' . $this->getAccessToken(), m::on(function ($options) use ($me) {
|
||||||
|
$headers = $options['headers'];
|
||||||
|
|
||||||
|
$me->assertTrue(isset($headers['Authorization']));
|
||||||
|
|
||||||
|
// OAuth protocol specifies a strict number of
|
||||||
|
// headers should be sent, in the correct order.
|
||||||
|
// We'll validate that here.
|
||||||
|
$pattern = '/OAuth oauth_consumer_key=".*?", oauth_nonce="[a-zA-Z0-9]+", oauth_signature_method="HMAC-SHA1", oauth_timestamp="\d{10}", oauth_version="1.0", oauth_token="tokencredentialsidentifier", oauth_signature=".*?"/';
|
||||||
|
|
||||||
|
$matches = preg_match($pattern, $headers['Authorization']);
|
||||||
|
$me->assertEquals(1, $matches, 'Asserting that the authorization header contains the correct expression.');
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}))->once()->andReturn($response = m::mock(ResponseInterface::class));
|
||||||
|
$response->shouldReceive('getBody')->once()->andReturn($this->getUserPayload());
|
||||||
|
|
||||||
|
$user = $server
|
||||||
|
->setAccessToken($this->getAccessToken())
|
||||||
|
->getUserDetails($temporaryCredentials);
|
||||||
|
$this->assertInstanceOf('League\OAuth1\Client\Server\User', $user);
|
||||||
|
$this->assertEquals('Matilda Wormwood', $user->name);
|
||||||
|
$this->assertEquals('545df696e29c0dddaed31967', $server->getUserUid($temporaryCredentials));
|
||||||
|
$this->assertEquals(null, $server->getUserEmail($temporaryCredentials));
|
||||||
|
$this->assertEquals('matildawormwood12', $server->getUserScreenName($temporaryCredentials));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getMockClientCredentials()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'identifier' => $this->getApplicationKey(),
|
||||||
|
'secret' => 'mysecret',
|
||||||
|
'callback_uri' => 'http://app.dev/',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getAccessToken()
|
||||||
|
{
|
||||||
|
return 'lmnopqrstuvwxyz';
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getApplicationKey()
|
||||||
|
{
|
||||||
|
return 'abcdefghijk';
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getApplicationExpiration($days = 0)
|
||||||
|
{
|
||||||
|
return is_numeric($days) && $days > 0 ? $days . 'day' . ($days == 1 ? '' : 's') : 'never';
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getApplicationName()
|
||||||
|
{
|
||||||
|
return 'fizz buzz';
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getApplicationScope($readonly = true)
|
||||||
|
{
|
||||||
|
return $readonly ? 'read' : 'read,write';
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getUserPayload()
|
||||||
|
{
|
||||||
|
return '{
|
||||||
|
"id": "545df696e29c0dddaed31967",
|
||||||
|
"avatarHash": null,
|
||||||
|
"bio": "I have magical powers",
|
||||||
|
"bioData": null,
|
||||||
|
"confirmed": true,
|
||||||
|
"fullName": "Matilda Wormwood",
|
||||||
|
"idPremOrgsAdmin": [],
|
||||||
|
"initials": "MW",
|
||||||
|
"memberType": "normal",
|
||||||
|
"products": [],
|
||||||
|
"status": "idle",
|
||||||
|
"url": "https://trello.com/matildawormwood12",
|
||||||
|
"username": "matildawormwood12",
|
||||||
|
"avatarSource": "none",
|
||||||
|
"email": null,
|
||||||
|
"gravatarHash": "39aaaada0224f26f0bb8f1965326dcb7",
|
||||||
|
"idBoards": [
|
||||||
|
"545df696e29c0dddaed31968",
|
||||||
|
"545e01d6c7b2dd962b5b46cb"
|
||||||
|
],
|
||||||
|
"idOrganizations": [
|
||||||
|
"54adfd79f9aea14f84009a85",
|
||||||
|
"54adfde13b0e706947bc4789"
|
||||||
|
],
|
||||||
|
"loginTypes": null,
|
||||||
|
"oneTimeMessagesDismissed": [],
|
||||||
|
"prefs": {
|
||||||
|
"sendSummaries": true,
|
||||||
|
"minutesBetweenSummaries": 1,
|
||||||
|
"minutesBeforeDeadlineToNotify": 1440,
|
||||||
|
"colorBlind": false,
|
||||||
|
"timezoneInfo": {
|
||||||
|
"timezoneNext": "CDT",
|
||||||
|
"dateNext": "2015-03-08T08:00:00.000Z",
|
||||||
|
"offsetNext": 300,
|
||||||
|
"timezoneCurrent": "CST",
|
||||||
|
"offsetCurrent": 360
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"trophies": [],
|
||||||
|
"uploadedAvatarHash": null,
|
||||||
|
"premiumFeatures": [],
|
||||||
|
"idBoardsPinned": null
|
||||||
|
}';
|
||||||
|
}
|
||||||
|
}
|
255
vendor/league/oauth1-client/tests/XingServerTest.php
vendored
Normal file
255
vendor/league/oauth1-client/tests/XingServerTest.php
vendored
Normal file
@ -0,0 +1,255 @@
|
|||||||
|
<?php namespace League\OAuth1\Client\Tests;
|
||||||
|
|
||||||
|
use InvalidArgumentException;
|
||||||
|
use League\OAuth1\Client\Credentials\ClientCredentials;
|
||||||
|
use League\OAuth1\Client\Server\Xing;
|
||||||
|
use Mockery as m;
|
||||||
|
use PHPUnit\Framework\TestCase;
|
||||||
|
|
||||||
|
|
||||||
|
use Psr\Http\Message\ResponseInterface;
|
||||||
|
|
||||||
|
class XingTest extends TestCase
|
||||||
|
{
|
||||||
|
protected function tearDown(): void
|
||||||
|
{
|
||||||
|
m::close();
|
||||||
|
|
||||||
|
parent::tearDown();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCreatingWithArray()
|
||||||
|
{
|
||||||
|
$server = new Xing($this->getMockClientCredentials());
|
||||||
|
|
||||||
|
$credentials = $server->getClientCredentials();
|
||||||
|
$this->assertInstanceOf('League\OAuth1\Client\Credentials\ClientCredentialsInterface', $credentials);
|
||||||
|
$this->assertEquals($this->getApplicationKey(), $credentials->getIdentifier());
|
||||||
|
$this->assertEquals('mysecret', $credentials->getSecret());
|
||||||
|
$this->assertEquals('http://app.dev/', $credentials->getCallbackUri());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCreatingWithObject()
|
||||||
|
{
|
||||||
|
$credentials = new ClientCredentials;
|
||||||
|
$credentials->setIdentifier('myidentifier');
|
||||||
|
$credentials->setSecret('mysecret');
|
||||||
|
$credentials->setCallbackUri('http://app.dev/');
|
||||||
|
|
||||||
|
$server = new Xing($credentials);
|
||||||
|
|
||||||
|
$this->assertEquals($credentials, $server->getClientCredentials());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingTemporaryCredentials()
|
||||||
|
{
|
||||||
|
$server = m::mock('League\OAuth1\Client\Server\Xing[createHttpClient]', [$this->getMockClientCredentials()]);
|
||||||
|
|
||||||
|
$server->shouldReceive('createHttpClient')->andReturn($client = m::mock('stdClass'));
|
||||||
|
|
||||||
|
$me = $this;
|
||||||
|
$client->shouldReceive('post')->with('https://api.xing.com/v1/request_token', m::on(function ($options) use ($me) {
|
||||||
|
$headers = $options['headers'];
|
||||||
|
$me->assertTrue(isset($headers['Authorization']));
|
||||||
|
|
||||||
|
// OAuth protocol specifies a strict number of
|
||||||
|
// headers should be sent, in the correct order.
|
||||||
|
// We'll validate that here.
|
||||||
|
$pattern = '/OAuth oauth_consumer_key=".*?", oauth_nonce="[a-zA-Z0-9]+", oauth_signature_method="HMAC-SHA1", oauth_timestamp="\d{10}", oauth_version="1.0", oauth_callback="' . preg_quote('http%3A%2F%2Fapp.dev%2F', '/') . '", oauth_signature=".*?"/';
|
||||||
|
|
||||||
|
$matches = preg_match($pattern, $headers['Authorization']);
|
||||||
|
$me->assertEquals(1, $matches, 'Asserting that the authorization header contains the correct expression.');
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}))->once()->andReturn($response = m::mock(ResponseInterface::class));
|
||||||
|
$response->shouldReceive('getBody')->andReturn('oauth_token=temporarycredentialsidentifier&oauth_token_secret=temporarycredentialssecret&oauth_callback_confirmed=true');
|
||||||
|
|
||||||
|
$credentials = $server->getTemporaryCredentials();
|
||||||
|
$this->assertInstanceOf('League\OAuth1\Client\Credentials\TemporaryCredentials', $credentials);
|
||||||
|
$this->assertEquals('temporarycredentialsidentifier', $credentials->getIdentifier());
|
||||||
|
$this->assertEquals('temporarycredentialssecret', $credentials->getSecret());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingDefaultAuthorizationUrl()
|
||||||
|
{
|
||||||
|
$server = new Xing($this->getMockClientCredentials());
|
||||||
|
|
||||||
|
$expected = 'https://api.xing.com/v1/authorize?oauth_token=foo';
|
||||||
|
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl('foo'));
|
||||||
|
|
||||||
|
$credentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
|
||||||
|
$credentials->shouldReceive('getIdentifier')->andReturn('foo');
|
||||||
|
$this->assertEquals($expected, $server->getAuthorizationUrl($credentials));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingTokenCredentialsFailsWithManInTheMiddle()
|
||||||
|
{
|
||||||
|
$server = new Xing($this->getMockClientCredentials());
|
||||||
|
|
||||||
|
$credentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
|
||||||
|
$credentials->shouldReceive('getIdentifier')->andReturn('foo');
|
||||||
|
|
||||||
|
$this->expectException(InvalidArgumentException::class);
|
||||||
|
|
||||||
|
$server->getTokenCredentials($credentials, 'bar', 'verifier');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingTokenCredentials()
|
||||||
|
{
|
||||||
|
$server = m::mock('League\OAuth1\Client\Server\Xing[createHttpClient]', [$this->getMockClientCredentials()]);
|
||||||
|
|
||||||
|
$temporaryCredentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
|
||||||
|
$temporaryCredentials->shouldReceive('getIdentifier')->andReturn('temporarycredentialsidentifier');
|
||||||
|
$temporaryCredentials->shouldReceive('getSecret')->andReturn('temporarycredentialssecret');
|
||||||
|
|
||||||
|
$server->shouldReceive('createHttpClient')->andReturn($client = m::mock('stdClass'));
|
||||||
|
|
||||||
|
$me = $this;
|
||||||
|
$client->shouldReceive('post')->with('https://api.xing.com/v1/access_token', m::on(function ($options) use ($me) {
|
||||||
|
$headers = $options['headers'];
|
||||||
|
$body = $options['form_params'];
|
||||||
|
|
||||||
|
$me->assertTrue(isset($headers['Authorization']));
|
||||||
|
|
||||||
|
// OAuth protocol specifies a strict number of
|
||||||
|
// headers should be sent, in the correct order.
|
||||||
|
// We'll validate that here.
|
||||||
|
$pattern = '/OAuth oauth_consumer_key=".*?", oauth_nonce="[a-zA-Z0-9]+", oauth_signature_method="HMAC-SHA1", oauth_timestamp="\d{10}", oauth_version="1.0", oauth_token="temporarycredentialsidentifier", oauth_signature=".*?"/';
|
||||||
|
|
||||||
|
$matches = preg_match($pattern, $headers['Authorization']);
|
||||||
|
$me->assertEquals(1, $matches, 'Asserting that the authorization header contains the correct expression.');
|
||||||
|
|
||||||
|
$me->assertSame($body, ['oauth_verifier' => 'myverifiercode']);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}))->once()->andReturn($response = m::mock(ResponseInterface::class));
|
||||||
|
$response->shouldReceive('getBody')->andReturn('oauth_token=tokencredentialsidentifier&oauth_token_secret=tokencredentialssecret');
|
||||||
|
|
||||||
|
$credentials = $server->getTokenCredentials($temporaryCredentials, 'temporarycredentialsidentifier', 'myverifiercode');
|
||||||
|
$this->assertInstanceOf('League\OAuth1\Client\Credentials\TokenCredentials', $credentials);
|
||||||
|
$this->assertEquals('tokencredentialsidentifier', $credentials->getIdentifier());
|
||||||
|
$this->assertEquals('tokencredentialssecret', $credentials->getSecret());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGettingUserDetails()
|
||||||
|
{
|
||||||
|
$server = m::mock('League\OAuth1\Client\Server\Xing[createHttpClient,protocolHeader]', [$this->getMockClientCredentials()]);
|
||||||
|
|
||||||
|
$temporaryCredentials = m::mock('League\OAuth1\Client\Credentials\TokenCredentials');
|
||||||
|
$temporaryCredentials->shouldReceive('getIdentifier')->andReturn('tokencredentialsidentifier');
|
||||||
|
$temporaryCredentials->shouldReceive('getSecret')->andReturn('tokencredentialssecret');
|
||||||
|
|
||||||
|
$server->shouldReceive('createHttpClient')->andReturn($client = m::mock('stdClass'));
|
||||||
|
|
||||||
|
$me = $this;
|
||||||
|
$client->shouldReceive('get')->with('https://api.xing.com/v1/users/me', m::on(function ($options) use ($me) {
|
||||||
|
$headers = $options['headers'];
|
||||||
|
|
||||||
|
$me->assertTrue(isset($headers['Authorization']));
|
||||||
|
|
||||||
|
// OAuth protocol specifies a strict number of
|
||||||
|
// headers should be sent, in the correct order.
|
||||||
|
// We'll validate that here.
|
||||||
|
$pattern = '/OAuth oauth_consumer_key=".*?", oauth_nonce="[a-zA-Z0-9]+", oauth_signature_method="HMAC-SHA1", oauth_timestamp="\d{10}", oauth_version="1.0", oauth_token="tokencredentialsidentifier", oauth_signature=".*?"/';
|
||||||
|
|
||||||
|
$matches = preg_match($pattern, $headers['Authorization']);
|
||||||
|
$me->assertEquals(1, $matches, 'Asserting that the authorization header contains the correct expression.');
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}))->once()->andReturn($response = m::mock(ResponseInterface::class));
|
||||||
|
$response->shouldReceive('getBody')->once()->andReturn($this->getUserPayload());
|
||||||
|
|
||||||
|
$user = $server->getUserDetails($temporaryCredentials);
|
||||||
|
$this->assertInstanceOf('League\OAuth1\Client\Server\User', $user);
|
||||||
|
$this->assertEquals('Roman Gelembjuk', $user->name);
|
||||||
|
$this->assertEquals('17144430_0f9409', $server->getUserUid($temporaryCredentials));
|
||||||
|
$this->assertEquals('XXXXXXXXXX@gmail.com', $server->getUserEmail($temporaryCredentials));
|
||||||
|
$this->assertEquals('Roman Gelembjuk', $server->getUserScreenName($temporaryCredentials));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getMockClientCredentials()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'identifier' => $this->getApplicationKey(),
|
||||||
|
'secret' => 'mysecret',
|
||||||
|
'callback_uri' => 'http://app.dev/',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getApplicationKey()
|
||||||
|
{
|
||||||
|
return 'abcdefghijk';
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getApplicationExpiration($days = 0)
|
||||||
|
{
|
||||||
|
return is_numeric($days) && $days > 0 ? $days . 'day' . ($days == 1 ? '' : 's') : 'never';
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getApplicationName()
|
||||||
|
{
|
||||||
|
return 'fizz buzz';
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getUserPayload()
|
||||||
|
{
|
||||||
|
return '{
|
||||||
|
"users":[
|
||||||
|
{
|
||||||
|
"id":"17144430_0f9409",
|
||||||
|
"active_email":"XXXXXXXXXX@gmail.com",
|
||||||
|
"time_zone":
|
||||||
|
{
|
||||||
|
"utc_offset":3.0,
|
||||||
|
"name":"Europe/Kiev"
|
||||||
|
},
|
||||||
|
"display_name":"Roman Gelembjuk",
|
||||||
|
"first_name":"Roman",
|
||||||
|
"last_name":"Gelembjuk",
|
||||||
|
"gender":"m",
|
||||||
|
"page_name":"Roman_Gelembjuk",
|
||||||
|
"birth_date":
|
||||||
|
{"year":null,"month":null,"day":null},
|
||||||
|
"wants":null,
|
||||||
|
"haves":null,
|
||||||
|
"interests":null,
|
||||||
|
"web_profiles":{},
|
||||||
|
"badges":[],
|
||||||
|
"photo_urls":
|
||||||
|
{
|
||||||
|
"large":"https://x1.xingassets.com/assets/frontend_minified/img/users/nobody_m.140x185.jpg",
|
||||||
|
"maxi_thumb":"https://x1.xingassets.com/assets/frontend_minified/img/users/nobody_m.70x93.jpg",
|
||||||
|
"medium_thumb":"https://x1.xingassets.com/assets/frontend_minified/img/users/nobody_m.57x75.jpg"
|
||||||
|
},
|
||||||
|
"permalink":"https://www.xing.com/profile/Roman_Gelembjuk",
|
||||||
|
"languages":{"en":null},
|
||||||
|
"employment_status":"EMPLOYEE",
|
||||||
|
"organisation_member":null,
|
||||||
|
"instant_messaging_accounts":{},
|
||||||
|
"educational_background":
|
||||||
|
{"degree":null,"primary_school":null,"schools":[],"qualifications":[]},
|
||||||
|
"private_address":{
|
||||||
|
"street":null,
|
||||||
|
"zip_code":null,
|
||||||
|
"city":null,
|
||||||
|
"province":null,
|
||||||
|
"country":null,
|
||||||
|
"email":"XXXXXXXX@gmail.com",
|
||||||
|
"fax":null,
|
||||||
|
"phone":null,
|
||||||
|
"mobile_phone":null}
|
||||||
|
,"business_address":
|
||||||
|
{
|
||||||
|
"street":null,
|
||||||
|
"zip_code":null,
|
||||||
|
"city":"Ivano-Frankivsk",
|
||||||
|
"province":null,
|
||||||
|
"country":"UA",
|
||||||
|
"email":null,
|
||||||
|
"fax":null,"phone":null,"mobile_phone":null
|
||||||
|
},
|
||||||
|
"premium_services":[]
|
||||||
|
}]}';
|
||||||
|
}
|
||||||
|
}
|
77
vendor/league/oauth1-client/tests/stubs/ServerStub.php
vendored
Normal file
77
vendor/league/oauth1-client/tests/stubs/ServerStub.php
vendored
Normal file
@ -0,0 +1,77 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace League\OAuth1\Client\Tests;
|
||||||
|
|
||||||
|
use League\OAuth1\Client\Credentials\TokenCredentials;
|
||||||
|
use League\OAuth1\Client\Server\Server;
|
||||||
|
use League\OAuth1\Client\Server\User;
|
||||||
|
|
||||||
|
class ServerStub extends Server
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @inheritDoc
|
||||||
|
*/
|
||||||
|
public function urlTemporaryCredentials()
|
||||||
|
{
|
||||||
|
return 'http://www.example.com/temporary';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @inheritDoc
|
||||||
|
*/
|
||||||
|
public function urlAuthorization()
|
||||||
|
{
|
||||||
|
return 'http://www.example.com/authorize';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @inheritDoc
|
||||||
|
*/
|
||||||
|
public function urlTokenCredentials()
|
||||||
|
{
|
||||||
|
return 'http://www.example.com/token';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @inheritDoc
|
||||||
|
*/
|
||||||
|
public function urlUserDetails()
|
||||||
|
{
|
||||||
|
return 'http://www.example.com/user';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @inheritDoc
|
||||||
|
*/
|
||||||
|
public function userDetails($data, TokenCredentials $tokenCredentials)
|
||||||
|
{
|
||||||
|
$user = new User;
|
||||||
|
$user->firstName = $data['foo'];
|
||||||
|
|
||||||
|
return $user;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @inheritDoc
|
||||||
|
*/
|
||||||
|
public function userUid($data, TokenCredentials $tokenCredentials)
|
||||||
|
{
|
||||||
|
return isset($data['id']) ? $data['id'] : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @inheritDoc
|
||||||
|
*/
|
||||||
|
public function userEmail($data, TokenCredentials $tokenCredentials)
|
||||||
|
{
|
||||||
|
return isset($data['contact_email']) ? $data['contact_email'] : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @inheritDoc
|
||||||
|
*/
|
||||||
|
public function userScreenName($data, TokenCredentials $tokenCredentials)
|
||||||
|
{
|
||||||
|
return isset($data['username']) ? $data['username'] : null;
|
||||||
|
}
|
||||||
|
}
|
1
vendor/league/oauth1-client/tests/test_rsa_invalidkey.pem
vendored
Normal file
1
vendor/league/oauth1-client/tests/test_rsa_invalidkey.pem
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
not a valid RSA key
|
15
vendor/league/oauth1-client/tests/test_rsa_privatekey.pem
vendored
Normal file
15
vendor/league/oauth1-client/tests/test_rsa_privatekey.pem
vendored
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
-----BEGIN RSA PRIVATE KEY-----
|
||||||
|
MIICXAIBAAKBgQDJScPCpHHPakw9v4nhxi+cBumCml3WpMNDaE3Cxnkf6HALzoi8
|
||||||
|
fQPx3XRfKSoLG6b7uTG+vDoLCL49ZCyYwrnggsFF08bJMqIhUHlZrkiyT5UhdTIh
|
||||||
|
XEEFfb6XmieHNtra+ur8E3PVal4PEdOCEmJehBMJkiCsxNOJ/kCeYSMdbQIDAQAB
|
||||||
|
AoGAMo7JkcEWKP/NCJFsg33xBWKjEj/NpBUcSnkPVwXc9IvAYObOZ3GLJRv3l9NS
|
||||||
|
ERov9fgNK5hBh/X5OphHr1LxtqU5gAFYx5Qgt/WG3ZH9KScXkaPS3Oq2qK9krbA2
|
||||||
|
BXYKP4NEqhjJTecy7M8bju5+lsjteyqVSsVLHdLhUfPRbE0CQQDyYP6iChqZm1AK
|
||||||
|
A8x8PKvJsd4zSdxWXUYSmD7mAtek5VeWblbcXYYdeYPN6hNmqzaLelmrZI51x1Uf
|
||||||
|
hf1ryIfrAkEA1JmdSsNuxi9MOY3HqErWYsqZ//mVOxVyCAwf7OWQ0rTHEQBhQwpS
|
||||||
|
9nk0YFHI9t6nVUwXrZ7/7UJPTu8OjPKyBwJAYw2OomwcqM/XKvCYfeFRl1DwbOdv
|
||||||
|
e4AM5gaAFgHtXP85B0o6hz5VU/BYFCvoF9o6pU+wG6IxsiJvQD3C7mx6VwJAbXYW
|
||||||
|
PVs4WsQZe/ya0vSNQ1pLRjdr9XrKNoh/m4prMYGwiPloGotjQdIP/JO/ZBQplcpS
|
||||||
|
2qrl3HPqv5poJHwE2wJBAM37BVINHR0zcSHfFLmSYrqmLx2oC3UAB3exmpYSUgOz
|
||||||
|
wJqPfmPWuuXuu6h0Z2DazUan+2EiecX6C4ywkm+qk1I=
|
||||||
|
-----END RSA PRIVATE KEY-----
|
19
vendor/league/oauth1-client/tests/test_rsa_publickey.pem
vendored
Normal file
19
vendor/league/oauth1-client/tests/test_rsa_publickey.pem
vendored
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
-----BEGIN CERTIFICATE-----
|
||||||
|
MIIDEDCCAnmgAwIBAgIJAMhMVuHMz+EgMA0GCSqGSIb3DQEBBQUAMGQxCzAJBgNV
|
||||||
|
BAYTAlVTMQswCQYDVQQIEwJUWDEPMA0GA1UEBxMGQXVzdGluMSEwHwYDVQQKExhJ
|
||||||
|
bnRlcm5ldCBXaWRnaXRzIFB0eSBMdGQxFDASBgNVBAMTC2V4YW1wbGUuY29tMB4X
|
||||||
|
DTE2MTEwMjIxMDUzNVoXDTIxMTEwMTIxMDUzNVowZDELMAkGA1UEBhMCVVMxCzAJ
|
||||||
|
BgNVBAgTAlRYMQ8wDQYDVQQHEwZBdXN0aW4xITAfBgNVBAoTGEludGVybmV0IFdp
|
||||||
|
ZGdpdHMgUHR5IEx0ZDEUMBIGA1UEAxMLZXhhbXBsZS5jb20wgZ8wDQYJKoZIhvcN
|
||||||
|
AQEBBQADgY0AMIGJAoGBAMlJw8Kkcc9qTD2/ieHGL5wG6YKaXdakw0NoTcLGeR/o
|
||||||
|
cAvOiLx9A/HddF8pKgsbpvu5Mb68OgsIvj1kLJjCueCCwUXTxskyoiFQeVmuSLJP
|
||||||
|
lSF1MiFcQQV9vpeaJ4c22tr66vwTc9VqXg8R04ISYl6EEwmSIKzE04n+QJ5hIx1t
|
||||||
|
AgMBAAGjgckwgcYwHQYDVR0OBBYEFLYKQbsK2oqRO83NbNXC2R6MkNcRMIGWBgNV
|
||||||
|
HSMEgY4wgYuAFLYKQbsK2oqRO83NbNXC2R6MkNcRoWikZjBkMQswCQYDVQQGEwJV
|
||||||
|
UzELMAkGA1UECBMCVFgxDzANBgNVBAcTBkF1c3RpbjEhMB8GA1UEChMYSW50ZXJu
|
||||||
|
ZXQgV2lkZ2l0cyBQdHkgTHRkMRQwEgYDVQQDEwtleGFtcGxlLmNvbYIJAMhMVuHM
|
||||||
|
z+EgMAwGA1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEFBQADgYEASwEwGQnRCqcNrb6k
|
||||||
|
g6/xpeyHE9/ruTBIE4dtArQI0NosaERC3i4nRKbgfJfIuYEaYiga4dC51CQqKrbH
|
||||||
|
YZ0dgYMzzp21OMQyKdz3E7csMJv5xxe5D2svdPzbBGU5+N80FYLx17f3UqsYFaAC
|
||||||
|
X0/YTQsdlM5tHZOd1ZbQUrERqLs=
|
||||||
|
-----END CERTIFICATE-----
|
0
vendor/mtdowling/jmespath.php/bin/jp.php
vendored
Normal file → Executable file
0
vendor/mtdowling/jmespath.php/bin/jp.php
vendored
Normal file → Executable file
0
vendor/mtdowling/jmespath.php/bin/perf.php
vendored
Normal file → Executable file
0
vendor/mtdowling/jmespath.php/bin/perf.php
vendored
Normal file → Executable file
39
vendor/mtdowling/jmespath.php/composer.json
vendored
Normal file
39
vendor/mtdowling/jmespath.php/composer.json
vendored
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
{
|
||||||
|
"name": "mtdowling/jmespath.php",
|
||||||
|
"description": "Declaratively specify how to extract elements from a JSON document",
|
||||||
|
"keywords": ["json", "jsonpath"],
|
||||||
|
"license": "MIT",
|
||||||
|
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Michael Dowling",
|
||||||
|
"email": "mtdowling@gmail.com",
|
||||||
|
"homepage": "https://github.com/mtdowling"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
|
||||||
|
"require": {
|
||||||
|
"php": "^5.4 || ^7.0 || ^8.0",
|
||||||
|
"symfony/polyfill-mbstring": "^1.17"
|
||||||
|
},
|
||||||
|
|
||||||
|
"require-dev": {
|
||||||
|
"composer/xdebug-handler": "^1.4",
|
||||||
|
"phpunit/phpunit": "^4.8.36 || ^7.5.15"
|
||||||
|
},
|
||||||
|
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"JmesPath\\": "src/"
|
||||||
|
},
|
||||||
|
"files": ["src/JmesPath.php"]
|
||||||
|
},
|
||||||
|
|
||||||
|
"bin": ["bin/jp.php"],
|
||||||
|
|
||||||
|
"extra": {
|
||||||
|
"branch-alias": {
|
||||||
|
"dev-master": "2.6-dev"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
3
vendor/psr/container/.gitignore
vendored
Normal file
3
vendor/psr/container/.gitignore
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
composer.lock
|
||||||
|
composer.phar
|
||||||
|
/vendor/
|
22
vendor/psr/container/composer.json
vendored
Normal file
22
vendor/psr/container/composer.json
vendored
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
{
|
||||||
|
"name": "psr/container",
|
||||||
|
"type": "library",
|
||||||
|
"description": "Common Container Interface (PHP FIG PSR-11)",
|
||||||
|
"keywords": ["psr", "psr-11", "container", "container-interop", "container-interface"],
|
||||||
|
"homepage": "https://github.com/php-fig/container",
|
||||||
|
"license": "MIT",
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "PHP-FIG",
|
||||||
|
"homepage": "https://www.php-fig.org/"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"require": {
|
||||||
|
"php": ">=7.2.0"
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"Psr\\Container\\": "src/"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
26
vendor/psr/http-message/composer.json
vendored
Normal file
26
vendor/psr/http-message/composer.json
vendored
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
{
|
||||||
|
"name": "psr/http-message",
|
||||||
|
"description": "Common interface for HTTP messages",
|
||||||
|
"keywords": ["psr", "psr-7", "http", "http-message", "request", "response"],
|
||||||
|
"homepage": "https://github.com/php-fig/http-message",
|
||||||
|
"license": "MIT",
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "PHP-FIG",
|
||||||
|
"homepage": "http://www.php-fig.org/"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"require": {
|
||||||
|
"php": ">=5.3.0"
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"Psr\\Http\\Message\\": "src/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"extra": {
|
||||||
|
"branch-alias": {
|
||||||
|
"dev-master": "1.0.x-dev"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
26
vendor/psr/log/composer.json
vendored
Normal file
26
vendor/psr/log/composer.json
vendored
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
{
|
||||||
|
"name": "psr/log",
|
||||||
|
"description": "Common interface for logging libraries",
|
||||||
|
"keywords": ["psr", "psr-3", "log"],
|
||||||
|
"homepage": "https://github.com/php-fig/log",
|
||||||
|
"license": "MIT",
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "PHP-FIG",
|
||||||
|
"homepage": "http://www.php-fig.org/"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"require": {
|
||||||
|
"php": ">=5.3.0"
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"Psr\\Log\\": "Psr/Log/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"extra": {
|
||||||
|
"branch-alias": {
|
||||||
|
"dev-master": "1.1.x-dev"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
5
vendor/swiss-payment-slip/swiss-payment-slip/.stickler.yml
vendored
Normal file
5
vendor/swiss-payment-slip/swiss-payment-slip/.stickler.yml
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
linters:
|
||||||
|
phpcs:
|
||||||
|
standard: PSR2
|
||||||
|
extensions: '.php,.ctp'
|
||||||
|
tab_width: 4
|
63
vendor/swiss-payment-slip/swiss-payment-slip/composer.json
vendored
Normal file
63
vendor/swiss-payment-slip/swiss-payment-slip/composer.json
vendored
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
{
|
||||||
|
"name": "swiss-payment-slip/swiss-payment-slip",
|
||||||
|
"description": "A library for creating Swiss payment slips (ESR)",
|
||||||
|
"license": "MIT",
|
||||||
|
"homepage": "https://github.com/ravage84/SwissPaymentSlip",
|
||||||
|
"keywords": [
|
||||||
|
"Payment slip",
|
||||||
|
"Inpayment slip",
|
||||||
|
"Einzahlungsschein",
|
||||||
|
"ESR"
|
||||||
|
],
|
||||||
|
"require": {
|
||||||
|
"php": ">=5.4.0"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"phpunit/phpunit": "^4.0.0",
|
||||||
|
"squizlabs/php_codesniffer": "^2.1.0"
|
||||||
|
},
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Marc Würth",
|
||||||
|
"email": "ravage@bluewin.ch",
|
||||||
|
"role": "Lead developer"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Manuel Reinhard",
|
||||||
|
"email": "manu@sprain.ch",
|
||||||
|
"homepage": "http://www.sprain.ch",
|
||||||
|
"role": "Developer of the original class"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Peter Siska",
|
||||||
|
"email": "pesche@gridonic.ch",
|
||||||
|
"homepage": "http://www.gridonic.ch",
|
||||||
|
"role": "Contributor"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"support": {
|
||||||
|
"email": "ravage@bluewin.ch",
|
||||||
|
"issues": "https://github.com/ravage84/SwissPaymentSlip/issues",
|
||||||
|
"source": "https://github.com/ravage84/SwissPaymentSlip"
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"SwissPaymentSlip\\SwissPaymentSlip\\": "src"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"autoload-dev": {
|
||||||
|
"psr-4": {
|
||||||
|
"SwissPaymentSlip\\SwissPaymentSlip\\Tests\\": "tests"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"test": "phpunit",
|
||||||
|
"check-codestyle": "phpcs -p --standard=PSR2 --runtime-set ignore_errors_on_exit 1 --runtime-set ignore_warnings_on_exit 1 src tests examples",
|
||||||
|
"fix-codestyle": "phpcbf -p --standard=PSR2 --runtime-set ignore_errors_on_exit 1 --runtime-set ignore_warnings_on_exit 1 src tests examples"
|
||||||
|
},
|
||||||
|
"config": {
|
||||||
|
"platform": {
|
||||||
|
"php": "5.4.0"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
1064
vendor/swiss-payment-slip/swiss-payment-slip/composer.lock
generated
vendored
Normal file
1064
vendor/swiss-payment-slip/swiss-payment-slip/composer.lock
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
44
vendor/symfony/polyfill-intl-idn/composer.json
vendored
Normal file
44
vendor/symfony/polyfill-intl-idn/composer.json
vendored
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
{
|
||||||
|
"name": "symfony/polyfill-intl-idn",
|
||||||
|
"type": "library",
|
||||||
|
"description": "Symfony polyfill for intl's idn_to_ascii and idn_to_utf8 functions",
|
||||||
|
"keywords": ["polyfill", "shim", "compatibility", "portable", "intl", "idn"],
|
||||||
|
"homepage": "https://symfony.com",
|
||||||
|
"license": "MIT",
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Laurent Bassin",
|
||||||
|
"email": "laurent@bassin.info"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Trevor Rowbotham",
|
||||||
|
"email": "trevor.rowbotham@pm.me"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Symfony Community",
|
||||||
|
"homepage": "https://symfony.com/contributors"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"require": {
|
||||||
|
"php": ">=7.1",
|
||||||
|
"symfony/polyfill-intl-normalizer": "^1.10",
|
||||||
|
"symfony/polyfill-php72": "^1.10"
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": { "Symfony\\Polyfill\\Intl\\Idn\\": "" },
|
||||||
|
"files": [ "bootstrap.php" ]
|
||||||
|
},
|
||||||
|
"suggest": {
|
||||||
|
"ext-intl": "For best performance"
|
||||||
|
},
|
||||||
|
"minimum-stability": "dev",
|
||||||
|
"extra": {
|
||||||
|
"branch-alias": {
|
||||||
|
"dev-main": "1.22-dev"
|
||||||
|
},
|
||||||
|
"thanks": {
|
||||||
|
"name": "symfony/polyfill",
|
||||||
|
"url": "https://github.com/symfony/polyfill"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -2,19 +2,49 @@
|
|||||||
//
|
//
|
||||||
// SPDX-License-Identifier: AGPL-3.0-only
|
// SPDX-License-Identifier: AGPL-3.0-only
|
||||||
|
|
||||||
import glob from 'glob';
|
import {globSync} from 'glob';
|
||||||
import path from 'path';
|
import * as path from 'path';
|
||||||
import vue from '@vitejs/plugin-vue';
|
import vue from '@vitejs/plugin-vue';
|
||||||
|
|
||||||
const moduleInputs = glob.sync('classes/Modules/*/www/js/entry.{js,jsx}')
|
const globpattern = [
|
||||||
.map(file => ['modules/'+file.split('/')[2], file]);
|
'classes/Modules/*/www/js/?(*.)entry.{js,ts}',
|
||||||
|
'www/themes/*/js/?(*.)entry.{js,ts}'
|
||||||
|
];
|
||||||
|
|
||||||
|
const inputs = globSync(globpattern)
|
||||||
|
.map(file => {
|
||||||
|
const regex = /(?<prefix>themes|Modules)\/(?<name>\w+)\/(\w+\/)*((?<entry>\w+)\.)?entry\.(js|ts)$/;
|
||||||
|
const match = file.match(regex);
|
||||||
|
console.log(match);
|
||||||
|
let entryname = file;
|
||||||
|
if (match) {
|
||||||
|
entryname = [match.groups.prefix.toLowerCase(), match.groups.name].join('/');
|
||||||
|
if (match.groups.entry && match.groups.entry.toLowerCase() !== match.groups.name.toLowerCase())
|
||||||
|
entryname += '-'+match.groups.entry;
|
||||||
|
}
|
||||||
|
return [entryname, file];
|
||||||
|
})
|
||||||
|
|
||||||
/** @type {import('vite').UserConfig} */
|
/** @type {import('vite').UserConfig} */
|
||||||
export default {
|
export default {
|
||||||
build: {
|
build: {
|
||||||
rollupOptions: {
|
rollupOptions: {
|
||||||
input: {
|
input: {
|
||||||
...Object.fromEntries(moduleInputs)
|
...Object.fromEntries(inputs)
|
||||||
|
},
|
||||||
|
output: {
|
||||||
|
assetFileNames: function(assetInfo) {
|
||||||
|
console.log(assetInfo);
|
||||||
|
return 'assets/[name]-[hash][extname]';
|
||||||
|
},
|
||||||
|
entryFileNames: function(chunkInfo) {
|
||||||
|
console.log(chunkInfo);
|
||||||
|
return '[name]-[hash].js';
|
||||||
|
},
|
||||||
|
chunkFileNames: function (chunkInfo) {
|
||||||
|
console.log(chunkInfo);
|
||||||
|
return '[name]-[hash].js';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
manifest: true,
|
manifest: true,
|
||||||
|
@ -1,19 +0,0 @@
|
|||||||
const mix = require('laravel-mix');
|
|
||||||
|
|
||||||
/*
|
|
||||||
|--------------------------------------------------------------------------
|
|
||||||
| Mix Asset Management
|
|
||||||
|--------------------------------------------------------------------------
|
|
||||||
|
|
|
||||||
| Mix provides a clean, fluent API for defining some Webpack build steps
|
|
||||||
| for your Laravel application. By default, we are compiling the Sass
|
|
||||||
| file for the application as well as bundling up all the JS files.
|
|
||||||
|
|
|
||||||
*/
|
|
||||||
|
|
||||||
mix.setPublicPath('www')
|
|
||||||
.copy([
|
|
||||||
'node_modules/vue/dist/vue.min.js',
|
|
||||||
'node_modules/vue/dist/vue.js'
|
|
||||||
],
|
|
||||||
'www/js/lib');
|
|
11
www/dist/.vite/manifest.json
vendored
Normal file
11
www/dist/.vite/manifest.json
vendored
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
{
|
||||||
|
"classes/Modules/MatrixProduct/www/js/entry.js": {
|
||||||
|
"file": "modules/MatrixProduct-Cmg6dHLU.js",
|
||||||
|
"name": "modules/MatrixProduct",
|
||||||
|
"src": "classes/Modules/MatrixProduct/www/js/entry.js",
|
||||||
|
"isEntry": true,
|
||||||
|
"css": [
|
||||||
|
"assets/MatrixProduct-DCtGag1V.css"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
1
www/dist/assets/MatrixProduct-DCtGag1V.css
vendored
Normal file
1
www/dist/assets/MatrixProduct-DCtGag1V.css
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
.vueAction{cursor:pointer}.flex{display:flex}.grid{display:grid}.flex-align-center{align-items:center}.justify-self-start{justify-self:start}.gap-1{gap:.25rem}.grid label,.grid .p-checkbox{padding-top:5px}
|
1
www/dist/assets/entry-078d65ea.css
vendored
1
www/dist/assets/entry-078d65ea.css
vendored
File diff suppressed because one or more lines are too long
1031
www/dist/assets/modules/MatrixProduct-2b98726c.js
vendored
1031
www/dist/assets/modules/MatrixProduct-2b98726c.js
vendored
File diff suppressed because one or more lines are too long
14
www/dist/manifest.json
vendored
14
www/dist/manifest.json
vendored
@ -1,14 +0,0 @@
|
|||||||
{
|
|
||||||
"classes/Modules/MatrixProduct/www/js/entry.css": {
|
|
||||||
"file": "assets/entry-078d65ea.css",
|
|
||||||
"src": "classes/Modules/MatrixProduct/www/js/entry.css"
|
|
||||||
},
|
|
||||||
"classes/Modules/MatrixProduct/www/js/entry.jsx": {
|
|
||||||
"css": [
|
|
||||||
"assets/entry-078d65ea.css"
|
|
||||||
],
|
|
||||||
"file": "assets/modules/MatrixProduct-2b98726c.js",
|
|
||||||
"isEntry": true,
|
|
||||||
"src": "classes/Modules/MatrixProduct/www/js/entry.jsx"
|
|
||||||
}
|
|
||||||
}
|
|
2243
www/dist/modules/MatrixProduct-Cmg6dHLU.js
vendored
Normal file
2243
www/dist/modules/MatrixProduct-Cmg6dHLU.js
vendored
Normal file
File diff suppressed because one or more lines are too long
@ -323,50 +323,6 @@ class erpooSystem extends Application
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$isTestlizenz = !empty(erpAPI::Ioncube_Property('testlizenz'));
|
|
||||||
$isCloud = erpAPI::Ioncube_Property('iscloud');
|
|
||||||
$isDemo = $isTestlizenz && $isCloud;
|
|
||||||
$activateDoubleClick = false;
|
|
||||||
/** @var Dataprotection $dataProtectionModule */
|
|
||||||
$dataProtectionModule = $this->loadModule('dataprotection');
|
|
||||||
|
|
||||||
if($isCloud
|
|
||||||
&& $dataProtectionModule !== null
|
|
||||||
&& $dataProtectionModule->isGoogleAnalyticsActive()
|
|
||||||
){
|
|
||||||
$activateDoubleClick = true;
|
|
||||||
$this->Tpl->Add(
|
|
||||||
'SCRIPTJAVASCRIPT',
|
|
||||||
'<!-- Global site tag (gtag.js) - Google Analytics -->
|
|
||||||
<script async src="https://www.googletagmanager.com/gtag/js?id=UA-1088253-14"></script>
|
|
||||||
<script>
|
|
||||||
window.dataLayer = window.dataLayer || [];
|
|
||||||
function gtag(){dataLayer.push(arguments);}
|
|
||||||
gtag(\'js\', new Date());
|
|
||||||
|
|
||||||
gtag(\'config\', \'UA-1088253-14\');
|
|
||||||
</script>');
|
|
||||||
|
|
||||||
$this->Tpl->Add('ADDITIONALCSPHEADER', ' www.googletagmanager.com www.google-analytics.com ssl.google-analytics.com stats.g.doubleclick.net ');
|
|
||||||
}
|
|
||||||
if($dataProtectionModule !== null && $dataProtectionModule->isHubspotActive()) {
|
|
||||||
$activateDoubleClick = true;
|
|
||||||
$this->Tpl->Add(
|
|
||||||
'SCRIPTJAVASCRIPT',
|
|
||||||
'<script type="text/javascript" id="hs-script-loader" async defer src="//js.hs-scripts.com/6748263.js"></script>'
|
|
||||||
);
|
|
||||||
$this->Tpl->Add(
|
|
||||||
'ADDITIONALCSPHEADER',
|
|
||||||
' js.hs-scripts.com js.hscollectedforms.net js.hsleadflows.net js.hs-banner.com js.hs-analytics.net api.hubapi.com js.hsadspixel.net '
|
|
||||||
);
|
|
||||||
$this->Tpl->Add(
|
|
||||||
'ADDITIONALCSPHEADER',
|
|
||||||
'forms.hubspot.com forms.hsforms.com track.hubspot.com www.google.com www.google.de '
|
|
||||||
);
|
|
||||||
}
|
|
||||||
if($activateDoubleClick) {
|
|
||||||
$this->Tpl->Add('ADDITIONALCSPHEADER', ' googleads.g.doubleclick.net ' );
|
|
||||||
}
|
|
||||||
$hooktpl = 'JSSCRIPTS';
|
$hooktpl = 'JSSCRIPTS';
|
||||||
$this->erp->RunHook('eproosystem_ende', 1, $hooktpl);
|
$this->erp->RunHook('eproosystem_ende', 1, $hooktpl);
|
||||||
}
|
}
|
||||||
@ -468,13 +424,6 @@ class erpooSystem extends Application
|
|||||||
];*/
|
];*/
|
||||||
|
|
||||||
|
|
||||||
if(!empty(erpAPI::Ioncube_Property('testlizenz')) && $this->User->GetType() === 'admin'){
|
|
||||||
$possibleUserItems['Starte hier!'] = [
|
|
||||||
'link' => 'index.php?module=learningdashboard&action=list',
|
|
||||||
'type' => 'cta'
|
|
||||||
];
|
|
||||||
}
|
|
||||||
|
|
||||||
$userItems = '<div class="sidebar-list small-items separator-bottom">';
|
$userItems = '<div class="sidebar-list small-items separator-bottom">';
|
||||||
|
|
||||||
foreach($possibleUserItems as $title => $data){
|
foreach($possibleUserItems as $title => $data){
|
||||||
@ -545,10 +494,7 @@ class erpooSystem extends Application
|
|||||||
|
|
||||||
/** @var Dataprotection $obj */
|
/** @var Dataprotection $obj */
|
||||||
$obj = $this->loadModule('dataprotection');
|
$obj = $this->loadModule('dataprotection');
|
||||||
$showChat = method_exists('erpAPI','Ioncube_Property')
|
$showChat = $obj !== null
|
||||||
&& !empty(erpAPI::Ioncube_Property('chatactive'))
|
|
||||||
&& !empty(erpAPI::Ioncube_Property('chat'))
|
|
||||||
&& $obj !== null
|
|
||||||
&& method_exists($obj, 'isZenDeskActive')
|
&& method_exists($obj, 'isZenDeskActive')
|
||||||
&& $obj->isZenDeskActive();
|
&& $obj->isZenDeskActive();
|
||||||
|
|
||||||
@ -608,23 +554,8 @@ class erpooSystem extends Application
|
|||||||
$this->Tpl->Set('FIXEDITEMS', $fixedItems);
|
$this->Tpl->Set('FIXEDITEMS', $fixedItems);
|
||||||
$this->Tpl->Set('XENTRALVERSION', $version);
|
$this->Tpl->Set('XENTRALVERSION', $version);
|
||||||
$this->Tpl->Set('SIDEBAR_CLASSES', $sidebarClasses);
|
$this->Tpl->Set('SIDEBAR_CLASSES', $sidebarClasses);
|
||||||
$isDevelopmentVersion = method_exists('erpAPI','Ioncube_Property')
|
|
||||||
&& !empty(erpAPI::Ioncube_Property('isdevelopmentversion'));
|
|
||||||
if($isDevelopmentVersion) {
|
|
||||||
$this->Tpl->Add(
|
|
||||||
'SIDEBARLOGO',
|
|
||||||
@file_get_contents(__DIR__ . '/themes/new/templates/sidebar_development_version_logo.svg')
|
|
||||||
);
|
|
||||||
$this->Tpl->Add(
|
|
||||||
'SIDEBARLOGO',
|
|
||||||
'<img class="development" src="themes/new/templates/development_version_logo.png" alt="logo" />'
|
|
||||||
);
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
// $this->Tpl->Add('SIDEBARLOGO', @file_get_contents(__DIR__ . '/themes/new/templates/sidebar_logo.svg'));
|
|
||||||
$this->Tpl->Add('SIDEBARLOGO','<div class="sidebar_logo">'.@file_get_contents(__DIR__ . '/themes/new/templates/sidebar_logo.svg').'</div>');
|
$this->Tpl->Add('SIDEBARLOGO','<div class="sidebar_logo">'.@file_get_contents(__DIR__ . '/themes/new/templates/sidebar_logo.svg').'</div>');
|
||||||
$this->Tpl->Add('SIDEBARLOGO','<div class="sidebar_icon_logo">'.@file_get_contents(__DIR__ . '/themes/new/templates/sidebar_icon_logo.svg').'</div>');
|
$this->Tpl->Add('SIDEBARLOGO','<div class="sidebar_icon_logo">'.@file_get_contents(__DIR__ . '/themes/new/templates/sidebar_icon_logo.svg').'</div>');
|
||||||
}
|
|
||||||
|
|
||||||
$this->Tpl->Parse('SIDEBAR', 'sidebar.tpl');
|
$this->Tpl->Parse('SIDEBAR', 'sidebar.tpl');
|
||||||
$this->Tpl->Parse('PROFILE_MENU', 'profile_menu.tpl');
|
$this->Tpl->Parse('PROFILE_MENU', 'profile_menu.tpl');
|
||||||
@ -1342,41 +1273,6 @@ if (typeof document.hidden !== \"undefined\") { // Opera 12.10 and Firefox 18 an
|
|||||||
$this->erp->SetKonfigurationValue('eproosystem_skipcheckuserdata', '1');
|
$this->erp->SetKonfigurationValue('eproosystem_skipcheckuserdata', '1');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(!$this->erp->ServerOK()) {
|
|
||||||
$serverlist = $this->erp->GetIoncubeServerList();
|
|
||||||
if(method_exists($this->erp, 'setSystemHealth')) {
|
|
||||||
$this->erp->setSystemHealth(
|
|
||||||
'server',
|
|
||||||
'ioncube',
|
|
||||||
'error',
|
|
||||||
'Die Ioncube-Lizenz ist nur gültig für folgene'.
|
|
||||||
(count($serverlist) == 1?'n':'').' Server: '.implode(', ',$serverlist)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
$expDays = erpAPI::Ioncube_ExpireInDays();
|
|
||||||
$testLicence = erpAPI::Ioncube_Property('testlizenz');
|
|
||||||
if(!$testLicence && $expDays !== false && $expDays < 14) {
|
|
||||||
$this->erp->setSystemHealth(
|
|
||||||
'server',
|
|
||||||
'ioncube',
|
|
||||||
'error',
|
|
||||||
sprintf(
|
|
||||||
'Die Lizenz am %s aus.',
|
|
||||||
erpAPI::Ioncube_ExpireDate()
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
$this->erp->setSystemHealth(
|
|
||||||
'server',
|
|
||||||
'ioncube',
|
|
||||||
'ok',
|
|
||||||
''
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($this->ModuleScriptCache->IsCacheDirWritable() === false) {
|
if ($this->ModuleScriptCache->IsCacheDirWritable() === false) {
|
||||||
$this->erp->setSystemHealth(
|
$this->erp->setSystemHealth(
|
||||||
'server',
|
'server',
|
||||||
@ -1823,21 +1719,6 @@ if (typeof document.hidden !== \"undefined\") { // Opera 12.10 and Firefox 18 an
|
|||||||
$this->Tpl->Set('NACHCHATNACHRICHTENBOX','-->');
|
$this->Tpl->Set('NACHCHATNACHRICHTENBOX','-->');
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!empty(erpAPI::Ioncube_Property('testlizenz'))){
|
|
||||||
$upgradeButton = '<li id="upgrade-licence"><a href="./index.php?module=appstore&action=buy">'.
|
|
||||||
'<svg width="18" height="16" viewBox="0 0 18 16" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
||||||
<path d="M4.47287 12.0104C2.04566 9.80074 1.66708 6.11981 3.59372 3.46237C5.52036 0.804943 9.13654 0.0202146 11.9914 1.64005" stroke="white" stroke-linecap="round" stroke-linejoin="round"/>
|
|
||||||
<path d="M2.21273 11.9649C1.39377 13.3996 1.11966 14.513 1.58214 14.9761C2.2843 15.6776 4.48124 14.6858 7.02522 12.6684" stroke="white" stroke-linecap="round" stroke-linejoin="round"/>
|
|
||||||
<path fill-rule="evenodd" clip-rule="evenodd" d="M9.93719 12.1581L7.52014 9.74109L12.8923 4.3689C13.3305 3.93091 13.8797 3.62049 14.481 3.47095L15.863 3.12392C16.0571 3.07558 16.2623 3.1325 16.4037 3.27392C16.5451 3.41534 16.602 3.62054 16.5537 3.8146L16.208 5.19732C16.0578 5.7984 15.7469 6.34731 15.3087 6.78527L9.93719 12.1581Z" stroke="white" stroke-linecap="round" stroke-linejoin="round"/>
|
|
||||||
<path fill-rule="evenodd" clip-rule="evenodd" d="M7.51976 9.7409L5.54021 9.08128C5.44619 9.05019 5.37505 8.97252 5.35233 8.87613C5.32961 8.77974 5.35857 8.67847 5.42881 8.60867L6.11882 7.91866C6.7306 7.30697 7.63548 7.09343 8.45619 7.36706L9.53644 7.72625L7.51976 9.7409Z" stroke="white" stroke-linecap="round" stroke-linejoin="round"/>
|
|
||||||
<path fill-rule="evenodd" clip-rule="evenodd" d="M9.93713 12.1584L10.5968 14.1386C10.6278 14.2326 10.7055 14.3038 10.8019 14.3265C10.8983 14.3492 10.9996 14.3203 11.0694 14.25L11.7594 13.56C12.3711 12.9482 12.5846 12.0434 12.311 11.2226L11.9518 10.1424L9.93713 12.1584Z" stroke="white" stroke-linecap="round" stroke-linejoin="round"/>
|
|
||||||
</svg>
|
|
||||||
'.
|
|
||||||
'<span>Upgrade</span></a></li>';
|
|
||||||
|
|
||||||
$this->Tpl->Set('UPGRADELICENCECTA', $upgradeButton);
|
|
||||||
}
|
|
||||||
|
|
||||||
if(!$this->erp->ModulVorhanden('aufgaben') || !$this->erp->RechteVorhanden('aufgaben','list')) {
|
if(!$this->erp->ModulVorhanden('aufgaben') || !$this->erp->RechteVorhanden('aufgaben','list')) {
|
||||||
$this->Tpl->Set('AUFGABENVOR','<!--');
|
$this->Tpl->Set('AUFGABENVOR','<!--');
|
||||||
$this->Tpl->Set('AUFGABENNACH','-->');
|
$this->Tpl->Set('AUFGABENNACH','-->');
|
||||||
|
4
www/js/jquery-1.11.1.min.js
vendored
4
www/js/jquery-1.11.1.min.js
vendored
File diff suppressed because one or more lines are too long
5
www/js/jquery-1.12.4.min.js
vendored
5
www/js/jquery-1.12.4.min.js
vendored
File diff suppressed because one or more lines are too long
166
www/js/jquery-1.4.3.min.js
vendored
166
www/js/jquery-1.4.3.min.js
vendored
@ -1,166 +0,0 @@
|
|||||||
/*!
|
|
||||||
* jQuery JavaScript Library v1.4.3
|
|
||||||
* http://jquery.com/
|
|
||||||
*
|
|
||||||
* Copyright 2010, John Resig
|
|
||||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
|
||||||
* http://jquery.org/license
|
|
||||||
*
|
|
||||||
* Includes Sizzle.js
|
|
||||||
* http://sizzlejs.com/
|
|
||||||
* Copyright 2010, The Dojo Foundation
|
|
||||||
* Released under the MIT, BSD, and GPL Licenses.
|
|
||||||
*
|
|
||||||
* Date: Thu Oct 14 23:10:06 2010 -0400
|
|
||||||
*/
|
|
||||||
(function(E,A){function U(){return false}function ba(){return true}function ja(a,b,d){d[0].type=a;return c.event.handle.apply(b,d)}function Ga(a){var b,d,e=[],f=[],h,k,l,n,s,v,B,D;k=c.data(this,this.nodeType?"events":"__events__");if(typeof k==="function")k=k.events;if(!(a.liveFired===this||!k||!k.live||a.button&&a.type==="click")){if(a.namespace)D=RegExp("(^|\\.)"+a.namespace.split(".").join("\\.(?:.*\\.)?")+"(\\.|$)");a.liveFired=this;var H=k.live.slice(0);for(n=0;n<H.length;n++){k=H[n];k.origType.replace(X,
|
|
||||||
"")===a.type?f.push(k.selector):H.splice(n--,1)}f=c(a.target).closest(f,a.currentTarget);s=0;for(v=f.length;s<v;s++){B=f[s];for(n=0;n<H.length;n++){k=H[n];if(B.selector===k.selector&&(!D||D.test(k.namespace))){l=B.elem;h=null;if(k.preType==="mouseenter"||k.preType==="mouseleave"){a.type=k.preType;h=c(a.relatedTarget).closest(k.selector)[0]}if(!h||h!==l)e.push({elem:l,handleObj:k,level:B.level})}}}s=0;for(v=e.length;s<v;s++){f=e[s];if(d&&f.level>d)break;a.currentTarget=f.elem;a.data=f.handleObj.data;
|
|
||||||
a.handleObj=f.handleObj;D=f.handleObj.origHandler.apply(f.elem,arguments);if(D===false||a.isPropagationStopped()){d=f.level;if(D===false)b=false}}return b}}function Y(a,b){return(a&&a!=="*"?a+".":"")+b.replace(Ha,"`").replace(Ia,"&")}function ka(a,b,d){if(c.isFunction(b))return c.grep(a,function(f,h){return!!b.call(f,h,f)===d});else if(b.nodeType)return c.grep(a,function(f){return f===b===d});else if(typeof b==="string"){var e=c.grep(a,function(f){return f.nodeType===1});if(Ja.test(b))return c.filter(b,
|
|
||||||
e,!d);else b=c.filter(b,e)}return c.grep(a,function(f){return c.inArray(f,b)>=0===d})}function la(a,b){var d=0;b.each(function(){if(this.nodeName===(a[d]&&a[d].nodeName)){var e=c.data(a[d++]),f=c.data(this,e);if(e=e&&e.events){delete f.handle;f.events={};for(var h in e)for(var k in e[h])c.event.add(this,h,e[h][k],e[h][k].data)}}})}function Ka(a,b){b.src?c.ajax({url:b.src,async:false,dataType:"script"}):c.globalEval(b.text||b.textContent||b.innerHTML||"");b.parentNode&&b.parentNode.removeChild(b)}
|
|
||||||
function ma(a,b,d){var e=b==="width"?a.offsetWidth:a.offsetHeight;if(d==="border")return e;c.each(b==="width"?La:Ma,function(){d||(e-=parseFloat(c.css(a,"padding"+this))||0);if(d==="margin")e+=parseFloat(c.css(a,"margin"+this))||0;else e-=parseFloat(c.css(a,"border"+this+"Width"))||0});return e}function ca(a,b,d,e){if(c.isArray(b)&&b.length)c.each(b,function(f,h){d||Na.test(a)?e(a,h):ca(a+"["+(typeof h==="object"||c.isArray(h)?f:"")+"]",h,d,e)});else if(!d&&b!=null&&typeof b==="object")c.isEmptyObject(b)?
|
|
||||||
e(a,""):c.each(b,function(f,h){ca(a+"["+f+"]",h,d,e)});else e(a,b)}function S(a,b){var d={};c.each(na.concat.apply([],na.slice(0,b)),function(){d[this]=a});return d}function oa(a){if(!da[a]){var b=c("<"+a+">").appendTo("body"),d=b.css("display");b.remove();if(d==="none"||d==="")d="block";da[a]=d}return da[a]}function ea(a){return c.isWindow(a)?a:a.nodeType===9?a.defaultView||a.parentWindow:false}var u=E.document,c=function(){function a(){if(!b.isReady){try{u.documentElement.doScroll("left")}catch(i){setTimeout(a,
|
|
||||||
1);return}b.ready()}}var b=function(i,r){return new b.fn.init(i,r)},d=E.jQuery,e=E.$,f,h=/^(?:[^<]*(<[\w\W]+>)[^>]*$|#([\w\-]+)$)/,k=/\S/,l=/^\s+/,n=/\s+$/,s=/\W/,v=/\d/,B=/^<(\w+)\s*\/?>(?:<\/\1>)?$/,D=/^[\],:{}\s]*$/,H=/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g,w=/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g,G=/(?:^|:|,)(?:\s*\[)+/g,M=/(webkit)[ \/]([\w.]+)/,g=/(opera)(?:.*version)?[ \/]([\w.]+)/,j=/(msie) ([\w.]+)/,o=/(mozilla)(?:.*? rv:([\w.]+))?/,m=navigator.userAgent,p=false,
|
|
||||||
q=[],t,x=Object.prototype.toString,C=Object.prototype.hasOwnProperty,P=Array.prototype.push,N=Array.prototype.slice,R=String.prototype.trim,Q=Array.prototype.indexOf,L={};b.fn=b.prototype={init:function(i,r){var y,z,F;if(!i)return this;if(i.nodeType){this.context=this[0]=i;this.length=1;return this}if(i==="body"&&!r&&u.body){this.context=u;this[0]=u.body;this.selector="body";this.length=1;return this}if(typeof i==="string")if((y=h.exec(i))&&(y[1]||!r))if(y[1]){F=r?r.ownerDocument||r:u;if(z=B.exec(i))if(b.isPlainObject(r)){i=
|
|
||||||
[u.createElement(z[1])];b.fn.attr.call(i,r,true)}else i=[F.createElement(z[1])];else{z=b.buildFragment([y[1]],[F]);i=(z.cacheable?z.fragment.cloneNode(true):z.fragment).childNodes}return b.merge(this,i)}else{if((z=u.getElementById(y[2]))&&z.parentNode){if(z.id!==y[2])return f.find(i);this.length=1;this[0]=z}this.context=u;this.selector=i;return this}else if(!r&&!s.test(i)){this.selector=i;this.context=u;i=u.getElementsByTagName(i);return b.merge(this,i)}else return!r||r.jquery?(r||f).find(i):b(r).find(i);
|
|
||||||
else if(b.isFunction(i))return f.ready(i);if(i.selector!==A){this.selector=i.selector;this.context=i.context}return b.makeArray(i,this)},selector:"",jquery:"1.4.3",length:0,size:function(){return this.length},toArray:function(){return N.call(this,0)},get:function(i){return i==null?this.toArray():i<0?this.slice(i)[0]:this[i]},pushStack:function(i,r,y){var z=b();b.isArray(i)?P.apply(z,i):b.merge(z,i);z.prevObject=this;z.context=this.context;if(r==="find")z.selector=this.selector+(this.selector?" ":
|
|
||||||
"")+y;else if(r)z.selector=this.selector+"."+r+"("+y+")";return z},each:function(i,r){return b.each(this,i,r)},ready:function(i){b.bindReady();if(b.isReady)i.call(u,b);else q&&q.push(i);return this},eq:function(i){return i===-1?this.slice(i):this.slice(i,+i+1)},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},slice:function(){return this.pushStack(N.apply(this,arguments),"slice",N.call(arguments).join(","))},map:function(i){return this.pushStack(b.map(this,function(r,y){return i.call(r,
|
|
||||||
y,r)}))},end:function(){return this.prevObject||b(null)},push:P,sort:[].sort,splice:[].splice};b.fn.init.prototype=b.fn;b.extend=b.fn.extend=function(){var i=arguments[0]||{},r=1,y=arguments.length,z=false,F,I,K,J,fa;if(typeof i==="boolean"){z=i;i=arguments[1]||{};r=2}if(typeof i!=="object"&&!b.isFunction(i))i={};if(y===r){i=this;--r}for(;r<y;r++)if((F=arguments[r])!=null)for(I in F){K=i[I];J=F[I];if(i!==J)if(z&&J&&(b.isPlainObject(J)||(fa=b.isArray(J)))){if(fa){fa=false;clone=K&&b.isArray(K)?K:[]}else clone=
|
|
||||||
K&&b.isPlainObject(K)?K:{};i[I]=b.extend(z,clone,J)}else if(J!==A)i[I]=J}return i};b.extend({noConflict:function(i){E.$=e;if(i)E.jQuery=d;return b},isReady:false,readyWait:1,ready:function(i){i===true&&b.readyWait--;if(!b.readyWait||i!==true&&!b.isReady){if(!u.body)return setTimeout(b.ready,1);b.isReady=true;if(!(i!==true&&--b.readyWait>0)){if(q){for(var r=0;i=q[r++];)i.call(u,b);q=null}b.fn.triggerHandler&&b(u).triggerHandler("ready")}}},bindReady:function(){if(!p){p=true;if(u.readyState==="complete")return setTimeout(b.ready,
|
|
||||||
1);if(u.addEventListener){u.addEventListener("DOMContentLoaded",t,false);E.addEventListener("load",b.ready,false)}else if(u.attachEvent){u.attachEvent("onreadystatechange",t);E.attachEvent("onload",b.ready);var i=false;try{i=E.frameElement==null}catch(r){}u.documentElement.doScroll&&i&&a()}}},isFunction:function(i){return b.type(i)==="function"},isArray:Array.isArray||function(i){return b.type(i)==="array"},isWindow:function(i){return i&&typeof i==="object"&&"setInterval"in i},isNaN:function(i){return i==
|
|
||||||
null||!v.test(i)||isNaN(i)},type:function(i){return i==null?String(i):L[x.call(i)]||"object"},isPlainObject:function(i){if(!i||b.type(i)!=="object"||i.nodeType||b.isWindow(i))return false;if(i.constructor&&!C.call(i,"constructor")&&!C.call(i.constructor.prototype,"isPrototypeOf"))return false;for(var r in i);return r===A||C.call(i,r)},isEmptyObject:function(i){for(var r in i)return false;return true},error:function(i){throw i;},parseJSON:function(i){if(typeof i!=="string"||!i)return null;i=b.trim(i);
|
|
||||||
if(D.test(i.replace(H,"@").replace(w,"]").replace(G,"")))return E.JSON&&E.JSON.parse?E.JSON.parse(i):(new Function("return "+i))();else b.error("Invalid JSON: "+i)},noop:function(){},globalEval:function(i){if(i&&k.test(i)){var r=u.getElementsByTagName("head")[0]||u.documentElement,y=u.createElement("script");y.type="text/javascript";if(b.support.scriptEval)y.appendChild(u.createTextNode(i));else y.text=i;r.insertBefore(y,r.firstChild);r.removeChild(y)}},nodeName:function(i,r){return i.nodeName&&i.nodeName.toUpperCase()===
|
|
||||||
r.toUpperCase()},each:function(i,r,y){var z,F=0,I=i.length,K=I===A||b.isFunction(i);if(y)if(K)for(z in i){if(r.apply(i[z],y)===false)break}else for(;F<I;){if(r.apply(i[F++],y)===false)break}else if(K)for(z in i){if(r.call(i[z],z,i[z])===false)break}else for(y=i[0];F<I&&r.call(y,F,y)!==false;y=i[++F]);return i},trim:R?function(i){return i==null?"":R.call(i)}:function(i){return i==null?"":i.toString().replace(l,"").replace(n,"")},makeArray:function(i,r){var y=r||[];if(i!=null){var z=b.type(i);i.length==
|
|
||||||
null||z==="string"||z==="function"||z==="regexp"||b.isWindow(i)?P.call(y,i):b.merge(y,i)}return y},inArray:function(i,r){if(r.indexOf)return r.indexOf(i);for(var y=0,z=r.length;y<z;y++)if(r[y]===i)return y;return-1},merge:function(i,r){var y=i.length,z=0;if(typeof r.length==="number")for(var F=r.length;z<F;z++)i[y++]=r[z];else for(;r[z]!==A;)i[y++]=r[z++];i.length=y;return i},grep:function(i,r,y){var z=[],F;y=!!y;for(var I=0,K=i.length;I<K;I++){F=!!r(i[I],I);y!==F&&z.push(i[I])}return z},map:function(i,
|
|
||||||
r,y){for(var z=[],F,I=0,K=i.length;I<K;I++){F=r(i[I],I,y);if(F!=null)z[z.length]=F}return z.concat.apply([],z)},guid:1,proxy:function(i,r,y){if(arguments.length===2)if(typeof r==="string"){y=i;i=y[r];r=A}else if(r&&!b.isFunction(r)){y=r;r=A}if(!r&&i)r=function(){return i.apply(y||this,arguments)};if(i)r.guid=i.guid=i.guid||r.guid||b.guid++;return r},access:function(i,r,y,z,F,I){var K=i.length;if(typeof r==="object"){for(var J in r)b.access(i,J,r[J],z,F,y);return i}if(y!==A){z=!I&&z&&b.isFunction(y);
|
|
||||||
for(J=0;J<K;J++)F(i[J],r,z?y.call(i[J],J,F(i[J],r)):y,I);return i}return K?F(i[0],r):A},now:function(){return(new Date).getTime()},uaMatch:function(i){i=i.toLowerCase();i=M.exec(i)||g.exec(i)||j.exec(i)||i.indexOf("compatible")<0&&o.exec(i)||[];return{browser:i[1]||"",version:i[2]||"0"}},browser:{}});b.each("Boolean Number String Function Array Date RegExp Object".split(" "),function(i,r){L["[object "+r+"]"]=r.toLowerCase()});m=b.uaMatch(m);if(m.browser){b.browser[m.browser]=true;b.browser.version=
|
|
||||||
m.version}if(b.browser.webkit)b.browser.safari=true;if(Q)b.inArray=function(i,r){return Q.call(r,i)};if(!/\s/.test("\u00a0")){l=/^[\s\xA0]+/;n=/[\s\xA0]+$/}f=b(u);if(u.addEventListener)t=function(){u.removeEventListener("DOMContentLoaded",t,false);b.ready()};else if(u.attachEvent)t=function(){if(u.readyState==="complete"){u.detachEvent("onreadystatechange",t);b.ready()}};return E.jQuery=E.$=b}();(function(){c.support={};var a=u.documentElement,b=u.createElement("script"),d=u.createElement("div"),
|
|
||||||
e="script"+c.now();d.style.display="none";d.innerHTML=" <link/><table></table><a href='/a' style='color:red;float:left;opacity:.55;'>a</a><input type='checkbox'/>";var f=d.getElementsByTagName("*"),h=d.getElementsByTagName("a")[0],k=u.createElement("select"),l=k.appendChild(u.createElement("option"));if(!(!f||!f.length||!h)){c.support={leadingWhitespace:d.firstChild.nodeType===3,tbody:!d.getElementsByTagName("tbody").length,htmlSerialize:!!d.getElementsByTagName("link").length,style:/red/.test(h.getAttribute("style")),
|
|
||||||
hrefNormalized:h.getAttribute("href")==="/a",opacity:/^0.55$/.test(h.style.opacity),cssFloat:!!h.style.cssFloat,checkOn:d.getElementsByTagName("input")[0].value==="on",optSelected:l.selected,optDisabled:false,checkClone:false,scriptEval:false,noCloneEvent:true,boxModel:null,inlineBlockNeedsLayout:false,shrinkWrapBlocks:false,reliableHiddenOffsets:true};k.disabled=true;c.support.optDisabled=!l.disabled;b.type="text/javascript";try{b.appendChild(u.createTextNode("window."+e+"=1;"))}catch(n){}a.insertBefore(b,
|
|
||||||
a.firstChild);if(E[e]){c.support.scriptEval=true;delete E[e]}a.removeChild(b);if(d.attachEvent&&d.fireEvent){d.attachEvent("onclick",function s(){c.support.noCloneEvent=false;d.detachEvent("onclick",s)});d.cloneNode(true).fireEvent("onclick")}d=u.createElement("div");d.innerHTML="<input type='radio' name='radiotest' checked='checked'/>";a=u.createDocumentFragment();a.appendChild(d.firstChild);c.support.checkClone=a.cloneNode(true).cloneNode(true).lastChild.checked;c(function(){var s=u.createElement("div");
|
|
||||||
s.style.width=s.style.paddingLeft="1px";u.body.appendChild(s);c.boxModel=c.support.boxModel=s.offsetWidth===2;if("zoom"in s.style){s.style.display="inline";s.style.zoom=1;c.support.inlineBlockNeedsLayout=s.offsetWidth===2;s.style.display="";s.innerHTML="<div style='width:4px;'></div>";c.support.shrinkWrapBlocks=s.offsetWidth!==2}s.innerHTML="<table><tr><td style='padding:0;display:none'></td><td>t</td></tr></table>";var v=s.getElementsByTagName("td");c.support.reliableHiddenOffsets=v[0].offsetHeight===
|
|
||||||
0;v[0].style.display="";v[1].style.display="none";c.support.reliableHiddenOffsets=c.support.reliableHiddenOffsets&&v[0].offsetHeight===0;s.innerHTML="";u.body.removeChild(s).style.display="none"});a=function(s){var v=u.createElement("div");s="on"+s;var B=s in v;if(!B){v.setAttribute(s,"return;");B=typeof v[s]==="function"}return B};c.support.submitBubbles=a("submit");c.support.changeBubbles=a("change");a=b=d=f=h=null}})();c.props={"for":"htmlFor","class":"className",readonly:"readOnly",maxlength:"maxLength",
|
|
||||||
cellspacing:"cellSpacing",rowspan:"rowSpan",colspan:"colSpan",tabindex:"tabIndex",usemap:"useMap",frameborder:"frameBorder"};var pa={},Oa=/^(?:\{.*\}|\[.*\])$/;c.extend({cache:{},uuid:0,expando:"jQuery"+c.now(),noData:{embed:true,object:"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000",applet:true},data:function(a,b,d){if(c.acceptData(a)){a=a==E?pa:a;var e=a.nodeType,f=e?a[c.expando]:null,h=c.cache;if(!(e&&!f&&typeof b==="string"&&d===A)){if(e)f||(a[c.expando]=f=++c.uuid);else h=a;if(typeof b==="object")if(e)h[f]=
|
|
||||||
c.extend(h[f],b);else c.extend(h,b);else if(e&&!h[f])h[f]={};a=e?h[f]:h;if(d!==A)a[b]=d;return typeof b==="string"?a[b]:a}}},removeData:function(a,b){if(c.acceptData(a)){a=a==E?pa:a;var d=a.nodeType,e=d?a[c.expando]:a,f=c.cache,h=d?f[e]:e;if(b){if(h){delete h[b];d&&c.isEmptyObject(h)&&c.removeData(a)}}else if(d&&c.support.deleteExpando)delete a[c.expando];else if(a.removeAttribute)a.removeAttribute(c.expando);else if(d)delete f[e];else for(var k in a)delete a[k]}},acceptData:function(a){if(a.nodeName){var b=
|
|
||||||
c.noData[a.nodeName.toLowerCase()];if(b)return!(b===true||a.getAttribute("classid")!==b)}return true}});c.fn.extend({data:function(a,b){if(typeof a==="undefined")return this.length?c.data(this[0]):null;else if(typeof a==="object")return this.each(function(){c.data(this,a)});var d=a.split(".");d[1]=d[1]?"."+d[1]:"";if(b===A){var e=this.triggerHandler("getData"+d[1]+"!",[d[0]]);if(e===A&&this.length){e=c.data(this[0],a);if(e===A&&this[0].nodeType===1){e=this[0].getAttribute("data-"+a);if(typeof e===
|
|
||||||
"string")try{e=e==="true"?true:e==="false"?false:e==="null"?null:!c.isNaN(e)?parseFloat(e):Oa.test(e)?c.parseJSON(e):e}catch(f){}else e=A}}return e===A&&d[1]?this.data(d[0]):e}else return this.each(function(){var h=c(this),k=[d[0],b];h.triggerHandler("setData"+d[1]+"!",k);c.data(this,a,b);h.triggerHandler("changeData"+d[1]+"!",k)})},removeData:function(a){return this.each(function(){c.removeData(this,a)})}});c.extend({queue:function(a,b,d){if(a){b=(b||"fx")+"queue";var e=c.data(a,b);if(!d)return e||
|
|
||||||
[];if(!e||c.isArray(d))e=c.data(a,b,c.makeArray(d));else e.push(d);return e}},dequeue:function(a,b){b=b||"fx";var d=c.queue(a,b),e=d.shift();if(e==="inprogress")e=d.shift();if(e){b==="fx"&&d.unshift("inprogress");e.call(a,function(){c.dequeue(a,b)})}}});c.fn.extend({queue:function(a,b){if(typeof a!=="string"){b=a;a="fx"}if(b===A)return c.queue(this[0],a);return this.each(function(){var d=c.queue(this,a,b);a==="fx"&&d[0]!=="inprogress"&&c.dequeue(this,a)})},dequeue:function(a){return this.each(function(){c.dequeue(this,
|
|
||||||
a)})},delay:function(a,b){a=c.fx?c.fx.speeds[a]||a:a;b=b||"fx";return this.queue(b,function(){var d=this;setTimeout(function(){c.dequeue(d,b)},a)})},clearQueue:function(a){return this.queue(a||"fx",[])}});var qa=/[\n\t]/g,ga=/\s+/,Pa=/\r/g,Qa=/^(?:href|src|style)$/,Ra=/^(?:button|input)$/i,Sa=/^(?:button|input|object|select|textarea)$/i,Ta=/^a(?:rea)?$/i,ra=/^(?:radio|checkbox)$/i;c.fn.extend({attr:function(a,b){return c.access(this,a,b,true,c.attr)},removeAttr:function(a){return this.each(function(){c.attr(this,
|
|
||||||
a,"");this.nodeType===1&&this.removeAttribute(a)})},addClass:function(a){if(c.isFunction(a))return this.each(function(s){var v=c(this);v.addClass(a.call(this,s,v.attr("class")))});if(a&&typeof a==="string")for(var b=(a||"").split(ga),d=0,e=this.length;d<e;d++){var f=this[d];if(f.nodeType===1)if(f.className){for(var h=" "+f.className+" ",k=f.className,l=0,n=b.length;l<n;l++)if(h.indexOf(" "+b[l]+" ")<0)k+=" "+b[l];f.className=c.trim(k)}else f.className=a}return this},removeClass:function(a){if(c.isFunction(a))return this.each(function(n){var s=
|
|
||||||
c(this);s.removeClass(a.call(this,n,s.attr("class")))});if(a&&typeof a==="string"||a===A)for(var b=(a||"").split(ga),d=0,e=this.length;d<e;d++){var f=this[d];if(f.nodeType===1&&f.className)if(a){for(var h=(" "+f.className+" ").replace(qa," "),k=0,l=b.length;k<l;k++)h=h.replace(" "+b[k]+" "," ");f.className=c.trim(h)}else f.className=""}return this},toggleClass:function(a,b){var d=typeof a,e=typeof b==="boolean";if(c.isFunction(a))return this.each(function(f){var h=c(this);h.toggleClass(a.call(this,
|
|
||||||
f,h.attr("class"),b),b)});return this.each(function(){if(d==="string")for(var f,h=0,k=c(this),l=b,n=a.split(ga);f=n[h++];){l=e?l:!k.hasClass(f);k[l?"addClass":"removeClass"](f)}else if(d==="undefined"||d==="boolean"){this.className&&c.data(this,"__className__",this.className);this.className=this.className||a===false?"":c.data(this,"__className__")||""}})},hasClass:function(a){a=" "+a+" ";for(var b=0,d=this.length;b<d;b++)if((" "+this[b].className+" ").replace(qa," ").indexOf(a)>-1)return true;return false},
|
|
||||||
val:function(a){if(!arguments.length){var b=this[0];if(b){if(c.nodeName(b,"option")){var d=b.attributes.value;return!d||d.specified?b.value:b.text}if(c.nodeName(b,"select")){var e=b.selectedIndex;d=[];var f=b.options;b=b.type==="select-one";if(e<0)return null;var h=b?e:0;for(e=b?e+1:f.length;h<e;h++){var k=f[h];if(k.selected&&(c.support.optDisabled?!k.disabled:k.getAttribute("disabled")===null)&&(!k.parentNode.disabled||!c.nodeName(k.parentNode,"optgroup"))){a=c(k).val();if(b)return a;d.push(a)}}return d}if(ra.test(b.type)&&
|
|
||||||
!c.support.checkOn)return b.getAttribute("value")===null?"on":b.value;return(b.value||"").replace(Pa,"")}return A}var l=c.isFunction(a);return this.each(function(n){var s=c(this),v=a;if(this.nodeType===1){if(l)v=a.call(this,n,s.val());if(v==null)v="";else if(typeof v==="number")v+="";else if(c.isArray(v))v=c.map(v,function(D){return D==null?"":D+""});if(c.isArray(v)&&ra.test(this.type))this.checked=c.inArray(s.val(),v)>=0;else if(c.nodeName(this,"select")){var B=c.makeArray(v);c("option",this).each(function(){this.selected=
|
|
||||||
c.inArray(c(this).val(),B)>=0});if(!B.length)this.selectedIndex=-1}else this.value=v}})}});c.extend({attrFn:{val:true,css:true,html:true,text:true,data:true,width:true,height:true,offset:true},attr:function(a,b,d,e){if(!a||a.nodeType===3||a.nodeType===8)return A;if(e&&b in c.attrFn)return c(a)[b](d);e=a.nodeType!==1||!c.isXMLDoc(a);var f=d!==A;b=e&&c.props[b]||b;if(a.nodeType===1){var h=Qa.test(b);if((b in a||a[b]!==A)&&e&&!h){if(f){b==="type"&&Ra.test(a.nodeName)&&a.parentNode&&c.error("type property can't be changed");
|
|
||||||
if(d===null)a.nodeType===1&&a.removeAttribute(b);else a[b]=d}if(c.nodeName(a,"form")&&a.getAttributeNode(b))return a.getAttributeNode(b).nodeValue;if(b==="tabIndex")return(b=a.getAttributeNode("tabIndex"))&&b.specified?b.value:Sa.test(a.nodeName)||Ta.test(a.nodeName)&&a.href?0:A;return a[b]}if(!c.support.style&&e&&b==="style"){if(f)a.style.cssText=""+d;return a.style.cssText}f&&a.setAttribute(b,""+d);if(!a.attributes[b]&&a.hasAttribute&&!a.hasAttribute(b))return A;a=!c.support.hrefNormalized&&e&&
|
|
||||||
h?a.getAttribute(b,2):a.getAttribute(b);return a===null?A:a}}});var X=/\.(.*)$/,ha=/^(?:textarea|input|select)$/i,Ha=/\./g,Ia=/ /g,Ua=/[^\w\s.|`]/g,Va=function(a){return a.replace(Ua,"\\$&")},sa={focusin:0,focusout:0};c.event={add:function(a,b,d,e){if(!(a.nodeType===3||a.nodeType===8)){if(c.isWindow(a)&&a!==E&&!a.frameElement)a=E;if(d===false)d=U;var f,h;if(d.handler){f=d;d=f.handler}if(!d.guid)d.guid=c.guid++;if(h=c.data(a)){var k=a.nodeType?"events":"__events__",l=h[k],n=h.handle;if(typeof l===
|
|
||||||
"function"){n=l.handle;l=l.events}else if(!l){a.nodeType||(h[k]=h=function(){});h.events=l={}}if(!n)h.handle=n=function(){return typeof c!=="undefined"&&!c.event.triggered?c.event.handle.apply(n.elem,arguments):A};n.elem=a;b=b.split(" ");for(var s=0,v;k=b[s++];){h=f?c.extend({},f):{handler:d,data:e};if(k.indexOf(".")>-1){v=k.split(".");k=v.shift();h.namespace=v.slice(0).sort().join(".")}else{v=[];h.namespace=""}h.type=k;if(!h.guid)h.guid=d.guid;var B=l[k],D=c.event.special[k]||{};if(!B){B=l[k]=[];
|
|
||||||
if(!D.setup||D.setup.call(a,e,v,n)===false)if(a.addEventListener)a.addEventListener(k,n,false);else a.attachEvent&&a.attachEvent("on"+k,n)}if(D.add){D.add.call(a,h);if(!h.handler.guid)h.handler.guid=d.guid}B.push(h);c.event.global[k]=true}a=null}}},global:{},remove:function(a,b,d,e){if(!(a.nodeType===3||a.nodeType===8)){if(d===false)d=U;var f,h,k=0,l,n,s,v,B,D,H=a.nodeType?"events":"__events__",w=c.data(a),G=w&&w[H];if(w&&G){if(typeof G==="function"){w=G;G=G.events}if(b&&b.type){d=b.handler;b=b.type}if(!b||
|
|
||||||
typeof b==="string"&&b.charAt(0)==="."){b=b||"";for(f in G)c.event.remove(a,f+b)}else{for(b=b.split(" ");f=b[k++];){v=f;l=f.indexOf(".")<0;n=[];if(!l){n=f.split(".");f=n.shift();s=RegExp("(^|\\.)"+c.map(n.slice(0).sort(),Va).join("\\.(?:.*\\.)?")+"(\\.|$)")}if(B=G[f])if(d){v=c.event.special[f]||{};for(h=e||0;h<B.length;h++){D=B[h];if(d.guid===D.guid){if(l||s.test(D.namespace)){e==null&&B.splice(h--,1);v.remove&&v.remove.call(a,D)}if(e!=null)break}}if(B.length===0||e!=null&&B.length===1){if(!v.teardown||
|
|
||||||
v.teardown.call(a,n)===false)c.removeEvent(a,f,w.handle);delete G[f]}}else for(h=0;h<B.length;h++){D=B[h];if(l||s.test(D.namespace)){c.event.remove(a,v,D.handler,h);B.splice(h--,1)}}}if(c.isEmptyObject(G)){if(b=w.handle)b.elem=null;delete w.events;delete w.handle;if(typeof w==="function")c.removeData(a,H);else c.isEmptyObject(w)&&c.removeData(a)}}}}},trigger:function(a,b,d,e){var f=a.type||a;if(!e){a=typeof a==="object"?a[c.expando]?a:c.extend(c.Event(f),a):c.Event(f);if(f.indexOf("!")>=0){a.type=
|
|
||||||
f=f.slice(0,-1);a.exclusive=true}if(!d){a.stopPropagation();c.event.global[f]&&c.each(c.cache,function(){this.events&&this.events[f]&&c.event.trigger(a,b,this.handle.elem)})}if(!d||d.nodeType===3||d.nodeType===8)return A;a.result=A;a.target=d;b=c.makeArray(b);b.unshift(a)}a.currentTarget=d;(e=d.nodeType?c.data(d,"handle"):(c.data(d,"__events__")||{}).handle)&&e.apply(d,b);e=d.parentNode||d.ownerDocument;try{if(!(d&&d.nodeName&&c.noData[d.nodeName.toLowerCase()]))if(d["on"+f]&&d["on"+f].apply(d,b)===
|
|
||||||
false){a.result=false;a.preventDefault()}}catch(h){}if(!a.isPropagationStopped()&&e)c.event.trigger(a,b,e,true);else if(!a.isDefaultPrevented()){e=a.target;var k,l=f.replace(X,""),n=c.nodeName(e,"a")&&l==="click",s=c.event.special[l]||{};if((!s._default||s._default.call(d,a)===false)&&!n&&!(e&&e.nodeName&&c.noData[e.nodeName.toLowerCase()])){try{if(e[l]){if(k=e["on"+l])e["on"+l]=null;c.event.triggered=true;e[l]()}}catch(v){}if(k)e["on"+l]=k;c.event.triggered=false}}},handle:function(a){var b,d,e;
|
|
||||||
d=[];var f,h=c.makeArray(arguments);a=h[0]=c.event.fix(a||E.event);a.currentTarget=this;b=a.type.indexOf(".")<0&&!a.exclusive;if(!b){e=a.type.split(".");a.type=e.shift();d=e.slice(0).sort();e=RegExp("(^|\\.)"+d.join("\\.(?:.*\\.)?")+"(\\.|$)")}a.namespace=a.namespace||d.join(".");f=c.data(this,this.nodeType?"events":"__events__");if(typeof f==="function")f=f.events;d=(f||{})[a.type];if(f&&d){d=d.slice(0);f=0;for(var k=d.length;f<k;f++){var l=d[f];if(b||e.test(l.namespace)){a.handler=l.handler;a.data=
|
|
||||||
l.data;a.handleObj=l;l=l.handler.apply(this,h);if(l!==A){a.result=l;if(l===false){a.preventDefault();a.stopPropagation()}}if(a.isImmediatePropagationStopped())break}}}return a.result},props:"altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode layerX layerY metaKey newValue offsetX offsetY pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" "),
|
|
||||||
fix:function(a){if(a[c.expando])return a;var b=a;a=c.Event(b);for(var d=this.props.length,e;d;){e=this.props[--d];a[e]=b[e]}if(!a.target)a.target=a.srcElement||u;if(a.target.nodeType===3)a.target=a.target.parentNode;if(!a.relatedTarget&&a.fromElement)a.relatedTarget=a.fromElement===a.target?a.toElement:a.fromElement;if(a.pageX==null&&a.clientX!=null){b=u.documentElement;d=u.body;a.pageX=a.clientX+(b&&b.scrollLeft||d&&d.scrollLeft||0)-(b&&b.clientLeft||d&&d.clientLeft||0);a.pageY=a.clientY+(b&&b.scrollTop||
|
|
||||||
d&&d.scrollTop||0)-(b&&b.clientTop||d&&d.clientTop||0)}if(a.which==null&&(a.charCode!=null||a.keyCode!=null))a.which=a.charCode!=null?a.charCode:a.keyCode;if(!a.metaKey&&a.ctrlKey)a.metaKey=a.ctrlKey;if(!a.which&&a.button!==A)a.which=a.button&1?1:a.button&2?3:a.button&4?2:0;return a},guid:1E8,proxy:c.proxy,special:{ready:{setup:c.bindReady,teardown:c.noop},live:{add:function(a){c.event.add(this,Y(a.origType,a.selector),c.extend({},a,{handler:Ga,guid:a.handler.guid}))},remove:function(a){c.event.remove(this,
|
|
||||||
Y(a.origType,a.selector),a)}},beforeunload:{setup:function(a,b,d){if(c.isWindow(this))this.onbeforeunload=d},teardown:function(a,b){if(this.onbeforeunload===b)this.onbeforeunload=null}}}};c.removeEvent=u.removeEventListener?function(a,b,d){a.removeEventListener&&a.removeEventListener(b,d,false)}:function(a,b,d){a.detachEvent&&a.detachEvent("on"+b,d)};c.Event=function(a){if(!this.preventDefault)return new c.Event(a);if(a&&a.type){this.originalEvent=a;this.type=a.type}else this.type=a;this.timeStamp=
|
|
||||||
c.now();this[c.expando]=true};c.Event.prototype={preventDefault:function(){this.isDefaultPrevented=ba;var a=this.originalEvent;if(a)if(a.preventDefault)a.preventDefault();else a.returnValue=false},stopPropagation:function(){this.isPropagationStopped=ba;var a=this.originalEvent;if(a){a.stopPropagation&&a.stopPropagation();a.cancelBubble=true}},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=ba;this.stopPropagation()},isDefaultPrevented:U,isPropagationStopped:U,isImmediatePropagationStopped:U};
|
|
||||||
var ta=function(a){var b=a.relatedTarget;try{for(;b&&b!==this;)b=b.parentNode;if(b!==this){a.type=a.data;c.event.handle.apply(this,arguments)}}catch(d){}},ua=function(a){a.type=a.data;c.event.handle.apply(this,arguments)};c.each({mouseenter:"mouseover",mouseleave:"mouseout"},function(a,b){c.event.special[a]={setup:function(d){c.event.add(this,b,d&&d.selector?ua:ta,a)},teardown:function(d){c.event.remove(this,b,d&&d.selector?ua:ta)}}});if(!c.support.submitBubbles)c.event.special.submit={setup:function(){if(this.nodeName.toLowerCase()!==
|
|
||||||
"form"){c.event.add(this,"click.specialSubmit",function(a){var b=a.target,d=b.type;if((d==="submit"||d==="image")&&c(b).closest("form").length){a.liveFired=A;return ja("submit",this,arguments)}});c.event.add(this,"keypress.specialSubmit",function(a){var b=a.target,d=b.type;if((d==="text"||d==="password")&&c(b).closest("form").length&&a.keyCode===13){a.liveFired=A;return ja("submit",this,arguments)}})}else return false},teardown:function(){c.event.remove(this,".specialSubmit")}};if(!c.support.changeBubbles){var V,
|
|
||||||
va=function(a){var b=a.type,d=a.value;if(b==="radio"||b==="checkbox")d=a.checked;else if(b==="select-multiple")d=a.selectedIndex>-1?c.map(a.options,function(e){return e.selected}).join("-"):"";else if(a.nodeName.toLowerCase()==="select")d=a.selectedIndex;return d},Z=function(a,b){var d=a.target,e,f;if(!(!ha.test(d.nodeName)||d.readOnly)){e=c.data(d,"_change_data");f=va(d);if(a.type!=="focusout"||d.type!=="radio")c.data(d,"_change_data",f);if(!(e===A||f===e))if(e!=null||f){a.type="change";a.liveFired=
|
|
||||||
A;return c.event.trigger(a,b,d)}}};c.event.special.change={filters:{focusout:Z,beforedeactivate:Z,click:function(a){var b=a.target,d=b.type;if(d==="radio"||d==="checkbox"||b.nodeName.toLowerCase()==="select")return Z.call(this,a)},keydown:function(a){var b=a.target,d=b.type;if(a.keyCode===13&&b.nodeName.toLowerCase()!=="textarea"||a.keyCode===32&&(d==="checkbox"||d==="radio")||d==="select-multiple")return Z.call(this,a)},beforeactivate:function(a){a=a.target;c.data(a,"_change_data",va(a))}},setup:function(){if(this.type===
|
|
||||||
"file")return false;for(var a in V)c.event.add(this,a+".specialChange",V[a]);return ha.test(this.nodeName)},teardown:function(){c.event.remove(this,".specialChange");return ha.test(this.nodeName)}};V=c.event.special.change.filters;V.focus=V.beforeactivate}u.addEventListener&&c.each({focus:"focusin",blur:"focusout"},function(a,b){function d(e){e=c.event.fix(e);e.type=b;return c.event.trigger(e,null,e.target)}c.event.special[b]={setup:function(){sa[b]++===0&&u.addEventListener(a,d,true)},teardown:function(){--sa[b]===
|
|
||||||
0&&u.removeEventListener(a,d,true)}}});c.each(["bind","one"],function(a,b){c.fn[b]=function(d,e,f){if(typeof d==="object"){for(var h in d)this[b](h,e,d[h],f);return this}if(c.isFunction(e)||e===false){f=e;e=A}var k=b==="one"?c.proxy(f,function(n){c(this).unbind(n,k);return f.apply(this,arguments)}):f;if(d==="unload"&&b!=="one")this.one(d,e,f);else{h=0;for(var l=this.length;h<l;h++)c.event.add(this[h],d,k,e)}return this}});c.fn.extend({unbind:function(a,b){if(typeof a==="object"&&!a.preventDefault)for(var d in a)this.unbind(d,
|
|
||||||
a[d]);else{d=0;for(var e=this.length;d<e;d++)c.event.remove(this[d],a,b)}return this},delegate:function(a,b,d,e){return this.live(b,d,e,a)},undelegate:function(a,b,d){return arguments.length===0?this.unbind("live"):this.die(b,null,d,a)},trigger:function(a,b){return this.each(function(){c.event.trigger(a,b,this)})},triggerHandler:function(a,b){if(this[0]){var d=c.Event(a);d.preventDefault();d.stopPropagation();c.event.trigger(d,b,this[0]);return d.result}},toggle:function(a){for(var b=arguments,d=
|
|
||||||
1;d<b.length;)c.proxy(a,b[d++]);return this.click(c.proxy(a,function(e){var f=(c.data(this,"lastToggle"+a.guid)||0)%d;c.data(this,"lastToggle"+a.guid,f+1);e.preventDefault();return b[f].apply(this,arguments)||false}))},hover:function(a,b){return this.mouseenter(a).mouseleave(b||a)}});var wa={focus:"focusin",blur:"focusout",mouseenter:"mouseover",mouseleave:"mouseout"};c.each(["live","die"],function(a,b){c.fn[b]=function(d,e,f,h){var k,l=0,n,s,v=h||this.selector;h=h?this:c(this.context);if(typeof d===
|
|
||||||
"object"&&!d.preventDefault){for(k in d)h[b](k,e,d[k],v);return this}if(c.isFunction(e)){f=e;e=A}for(d=(d||"").split(" ");(k=d[l++])!=null;){n=X.exec(k);s="";if(n){s=n[0];k=k.replace(X,"")}if(k==="hover")d.push("mouseenter"+s,"mouseleave"+s);else{n=k;if(k==="focus"||k==="blur"){d.push(wa[k]+s);k+=s}else k=(wa[k]||k)+s;if(b==="live"){s=0;for(var B=h.length;s<B;s++)c.event.add(h[s],"live."+Y(k,v),{data:e,selector:v,handler:f,origType:k,origHandler:f,preType:n})}else h.unbind("live."+Y(k,v),f)}}return this}});
|
|
||||||
c.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error".split(" "),function(a,b){c.fn[b]=function(d,e){if(e==null){e=d;d=null}return arguments.length>0?this.bind(b,d,e):this.trigger(b)};if(c.attrFn)c.attrFn[b]=true});E.attachEvent&&!E.addEventListener&&c(E).bind("unload",function(){for(var a in c.cache)if(c.cache[a].handle)try{c.event.remove(c.cache[a].handle.elem)}catch(b){}});
|
|
||||||
(function(){function a(g,j,o,m,p,q){p=0;for(var t=m.length;p<t;p++){var x=m[p];if(x){x=x[g];for(var C=false;x;){if(x.sizcache===o){C=m[x.sizset];break}if(x.nodeType===1&&!q){x.sizcache=o;x.sizset=p}if(x.nodeName.toLowerCase()===j){C=x;break}x=x[g]}m[p]=C}}}function b(g,j,o,m,p,q){p=0;for(var t=m.length;p<t;p++){var x=m[p];if(x){x=x[g];for(var C=false;x;){if(x.sizcache===o){C=m[x.sizset];break}if(x.nodeType===1){if(!q){x.sizcache=o;x.sizset=p}if(typeof j!=="string"){if(x===j){C=true;break}}else if(l.filter(j,
|
|
||||||
[x]).length>0){C=x;break}}x=x[g]}m[p]=C}}}var d=/((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^\[\]]*\]|['"][^'"]*['"]|[^\[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g,e=0,f=Object.prototype.toString,h=false,k=true;[0,0].sort(function(){k=false;return 0});var l=function(g,j,o,m){o=o||[];var p=j=j||u;if(j.nodeType!==1&&j.nodeType!==9)return[];if(!g||typeof g!=="string")return o;var q=[],t,x,C,P,N=true,R=l.isXML(j),Q=g,L;do{d.exec("");if(t=d.exec(Q)){Q=t[3];q.push(t[1]);if(t[2]){P=t[3];
|
|
||||||
break}}}while(t);if(q.length>1&&s.exec(g))if(q.length===2&&n.relative[q[0]])x=M(q[0]+q[1],j);else for(x=n.relative[q[0]]?[j]:l(q.shift(),j);q.length;){g=q.shift();if(n.relative[g])g+=q.shift();x=M(g,x)}else{if(!m&&q.length>1&&j.nodeType===9&&!R&&n.match.ID.test(q[0])&&!n.match.ID.test(q[q.length-1])){t=l.find(q.shift(),j,R);j=t.expr?l.filter(t.expr,t.set)[0]:t.set[0]}if(j){t=m?{expr:q.pop(),set:D(m)}:l.find(q.pop(),q.length===1&&(q[0]==="~"||q[0]==="+")&&j.parentNode?j.parentNode:j,R);x=t.expr?l.filter(t.expr,
|
|
||||||
t.set):t.set;if(q.length>0)C=D(x);else N=false;for(;q.length;){t=L=q.pop();if(n.relative[L])t=q.pop();else L="";if(t==null)t=j;n.relative[L](C,t,R)}}else C=[]}C||(C=x);C||l.error(L||g);if(f.call(C)==="[object Array]")if(N)if(j&&j.nodeType===1)for(g=0;C[g]!=null;g++){if(C[g]&&(C[g]===true||C[g].nodeType===1&&l.contains(j,C[g])))o.push(x[g])}else for(g=0;C[g]!=null;g++)C[g]&&C[g].nodeType===1&&o.push(x[g]);else o.push.apply(o,C);else D(C,o);if(P){l(P,p,o,m);l.uniqueSort(o)}return o};l.uniqueSort=function(g){if(w){h=
|
|
||||||
k;g.sort(w);if(h)for(var j=1;j<g.length;j++)g[j]===g[j-1]&&g.splice(j--,1)}return g};l.matches=function(g,j){return l(g,null,null,j)};l.matchesSelector=function(g,j){return l(j,null,null,[g]).length>0};l.find=function(g,j,o){var m;if(!g)return[];for(var p=0,q=n.order.length;p<q;p++){var t=n.order[p],x;if(x=n.leftMatch[t].exec(g)){var C=x[1];x.splice(1,1);if(C.substr(C.length-1)!=="\\"){x[1]=(x[1]||"").replace(/\\/g,"");m=n.find[t](x,j,o);if(m!=null){g=g.replace(n.match[t],"");break}}}}m||(m=j.getElementsByTagName("*"));
|
|
||||||
return{set:m,expr:g}};l.filter=function(g,j,o,m){for(var p=g,q=[],t=j,x,C,P=j&&j[0]&&l.isXML(j[0]);g&&j.length;){for(var N in n.filter)if((x=n.leftMatch[N].exec(g))!=null&&x[2]){var R=n.filter[N],Q,L;L=x[1];C=false;x.splice(1,1);if(L.substr(L.length-1)!=="\\"){if(t===q)q=[];if(n.preFilter[N])if(x=n.preFilter[N](x,t,o,q,m,P)){if(x===true)continue}else C=Q=true;if(x)for(var i=0;(L=t[i])!=null;i++)if(L){Q=R(L,x,i,t);var r=m^!!Q;if(o&&Q!=null)if(r)C=true;else t[i]=false;else if(r){q.push(L);C=true}}if(Q!==
|
|
||||||
A){o||(t=q);g=g.replace(n.match[N],"");if(!C)return[];break}}}if(g===p)if(C==null)l.error(g);else break;p=g}return t};l.error=function(g){throw"Syntax error, unrecognized expression: "+g;};var n=l.selectors={order:["ID","NAME","TAG"],match:{ID:/#((?:[\w\u00c0-\uFFFF\-]|\\.)+)/,CLASS:/\.((?:[\w\u00c0-\uFFFF\-]|\\.)+)/,NAME:/\[name=['"]*((?:[\w\u00c0-\uFFFF\-]|\\.)+)['"]*\]/,ATTR:/\[\s*((?:[\w\u00c0-\uFFFF\-]|\\.)+)\s*(?:(\S?=)\s*(['"]*)(.*?)\3|)\s*\]/,TAG:/^((?:[\w\u00c0-\uFFFF\*\-]|\\.)+)/,CHILD:/:(only|nth|last|first)-child(?:\((even|odd|[\dn+\-]*)\))?/,
|
|
||||||
POS:/:(nth|eq|gt|lt|first|last|even|odd)(?:\((\d*)\))?(?=[^\-]|$)/,PSEUDO:/:((?:[\w\u00c0-\uFFFF\-]|\\.)+)(?:\((['"]?)((?:\([^\)]+\)|[^\(\)]*)+)\2\))?/},leftMatch:{},attrMap:{"class":"className","for":"htmlFor"},attrHandle:{href:function(g){return g.getAttribute("href")}},relative:{"+":function(g,j){var o=typeof j==="string",m=o&&!/\W/.test(j);o=o&&!m;if(m)j=j.toLowerCase();m=0;for(var p=g.length,q;m<p;m++)if(q=g[m]){for(;(q=q.previousSibling)&&q.nodeType!==1;);g[m]=o||q&&q.nodeName.toLowerCase()===
|
|
||||||
j?q||false:q===j}o&&l.filter(j,g,true)},">":function(g,j){var o=typeof j==="string",m,p=0,q=g.length;if(o&&!/\W/.test(j))for(j=j.toLowerCase();p<q;p++){if(m=g[p]){o=m.parentNode;g[p]=o.nodeName.toLowerCase()===j?o:false}}else{for(;p<q;p++)if(m=g[p])g[p]=o?m.parentNode:m.parentNode===j;o&&l.filter(j,g,true)}},"":function(g,j,o){var m=e++,p=b,q;if(typeof j==="string"&&!/\W/.test(j)){q=j=j.toLowerCase();p=a}p("parentNode",j,m,g,q,o)},"~":function(g,j,o){var m=e++,p=b,q;if(typeof j==="string"&&!/\W/.test(j)){q=
|
|
||||||
j=j.toLowerCase();p=a}p("previousSibling",j,m,g,q,o)}},find:{ID:function(g,j,o){if(typeof j.getElementById!=="undefined"&&!o)return(g=j.getElementById(g[1]))&&g.parentNode?[g]:[]},NAME:function(g,j){if(typeof j.getElementsByName!=="undefined"){for(var o=[],m=j.getElementsByName(g[1]),p=0,q=m.length;p<q;p++)m[p].getAttribute("name")===g[1]&&o.push(m[p]);return o.length===0?null:o}},TAG:function(g,j){return j.getElementsByTagName(g[1])}},preFilter:{CLASS:function(g,j,o,m,p,q){g=" "+g[1].replace(/\\/g,
|
|
||||||
"")+" ";if(q)return g;q=0;for(var t;(t=j[q])!=null;q++)if(t)if(p^(t.className&&(" "+t.className+" ").replace(/[\t\n]/g," ").indexOf(g)>=0))o||m.push(t);else if(o)j[q]=false;return false},ID:function(g){return g[1].replace(/\\/g,"")},TAG:function(g){return g[1].toLowerCase()},CHILD:function(g){if(g[1]==="nth"){var j=/(-?)(\d*)n((?:\+|-)?\d*)/.exec(g[2]==="even"&&"2n"||g[2]==="odd"&&"2n+1"||!/\D/.test(g[2])&&"0n+"+g[2]||g[2]);g[2]=j[1]+(j[2]||1)-0;g[3]=j[3]-0}g[0]=e++;return g},ATTR:function(g,j,o,
|
|
||||||
m,p,q){j=g[1].replace(/\\/g,"");if(!q&&n.attrMap[j])g[1]=n.attrMap[j];if(g[2]==="~=")g[4]=" "+g[4]+" ";return g},PSEUDO:function(g,j,o,m,p){if(g[1]==="not")if((d.exec(g[3])||"").length>1||/^\w/.test(g[3]))g[3]=l(g[3],null,null,j);else{g=l.filter(g[3],j,o,true^p);o||m.push.apply(m,g);return false}else if(n.match.POS.test(g[0])||n.match.CHILD.test(g[0]))return true;return g},POS:function(g){g.unshift(true);return g}},filters:{enabled:function(g){return g.disabled===false&&g.type!=="hidden"},disabled:function(g){return g.disabled===
|
|
||||||
true},checked:function(g){return g.checked===true},selected:function(g){return g.selected===true},parent:function(g){return!!g.firstChild},empty:function(g){return!g.firstChild},has:function(g,j,o){return!!l(o[3],g).length},header:function(g){return/h\d/i.test(g.nodeName)},text:function(g){return"text"===g.type},radio:function(g){return"radio"===g.type},checkbox:function(g){return"checkbox"===g.type},file:function(g){return"file"===g.type},password:function(g){return"password"===g.type},submit:function(g){return"submit"===
|
|
||||||
g.type},image:function(g){return"image"===g.type},reset:function(g){return"reset"===g.type},button:function(g){return"button"===g.type||g.nodeName.toLowerCase()==="button"},input:function(g){return/input|select|textarea|button/i.test(g.nodeName)}},setFilters:{first:function(g,j){return j===0},last:function(g,j,o,m){return j===m.length-1},even:function(g,j){return j%2===0},odd:function(g,j){return j%2===1},lt:function(g,j,o){return j<o[3]-0},gt:function(g,j,o){return j>o[3]-0},nth:function(g,j,o){return o[3]-
|
|
||||||
0===j},eq:function(g,j,o){return o[3]-0===j}},filter:{PSEUDO:function(g,j,o,m){var p=j[1],q=n.filters[p];if(q)return q(g,o,j,m);else if(p==="contains")return(g.textContent||g.innerText||l.getText([g])||"").indexOf(j[3])>=0;else if(p==="not"){j=j[3];o=0;for(m=j.length;o<m;o++)if(j[o]===g)return false;return true}else l.error("Syntax error, unrecognized expression: "+p)},CHILD:function(g,j){var o=j[1],m=g;switch(o){case "only":case "first":for(;m=m.previousSibling;)if(m.nodeType===1)return false;if(o===
|
|
||||||
"first")return true;m=g;case "last":for(;m=m.nextSibling;)if(m.nodeType===1)return false;return true;case "nth":o=j[2];var p=j[3];if(o===1&&p===0)return true;var q=j[0],t=g.parentNode;if(t&&(t.sizcache!==q||!g.nodeIndex)){var x=0;for(m=t.firstChild;m;m=m.nextSibling)if(m.nodeType===1)m.nodeIndex=++x;t.sizcache=q}m=g.nodeIndex-p;return o===0?m===0:m%o===0&&m/o>=0}},ID:function(g,j){return g.nodeType===1&&g.getAttribute("id")===j},TAG:function(g,j){return j==="*"&&g.nodeType===1||g.nodeName.toLowerCase()===
|
|
||||||
j},CLASS:function(g,j){return(" "+(g.className||g.getAttribute("class"))+" ").indexOf(j)>-1},ATTR:function(g,j){var o=j[1];o=n.attrHandle[o]?n.attrHandle[o](g):g[o]!=null?g[o]:g.getAttribute(o);var m=o+"",p=j[2],q=j[4];return o==null?p==="!=":p==="="?m===q:p==="*="?m.indexOf(q)>=0:p==="~="?(" "+m+" ").indexOf(q)>=0:!q?m&&o!==false:p==="!="?m!==q:p==="^="?m.indexOf(q)===0:p==="$="?m.substr(m.length-q.length)===q:p==="|="?m===q||m.substr(0,q.length+1)===q+"-":false},POS:function(g,j,o,m){var p=n.setFilters[j[2]];
|
|
||||||
if(p)return p(g,o,j,m)}}},s=n.match.POS,v=function(g,j){return"\\"+(j-0+1)},B;for(B in n.match){n.match[B]=RegExp(n.match[B].source+/(?![^\[]*\])(?![^\(]*\))/.source);n.leftMatch[B]=RegExp(/(^(?:.|\r|\n)*?)/.source+n.match[B].source.replace(/\\(\d+)/g,v))}var D=function(g,j){g=Array.prototype.slice.call(g,0);if(j){j.push.apply(j,g);return j}return g};try{Array.prototype.slice.call(u.documentElement.childNodes,0)}catch(H){D=function(g,j){var o=j||[],m=0;if(f.call(g)==="[object Array]")Array.prototype.push.apply(o,
|
|
||||||
g);else if(typeof g.length==="number")for(var p=g.length;m<p;m++)o.push(g[m]);else for(;g[m];m++)o.push(g[m]);return o}}var w,G;if(u.documentElement.compareDocumentPosition)w=function(g,j){if(g===j){h=true;return 0}if(!g.compareDocumentPosition||!j.compareDocumentPosition)return g.compareDocumentPosition?-1:1;return g.compareDocumentPosition(j)&4?-1:1};else{w=function(g,j){var o=[],m=[],p=g.parentNode,q=j.parentNode,t=p;if(g===j){h=true;return 0}else if(p===q)return G(g,j);else if(p){if(!q)return 1}else return-1;
|
|
||||||
for(;t;){o.unshift(t);t=t.parentNode}for(t=q;t;){m.unshift(t);t=t.parentNode}p=o.length;q=m.length;for(t=0;t<p&&t<q;t++)if(o[t]!==m[t])return G(o[t],m[t]);return t===p?G(g,m[t],-1):G(o[t],j,1)};G=function(g,j,o){if(g===j)return o;for(g=g.nextSibling;g;){if(g===j)return-1;g=g.nextSibling}return 1}}l.getText=function(g){for(var j="",o,m=0;g[m];m++){o=g[m];if(o.nodeType===3||o.nodeType===4)j+=o.nodeValue;else if(o.nodeType!==8)j+=l.getText(o.childNodes)}return j};(function(){var g=u.createElement("div"),
|
|
||||||
j="script"+(new Date).getTime();g.innerHTML="<a name='"+j+"'/>";var o=u.documentElement;o.insertBefore(g,o.firstChild);if(u.getElementById(j)){n.find.ID=function(m,p,q){if(typeof p.getElementById!=="undefined"&&!q)return(p=p.getElementById(m[1]))?p.id===m[1]||typeof p.getAttributeNode!=="undefined"&&p.getAttributeNode("id").nodeValue===m[1]?[p]:A:[]};n.filter.ID=function(m,p){var q=typeof m.getAttributeNode!=="undefined"&&m.getAttributeNode("id");return m.nodeType===1&&q&&q.nodeValue===p}}o.removeChild(g);
|
|
||||||
o=g=null})();(function(){var g=u.createElement("div");g.appendChild(u.createComment(""));if(g.getElementsByTagName("*").length>0)n.find.TAG=function(j,o){var m=o.getElementsByTagName(j[1]);if(j[1]==="*"){for(var p=[],q=0;m[q];q++)m[q].nodeType===1&&p.push(m[q]);m=p}return m};g.innerHTML="<a href='#'></a>";if(g.firstChild&&typeof g.firstChild.getAttribute!=="undefined"&&g.firstChild.getAttribute("href")!=="#")n.attrHandle.href=function(j){return j.getAttribute("href",2)};g=null})();u.querySelectorAll&&
|
|
||||||
function(){var g=l,j=u.createElement("div");j.innerHTML="<p class='TEST'></p>";if(!(j.querySelectorAll&&j.querySelectorAll(".TEST").length===0)){l=function(m,p,q,t){p=p||u;if(!t&&!l.isXML(p))if(p.nodeType===9)try{return D(p.querySelectorAll(m),q)}catch(x){}else if(p.nodeType===1&&p.nodeName.toLowerCase()!=="object"){var C=p.id,P=p.id="__sizzle__";try{return D(p.querySelectorAll("#"+P+" "+m),q)}catch(N){}finally{if(C)p.id=C;else p.removeAttribute("id")}}return g(m,p,q,t)};for(var o in g)l[o]=g[o];
|
|
||||||
j=null}}();(function(){var g=u.documentElement,j=g.matchesSelector||g.mozMatchesSelector||g.webkitMatchesSelector||g.msMatchesSelector,o=false;try{j.call(u.documentElement,":sizzle")}catch(m){o=true}if(j)l.matchesSelector=function(p,q){try{if(o||!n.match.PSEUDO.test(q))return j.call(p,q)}catch(t){}return l(q,null,null,[p]).length>0}})();(function(){var g=u.createElement("div");g.innerHTML="<div class='test e'></div><div class='test'></div>";if(!(!g.getElementsByClassName||g.getElementsByClassName("e").length===
|
|
||||||
0)){g.lastChild.className="e";if(g.getElementsByClassName("e").length!==1){n.order.splice(1,0,"CLASS");n.find.CLASS=function(j,o,m){if(typeof o.getElementsByClassName!=="undefined"&&!m)return o.getElementsByClassName(j[1])};g=null}}})();l.contains=u.documentElement.contains?function(g,j){return g!==j&&(g.contains?g.contains(j):true)}:function(g,j){return!!(g.compareDocumentPosition(j)&16)};l.isXML=function(g){return(g=(g?g.ownerDocument||g:0).documentElement)?g.nodeName!=="HTML":false};var M=function(g,
|
|
||||||
j){for(var o=[],m="",p,q=j.nodeType?[j]:j;p=n.match.PSEUDO.exec(g);){m+=p[0];g=g.replace(n.match.PSEUDO,"")}g=n.relative[g]?g+"*":g;p=0;for(var t=q.length;p<t;p++)l(g,q[p],o);return l.filter(m,o)};c.find=l;c.expr=l.selectors;c.expr[":"]=c.expr.filters;c.unique=l.uniqueSort;c.text=l.getText;c.isXMLDoc=l.isXML;c.contains=l.contains})();var Wa=/Until$/,Xa=/^(?:parents|prevUntil|prevAll)/,Ya=/,/,Ja=/^.[^:#\[\.,]*$/,Za=Array.prototype.slice,$a=c.expr.match.POS;c.fn.extend({find:function(a){for(var b=this.pushStack("",
|
|
||||||
"find",a),d=0,e=0,f=this.length;e<f;e++){d=b.length;c.find(a,this[e],b);if(e>0)for(var h=d;h<b.length;h++)for(var k=0;k<d;k++)if(b[k]===b[h]){b.splice(h--,1);break}}return b},has:function(a){var b=c(a);return this.filter(function(){for(var d=0,e=b.length;d<e;d++)if(c.contains(this,b[d]))return true})},not:function(a){return this.pushStack(ka(this,a,false),"not",a)},filter:function(a){return this.pushStack(ka(this,a,true),"filter",a)},is:function(a){return!!a&&c.filter(a,this).length>0},closest:function(a,
|
|
||||||
b){var d=[],e,f,h=this[0];if(c.isArray(a)){var k={},l,n=1;if(h&&a.length){e=0;for(f=a.length;e<f;e++){l=a[e];k[l]||(k[l]=c.expr.match.POS.test(l)?c(l,b||this.context):l)}for(;h&&h.ownerDocument&&h!==b;){for(l in k){e=k[l];if(e.jquery?e.index(h)>-1:c(h).is(e))d.push({selector:l,elem:h,level:n})}h=h.parentNode;n++}}return d}k=$a.test(a)?c(a,b||this.context):null;e=0;for(f=this.length;e<f;e++)for(h=this[e];h;)if(k?k.index(h)>-1:c.find.matchesSelector(h,a)){d.push(h);break}else{h=h.parentNode;if(!h||
|
|
||||||
!h.ownerDocument||h===b)break}d=d.length>1?c.unique(d):d;return this.pushStack(d,"closest",a)},index:function(a){if(!a||typeof a==="string")return c.inArray(this[0],a?c(a):this.parent().children());return c.inArray(a.jquery?a[0]:a,this)},add:function(a,b){var d=typeof a==="string"?c(a,b||this.context):c.makeArray(a),e=c.merge(this.get(),d);return this.pushStack(!d[0]||!d[0].parentNode||d[0].parentNode.nodeType===11||!e[0]||!e[0].parentNode||e[0].parentNode.nodeType===11?e:c.unique(e))},andSelf:function(){return this.add(this.prevObject)}});
|
|
||||||
c.each({parent:function(a){return(a=a.parentNode)&&a.nodeType!==11?a:null},parents:function(a){return c.dir(a,"parentNode")},parentsUntil:function(a,b,d){return c.dir(a,"parentNode",d)},next:function(a){return c.nth(a,2,"nextSibling")},prev:function(a){return c.nth(a,2,"previousSibling")},nextAll:function(a){return c.dir(a,"nextSibling")},prevAll:function(a){return c.dir(a,"previousSibling")},nextUntil:function(a,b,d){return c.dir(a,"nextSibling",d)},prevUntil:function(a,b,d){return c.dir(a,"previousSibling",
|
|
||||||
d)},siblings:function(a){return c.sibling(a.parentNode.firstChild,a)},children:function(a){return c.sibling(a.firstChild)},contents:function(a){return c.nodeName(a,"iframe")?a.contentDocument||a.contentWindow.document:c.makeArray(a.childNodes)}},function(a,b){c.fn[a]=function(d,e){var f=c.map(this,b,d);Wa.test(a)||(e=d);if(e&&typeof e==="string")f=c.filter(e,f);f=this.length>1?c.unique(f):f;if((this.length>1||Ya.test(e))&&Xa.test(a))f=f.reverse();return this.pushStack(f,a,Za.call(arguments).join(","))}});
|
|
||||||
c.extend({filter:function(a,b,d){if(d)a=":not("+a+")";return b.length===1?c.find.matchesSelector(b[0],a)?[b[0]]:[]:c.find.matches(a,b)},dir:function(a,b,d){var e=[];for(a=a[b];a&&a.nodeType!==9&&(d===A||a.nodeType!==1||!c(a).is(d));){a.nodeType===1&&e.push(a);a=a[b]}return e},nth:function(a,b,d){b=b||1;for(var e=0;a;a=a[d])if(a.nodeType===1&&++e===b)break;return a},sibling:function(a,b){for(var d=[];a;a=a.nextSibling)a.nodeType===1&&a!==b&&d.push(a);return d}});var xa=/ jQuery\d+="(?:\d+|null)"/g,
|
|
||||||
$=/^\s+/,ya=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/ig,za=/<([\w:]+)/,ab=/<tbody/i,bb=/<|&#?\w+;/,Aa=/<(?:script|object|embed|option|style)/i,Ba=/checked\s*(?:[^=]|=\s*.checked.)/i,cb=/\=([^="'>\s]+\/)>/g,O={option:[1,"<select multiple='multiple'>","</select>"],legend:[1,"<fieldset>","</fieldset>"],thead:[1,"<table>","</table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],col:[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"],
|
|
||||||
area:[1,"<map>","</map>"],_default:[0,"",""]};O.optgroup=O.option;O.tbody=O.tfoot=O.colgroup=O.caption=O.thead;O.th=O.td;if(!c.support.htmlSerialize)O._default=[1,"div<div>","</div>"];c.fn.extend({text:function(a){if(c.isFunction(a))return this.each(function(b){var d=c(this);d.text(a.call(this,b,d.text()))});if(typeof a!=="object"&&a!==A)return this.empty().append((this[0]&&this[0].ownerDocument||u).createTextNode(a));return c.text(this)},wrapAll:function(a){if(c.isFunction(a))return this.each(function(d){c(this).wrapAll(a.call(this,
|
|
||||||
d))});if(this[0]){var b=c(a,this[0].ownerDocument).eq(0).clone(true);this[0].parentNode&&b.insertBefore(this[0]);b.map(function(){for(var d=this;d.firstChild&&d.firstChild.nodeType===1;)d=d.firstChild;return d}).append(this)}return this},wrapInner:function(a){if(c.isFunction(a))return this.each(function(b){c(this).wrapInner(a.call(this,b))});return this.each(function(){var b=c(this),d=b.contents();d.length?d.wrapAll(a):b.append(a)})},wrap:function(a){return this.each(function(){c(this).wrapAll(a)})},
|
|
||||||
unwrap:function(){return this.parent().each(function(){c.nodeName(this,"body")||c(this).replaceWith(this.childNodes)}).end()},append:function(){return this.domManip(arguments,true,function(a){this.nodeType===1&&this.appendChild(a)})},prepend:function(){return this.domManip(arguments,true,function(a){this.nodeType===1&&this.insertBefore(a,this.firstChild)})},before:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,false,function(b){this.parentNode.insertBefore(b,this)});else if(arguments.length){var a=
|
|
||||||
c(arguments[0]);a.push.apply(a,this.toArray());return this.pushStack(a,"before",arguments)}},after:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,false,function(b){this.parentNode.insertBefore(b,this.nextSibling)});else if(arguments.length){var a=this.pushStack(this,"after",arguments);a.push.apply(a,c(arguments[0]).toArray());return a}},remove:function(a,b){for(var d=0,e;(e=this[d])!=null;d++)if(!a||c.filter(a,[e]).length){if(!b&&e.nodeType===1){c.cleanData(e.getElementsByTagName("*"));
|
|
||||||
c.cleanData([e])}e.parentNode&&e.parentNode.removeChild(e)}return this},empty:function(){for(var a=0,b;(b=this[a])!=null;a++)for(b.nodeType===1&&c.cleanData(b.getElementsByTagName("*"));b.firstChild;)b.removeChild(b.firstChild);return this},clone:function(a){var b=this.map(function(){if(!c.support.noCloneEvent&&!c.isXMLDoc(this)){var d=this.outerHTML,e=this.ownerDocument;if(!d){d=e.createElement("div");d.appendChild(this.cloneNode(true));d=d.innerHTML}return c.clean([d.replace(xa,"").replace(cb,'="$1">').replace($,
|
|
||||||
"")],e)[0]}else return this.cloneNode(true)});if(a===true){la(this,b);la(this.find("*"),b.find("*"))}return b},html:function(a){if(a===A)return this[0]&&this[0].nodeType===1?this[0].innerHTML.replace(xa,""):null;else if(typeof a==="string"&&!Aa.test(a)&&(c.support.leadingWhitespace||!$.test(a))&&!O[(za.exec(a)||["",""])[1].toLowerCase()]){a=a.replace(ya,"<$1></$2>");try{for(var b=0,d=this.length;b<d;b++)if(this[b].nodeType===1){c.cleanData(this[b].getElementsByTagName("*"));this[b].innerHTML=a}}catch(e){this.empty().append(a)}}else c.isFunction(a)?
|
|
||||||
this.each(function(f){var h=c(this);h.html(a.call(this,f,h.html()))}):this.empty().append(a);return this},replaceWith:function(a){if(this[0]&&this[0].parentNode){if(c.isFunction(a))return this.each(function(b){var d=c(this),e=d.html();d.replaceWith(a.call(this,b,e))});if(typeof a!=="string")a=c(a).detach();return this.each(function(){var b=this.nextSibling,d=this.parentNode;c(this).remove();b?c(b).before(a):c(d).append(a)})}else return this.pushStack(c(c.isFunction(a)?a():a),"replaceWith",a)},detach:function(a){return this.remove(a,
|
|
||||||
true)},domManip:function(a,b,d){var e,f,h=a[0],k=[],l;if(!c.support.checkClone&&arguments.length===3&&typeof h==="string"&&Ba.test(h))return this.each(function(){c(this).domManip(a,b,d,true)});if(c.isFunction(h))return this.each(function(s){var v=c(this);a[0]=h.call(this,s,b?v.html():A);v.domManip(a,b,d)});if(this[0]){e=h&&h.parentNode;e=c.support.parentNode&&e&&e.nodeType===11&&e.childNodes.length===this.length?{fragment:e}:c.buildFragment(a,this,k);l=e.fragment;if(f=l.childNodes.length===1?l=l.firstChild:
|
|
||||||
l.firstChild){b=b&&c.nodeName(f,"tr");f=0;for(var n=this.length;f<n;f++)d.call(b?c.nodeName(this[f],"table")?this[f].getElementsByTagName("tbody")[0]||this[f].appendChild(this[f].ownerDocument.createElement("tbody")):this[f]:this[f],f>0||e.cacheable||this.length>1?l.cloneNode(true):l)}k.length&&c.each(k,Ka)}return this}});c.buildFragment=function(a,b,d){var e,f,h;b=b&&b[0]?b[0].ownerDocument||b[0]:u;if(a.length===1&&typeof a[0]==="string"&&a[0].length<512&&b===u&&!Aa.test(a[0])&&(c.support.checkClone||
|
|
||||||
!Ba.test(a[0]))){f=true;if(h=c.fragments[a[0]])if(h!==1)e=h}if(!e){e=b.createDocumentFragment();c.clean(a,b,e,d)}if(f)c.fragments[a[0]]=h?e:1;return{fragment:e,cacheable:f}};c.fragments={};c.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){c.fn[a]=function(d){var e=[];d=c(d);var f=this.length===1&&this[0].parentNode;if(f&&f.nodeType===11&&f.childNodes.length===1&&d.length===1){d[b](this[0]);return this}else{f=0;for(var h=
|
|
||||||
d.length;f<h;f++){var k=(f>0?this.clone(true):this).get();c(d[f])[b](k);e=e.concat(k)}return this.pushStack(e,a,d.selector)}}});c.extend({clean:function(a,b,d,e){b=b||u;if(typeof b.createElement==="undefined")b=b.ownerDocument||b[0]&&b[0].ownerDocument||u;for(var f=[],h=0,k;(k=a[h])!=null;h++){if(typeof k==="number")k+="";if(k){if(typeof k==="string"&&!bb.test(k))k=b.createTextNode(k);else if(typeof k==="string"){k=k.replace(ya,"<$1></$2>");var l=(za.exec(k)||["",""])[1].toLowerCase(),n=O[l]||O._default,
|
|
||||||
s=n[0],v=b.createElement("div");for(v.innerHTML=n[1]+k+n[2];s--;)v=v.lastChild;if(!c.support.tbody){s=ab.test(k);l=l==="table"&&!s?v.firstChild&&v.firstChild.childNodes:n[1]==="<table>"&&!s?v.childNodes:[];for(n=l.length-1;n>=0;--n)c.nodeName(l[n],"tbody")&&!l[n].childNodes.length&&l[n].parentNode.removeChild(l[n])}!c.support.leadingWhitespace&&$.test(k)&&v.insertBefore(b.createTextNode($.exec(k)[0]),v.firstChild);k=v.childNodes}if(k.nodeType)f.push(k);else f=c.merge(f,k)}}if(d)for(h=0;f[h];h++)if(e&&
|
|
||||||
c.nodeName(f[h],"script")&&(!f[h].type||f[h].type.toLowerCase()==="text/javascript"))e.push(f[h].parentNode?f[h].parentNode.removeChild(f[h]):f[h]);else{f[h].nodeType===1&&f.splice.apply(f,[h+1,0].concat(c.makeArray(f[h].getElementsByTagName("script"))));d.appendChild(f[h])}return f},cleanData:function(a){for(var b,d,e=c.cache,f=c.event.special,h=c.support.deleteExpando,k=0,l;(l=a[k])!=null;k++)if(!(l.nodeName&&c.noData[l.nodeName.toLowerCase()]))if(d=l[c.expando]){if((b=e[d])&&b.events)for(var n in b.events)f[n]?
|
|
||||||
c.event.remove(l,n):c.removeEvent(l,n,b.handle);if(h)delete l[c.expando];else l.removeAttribute&&l.removeAttribute(c.expando);delete e[d]}}});var Ca=/alpha\([^)]*\)/i,db=/opacity=([^)]*)/,eb=/-([a-z])/ig,fb=/([A-Z])/g,Da=/^-?\d+(?:px)?$/i,gb=/^-?\d/,hb={position:"absolute",visibility:"hidden",display:"block"},La=["Left","Right"],Ma=["Top","Bottom"],W,ib=u.defaultView&&u.defaultView.getComputedStyle,jb=function(a,b){return b.toUpperCase()};c.fn.css=function(a,b){if(arguments.length===2&&b===A)return this;
|
|
||||||
return c.access(this,a,b,true,function(d,e,f){return f!==A?c.style(d,e,f):c.css(d,e)})};c.extend({cssHooks:{opacity:{get:function(a,b){if(b){var d=W(a,"opacity","opacity");return d===""?"1":d}else return a.style.opacity}}},cssNumber:{zIndex:true,fontWeight:true,opacity:true,zoom:true,lineHeight:true},cssProps:{"float":c.support.cssFloat?"cssFloat":"styleFloat"},style:function(a,b,d,e){if(!(!a||a.nodeType===3||a.nodeType===8||!a.style)){var f,h=c.camelCase(b),k=a.style,l=c.cssHooks[h];b=c.cssProps[h]||
|
|
||||||
h;if(d!==A){if(!(typeof d==="number"&&isNaN(d)||d==null)){if(typeof d==="number"&&!c.cssNumber[h])d+="px";if(!l||!("set"in l)||(d=l.set(a,d))!==A)try{k[b]=d}catch(n){}}}else{if(l&&"get"in l&&(f=l.get(a,false,e))!==A)return f;return k[b]}}},css:function(a,b,d){var e,f=c.camelCase(b),h=c.cssHooks[f];b=c.cssProps[f]||f;if(h&&"get"in h&&(e=h.get(a,true,d))!==A)return e;else if(W)return W(a,b,f)},swap:function(a,b,d){var e={},f;for(f in b){e[f]=a.style[f];a.style[f]=b[f]}d.call(a);for(f in b)a.style[f]=
|
|
||||||
e[f]},camelCase:function(a){return a.replace(eb,jb)}});c.curCSS=c.css;c.each(["height","width"],function(a,b){c.cssHooks[b]={get:function(d,e,f){var h;if(e){if(d.offsetWidth!==0)h=ma(d,b,f);else c.swap(d,hb,function(){h=ma(d,b,f)});return h+"px"}},set:function(d,e){if(Da.test(e)){e=parseFloat(e);if(e>=0)return e+"px"}else return e}}});if(!c.support.opacity)c.cssHooks.opacity={get:function(a,b){return db.test((b&&a.currentStyle?a.currentStyle.filter:a.style.filter)||"")?parseFloat(RegExp.$1)/100+"":
|
|
||||||
b?"1":""},set:function(a,b){var d=a.style;d.zoom=1;var e=c.isNaN(b)?"":"alpha(opacity="+b*100+")",f=d.filter||"";d.filter=Ca.test(f)?f.replace(Ca,e):d.filter+" "+e}};if(ib)W=function(a,b,d){var e;d=d.replace(fb,"-$1").toLowerCase();if(!(b=a.ownerDocument.defaultView))return A;if(b=b.getComputedStyle(a,null)){e=b.getPropertyValue(d);if(e===""&&!c.contains(a.ownerDocument.documentElement,a))e=c.style(a,d)}return e};else if(u.documentElement.currentStyle)W=function(a,b){var d,e,f=a.currentStyle&&a.currentStyle[b],
|
|
||||||
h=a.style;if(!Da.test(f)&&gb.test(f)){d=h.left;e=a.runtimeStyle.left;a.runtimeStyle.left=a.currentStyle.left;h.left=b==="fontSize"?"1em":f||0;f=h.pixelLeft+"px";h.left=d;a.runtimeStyle.left=e}return f};if(c.expr&&c.expr.filters){c.expr.filters.hidden=function(a){var b=a.offsetHeight;return a.offsetWidth===0&&b===0||!c.support.reliableHiddenOffsets&&(a.style.display||c.css(a,"display"))==="none"};c.expr.filters.visible=function(a){return!c.expr.filters.hidden(a)}}var kb=c.now(),lb=/<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi,
|
|
||||||
mb=/^(?:select|textarea)/i,nb=/^(?:color|date|datetime|email|hidden|month|number|password|range|search|tel|text|time|url|week)$/i,ob=/^(?:GET|HEAD|DELETE)$/,Na=/\[\]$/,T=/\=\?(&|$)/,ia=/\?/,pb=/([?&])_=[^&]*/,qb=/^(\w+:)?\/\/([^\/?#]+)/,rb=/%20/g,sb=/#.*$/,Ea=c.fn.load;c.fn.extend({load:function(a,b,d){if(typeof a!=="string"&&Ea)return Ea.apply(this,arguments);else if(!this.length)return this;var e=a.indexOf(" ");if(e>=0){var f=a.slice(e,a.length);a=a.slice(0,e)}e="GET";if(b)if(c.isFunction(b)){d=
|
|
||||||
b;b=null}else if(typeof b==="object"){b=c.param(b,c.ajaxSettings.traditional);e="POST"}var h=this;c.ajax({url:a,type:e,dataType:"html",data:b,complete:function(k,l){if(l==="success"||l==="notmodified")h.html(f?c("<div>").append(k.responseText.replace(lb,"")).find(f):k.responseText);d&&h.each(d,[k.responseText,l,k])}});return this},serialize:function(){return c.param(this.serializeArray())},serializeArray:function(){return this.map(function(){return this.elements?c.makeArray(this.elements):this}).filter(function(){return this.name&&
|
|
||||||
!this.disabled&&(this.checked||mb.test(this.nodeName)||nb.test(this.type))}).map(function(a,b){var d=c(this).val();return d==null?null:c.isArray(d)?c.map(d,function(e){return{name:b.name,value:e}}):{name:b.name,value:d}}).get()}});c.each("ajaxStart ajaxStop ajaxComplete ajaxError ajaxSuccess ajaxSend".split(" "),function(a,b){c.fn[b]=function(d){return this.bind(b,d)}});c.extend({get:function(a,b,d,e){if(c.isFunction(b)){e=e||d;d=b;b=null}return c.ajax({type:"GET",url:a,data:b,success:d,dataType:e})},
|
|
||||||
getScript:function(a,b){return c.get(a,null,b,"script")},getJSON:function(a,b,d){return c.get(a,b,d,"json")},post:function(a,b,d,e){if(c.isFunction(b)){e=e||d;d=b;b={}}return c.ajax({type:"POST",url:a,data:b,success:d,dataType:e})},ajaxSetup:function(a){c.extend(c.ajaxSettings,a)},ajaxSettings:{url:location.href,global:true,type:"GET",contentType:"application/x-www-form-urlencoded",processData:true,async:true,xhr:function(){return new E.XMLHttpRequest},accepts:{xml:"application/xml, text/xml",html:"text/html",
|
|
||||||
script:"text/javascript, application/javascript",json:"application/json, text/javascript",text:"text/plain",_default:"*/*"}},ajax:function(a){var b=c.extend(true,{},c.ajaxSettings,a),d,e,f,h=b.type.toUpperCase(),k=ob.test(h);b.url=b.url.replace(sb,"");b.context=a&&a.context!=null?a.context:b;if(b.data&&b.processData&&typeof b.data!=="string")b.data=c.param(b.data,b.traditional);if(b.dataType==="jsonp"){if(h==="GET")T.test(b.url)||(b.url+=(ia.test(b.url)?"&":"?")+(b.jsonp||"callback")+"=?");else if(!b.data||
|
|
||||||
!T.test(b.data))b.data=(b.data?b.data+"&":"")+(b.jsonp||"callback")+"=?";b.dataType="json"}if(b.dataType==="json"&&(b.data&&T.test(b.data)||T.test(b.url))){d=b.jsonpCallback||"jsonp"+kb++;if(b.data)b.data=(b.data+"").replace(T,"="+d+"$1");b.url=b.url.replace(T,"="+d+"$1");b.dataType="script";var l=E[d];E[d]=function(m){f=m;c.handleSuccess(b,w,e,f);c.handleComplete(b,w,e,f);if(c.isFunction(l))l(m);else{E[d]=A;try{delete E[d]}catch(p){}}v&&v.removeChild(B)}}if(b.dataType==="script"&&b.cache===null)b.cache=
|
|
||||||
false;if(b.cache===false&&h==="GET"){var n=c.now(),s=b.url.replace(pb,"$1_="+n);b.url=s+(s===b.url?(ia.test(b.url)?"&":"?")+"_="+n:"")}if(b.data&&h==="GET")b.url+=(ia.test(b.url)?"&":"?")+b.data;b.global&&c.active++===0&&c.event.trigger("ajaxStart");n=(n=qb.exec(b.url))&&(n[1]&&n[1]!==location.protocol||n[2]!==location.host);if(b.dataType==="script"&&h==="GET"&&n){var v=u.getElementsByTagName("head")[0]||u.documentElement,B=u.createElement("script");if(b.scriptCharset)B.charset=b.scriptCharset;B.src=
|
|
||||||
b.url;if(!d){var D=false;B.onload=B.onreadystatechange=function(){if(!D&&(!this.readyState||this.readyState==="loaded"||this.readyState==="complete")){D=true;c.handleSuccess(b,w,e,f);c.handleComplete(b,w,e,f);B.onload=B.onreadystatechange=null;v&&B.parentNode&&v.removeChild(B)}}}v.insertBefore(B,v.firstChild);return A}var H=false,w=b.xhr();if(w){b.username?w.open(h,b.url,b.async,b.username,b.password):w.open(h,b.url,b.async);try{if(b.data!=null&&!k||a&&a.contentType)w.setRequestHeader("Content-Type",
|
|
||||||
b.contentType);if(b.ifModified){c.lastModified[b.url]&&w.setRequestHeader("If-Modified-Since",c.lastModified[b.url]);c.etag[b.url]&&w.setRequestHeader("If-None-Match",c.etag[b.url])}n||w.setRequestHeader("X-Requested-With","XMLHttpRequest");w.setRequestHeader("Accept",b.dataType&&b.accepts[b.dataType]?b.accepts[b.dataType]+", */*; q=0.01":b.accepts._default)}catch(G){}if(b.beforeSend&&b.beforeSend.call(b.context,w,b)===false){b.global&&c.active--===1&&c.event.trigger("ajaxStop");w.abort();return false}b.global&&
|
|
||||||
c.triggerGlobal(b,"ajaxSend",[w,b]);var M=w.onreadystatechange=function(m){if(!w||w.readyState===0||m==="abort"){H||c.handleComplete(b,w,e,f);H=true;if(w)w.onreadystatechange=c.noop}else if(!H&&w&&(w.readyState===4||m==="timeout")){H=true;w.onreadystatechange=c.noop;e=m==="timeout"?"timeout":!c.httpSuccess(w)?"error":b.ifModified&&c.httpNotModified(w,b.url)?"notmodified":"success";var p;if(e==="success")try{f=c.httpData(w,b.dataType,b)}catch(q){e="parsererror";p=q}if(e==="success"||e==="notmodified")d||
|
|
||||||
c.handleSuccess(b,w,e,f);else c.handleError(b,w,e,p);d||c.handleComplete(b,w,e,f);m==="timeout"&&w.abort();if(b.async)w=null}};try{var g=w.abort;w.abort=function(){w&&g.call&&g.call(w);M("abort")}}catch(j){}b.async&&b.timeout>0&&setTimeout(function(){w&&!H&&M("timeout")},b.timeout);try{w.send(k||b.data==null?null:b.data)}catch(o){c.handleError(b,w,null,o);c.handleComplete(b,w,e,f)}b.async||M();return w}},param:function(a,b){var d=[],e=function(h,k){k=c.isFunction(k)?k():k;d[d.length]=encodeURIComponent(h)+
|
|
||||||
"="+encodeURIComponent(k)};if(b===A)b=c.ajaxSettings.traditional;if(c.isArray(a)||a.jquery)c.each(a,function(){e(this.name,this.value)});else for(var f in a)ca(f,a[f],b,e);return d.join("&").replace(rb,"+")}});c.extend({active:0,lastModified:{},etag:{},handleError:function(a,b,d,e){a.error&&a.error.call(a.context,b,d,e);a.global&&c.triggerGlobal(a,"ajaxError",[b,a,e])},handleSuccess:function(a,b,d,e){a.success&&a.success.call(a.context,e,d,b);a.global&&c.triggerGlobal(a,"ajaxSuccess",[b,a])},handleComplete:function(a,
|
|
||||||
b,d){a.complete&&a.complete.call(a.context,b,d);a.global&&c.triggerGlobal(a,"ajaxComplete",[b,a]);a.global&&c.active--===1&&c.event.trigger("ajaxStop")},triggerGlobal:function(a,b,d){(a.context&&a.context.url==null?c(a.context):c.event).trigger(b,d)},httpSuccess:function(a){try{return!a.status&&location.protocol==="file:"||a.status>=200&&a.status<300||a.status===304||a.status===1223}catch(b){}return false},httpNotModified:function(a,b){var d=a.getResponseHeader("Last-Modified"),e=a.getResponseHeader("Etag");
|
|
||||||
if(d)c.lastModified[b]=d;if(e)c.etag[b]=e;return a.status===304},httpData:function(a,b,d){var e=a.getResponseHeader("content-type")||"",f=b==="xml"||!b&&e.indexOf("xml")>=0;a=f?a.responseXML:a.responseText;f&&a.documentElement.nodeName==="parsererror"&&c.error("parsererror");if(d&&d.dataFilter)a=d.dataFilter(a,b);if(typeof a==="string")if(b==="json"||!b&&e.indexOf("json")>=0)a=c.parseJSON(a);else if(b==="script"||!b&&e.indexOf("javascript")>=0)c.globalEval(a);return a}});if(E.ActiveXObject)c.ajaxSettings.xhr=
|
|
||||||
function(){if(E.location.protocol!=="file:")try{return new E.XMLHttpRequest}catch(a){}try{return new E.ActiveXObject("Microsoft.XMLHTTP")}catch(b){}};c.support.ajax=!!c.ajaxSettings.xhr();var da={},tb=/^(?:toggle|show|hide)$/,ub=/^([+\-]=)?([\d+.\-]+)(.*)$/,aa,na=[["height","marginTop","marginBottom","paddingTop","paddingBottom"],["width","marginLeft","marginRight","paddingLeft","paddingRight"],["opacity"]];c.fn.extend({show:function(a,b,d){if(a||a===0)return this.animate(S("show",3),a,b,d);else{a=
|
|
||||||
0;for(b=this.length;a<b;a++){if(!c.data(this[a],"olddisplay")&&this[a].style.display==="none")this[a].style.display="";this[a].style.display===""&&c.css(this[a],"display")==="none"&&c.data(this[a],"olddisplay",oa(this[a].nodeName))}for(a=0;a<b;a++)this[a].style.display=c.data(this[a],"olddisplay")||"";return this}},hide:function(a,b,d){if(a||a===0)return this.animate(S("hide",3),a,b,d);else{a=0;for(b=this.length;a<b;a++){d=c.css(this[a],"display");d!=="none"&&c.data(this[a],"olddisplay",d)}for(a=
|
|
||||||
0;a<b;a++)this[a].style.display="none";return this}},_toggle:c.fn.toggle,toggle:function(a,b,d){var e=typeof a==="boolean";if(c.isFunction(a)&&c.isFunction(b))this._toggle.apply(this,arguments);else a==null||e?this.each(function(){var f=e?a:c(this).is(":hidden");c(this)[f?"show":"hide"]()}):this.animate(S("toggle",3),a,b,d);return this},fadeTo:function(a,b,d,e){return this.filter(":hidden").css("opacity",0).show().end().animate({opacity:b},a,d,e)},animate:function(a,b,d,e){var f=c.speed(b,d,e);if(c.isEmptyObject(a))return this.each(f.complete);
|
|
||||||
return this[f.queue===false?"each":"queue"](function(){var h=c.extend({},f),k,l=this.nodeType===1,n=l&&c(this).is(":hidden"),s=this;for(k in a){var v=c.camelCase(k);if(k!==v){a[v]=a[k];delete a[k];k=v}if(a[k]==="hide"&&n||a[k]==="show"&&!n)return h.complete.call(this);if(l&&(k==="height"||k==="width")){h.overflow=[this.style.overflow,this.style.overflowX,this.style.overflowY];if(c.css(this,"display")==="inline"&&c.css(this,"float")==="none")if(c.support.inlineBlockNeedsLayout)if(oa(this.nodeName)===
|
|
||||||
"inline")this.style.display="inline-block";else{this.style.display="inline";this.style.zoom=1}else this.style.display="inline-block"}if(c.isArray(a[k])){(h.specialEasing=h.specialEasing||{})[k]=a[k][1];a[k]=a[k][0]}}if(h.overflow!=null)this.style.overflow="hidden";h.curAnim=c.extend({},a);c.each(a,function(B,D){var H=new c.fx(s,h,B);if(tb.test(D))H[D==="toggle"?n?"show":"hide":D](a);else{var w=ub.exec(D),G=H.cur(true)||0;if(w){var M=parseFloat(w[2]),g=w[3]||"px";if(g!=="px"){c.style(s,B,(M||1)+g);
|
|
||||||
G=(M||1)/H.cur(true)*G;c.style(s,B,G+g)}if(w[1])M=(w[1]==="-="?-1:1)*M+G;H.custom(G,M,g)}else H.custom(G,D,"")}});return true})},stop:function(a,b){var d=c.timers;a&&this.queue([]);this.each(function(){for(var e=d.length-1;e>=0;e--)if(d[e].elem===this){b&&d[e](true);d.splice(e,1)}});b||this.dequeue();return this}});c.each({slideDown:S("show",1),slideUp:S("hide",1),slideToggle:S("toggle",1),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"}},function(a,b){c.fn[a]=function(d,e,f){return this.animate(b,
|
|
||||||
d,e,f)}});c.extend({speed:function(a,b,d){var e=a&&typeof a==="object"?c.extend({},a):{complete:d||!d&&b||c.isFunction(a)&&a,duration:a,easing:d&&b||b&&!c.isFunction(b)&&b};e.duration=c.fx.off?0:typeof e.duration==="number"?e.duration:e.duration in c.fx.speeds?c.fx.speeds[e.duration]:c.fx.speeds._default;e.old=e.complete;e.complete=function(){e.queue!==false&&c(this).dequeue();c.isFunction(e.old)&&e.old.call(this)};return e},easing:{linear:function(a,b,d,e){return d+e*a},swing:function(a,b,d,e){return(-Math.cos(a*
|
|
||||||
Math.PI)/2+0.5)*e+d}},timers:[],fx:function(a,b,d){this.options=b;this.elem=a;this.prop=d;if(!b.orig)b.orig={}}});c.fx.prototype={update:function(){this.options.step&&this.options.step.call(this.elem,this.now,this);(c.fx.step[this.prop]||c.fx.step._default)(this)},cur:function(){if(this.elem[this.prop]!=null&&(!this.elem.style||this.elem.style[this.prop]==null))return this.elem[this.prop];var a=parseFloat(c.css(this.elem,this.prop));return a&&a>-1E4?a:0},custom:function(a,b,d){function e(h){return f.step(h)}
|
|
||||||
this.startTime=c.now();this.start=a;this.end=b;this.unit=d||this.unit||"px";this.now=this.start;this.pos=this.state=0;var f=this;a=c.fx;e.elem=this.elem;if(e()&&c.timers.push(e)&&!aa)aa=setInterval(a.tick,a.interval)},show:function(){this.options.orig[this.prop]=c.style(this.elem,this.prop);this.options.show=true;this.custom(this.prop==="width"||this.prop==="height"?1:0,this.cur());c(this.elem).show()},hide:function(){this.options.orig[this.prop]=c.style(this.elem,this.prop);this.options.hide=true;
|
|
||||||
this.custom(this.cur(),0)},step:function(a){var b=c.now(),d=true;if(a||b>=this.options.duration+this.startTime){this.now=this.end;this.pos=this.state=1;this.update();this.options.curAnim[this.prop]=true;for(var e in this.options.curAnim)if(this.options.curAnim[e]!==true)d=false;if(d){if(this.options.overflow!=null&&!c.support.shrinkWrapBlocks){var f=this.elem,h=this.options;c.each(["","X","Y"],function(l,n){f.style["overflow"+n]=h.overflow[l]})}this.options.hide&&c(this.elem).hide();if(this.options.hide||
|
|
||||||
this.options.show)for(var k in this.options.curAnim)c.style(this.elem,k,this.options.orig[k]);this.options.complete.call(this.elem)}return false}else{a=b-this.startTime;this.state=a/this.options.duration;b=this.options.easing||(c.easing.swing?"swing":"linear");this.pos=c.easing[this.options.specialEasing&&this.options.specialEasing[this.prop]||b](this.state,a,0,1,this.options.duration);this.now=this.start+(this.end-this.start)*this.pos;this.update()}return true}};c.extend(c.fx,{tick:function(){for(var a=
|
|
||||||
c.timers,b=0;b<a.length;b++)a[b]()||a.splice(b--,1);a.length||c.fx.stop()},interval:13,stop:function(){clearInterval(aa);aa=null},speeds:{slow:600,fast:200,_default:400},step:{opacity:function(a){c.style(a.elem,"opacity",a.now)},_default:function(a){if(a.elem.style&&a.elem.style[a.prop]!=null)a.elem.style[a.prop]=(a.prop==="width"||a.prop==="height"?Math.max(0,a.now):a.now)+a.unit;else a.elem[a.prop]=a.now}}});if(c.expr&&c.expr.filters)c.expr.filters.animated=function(a){return c.grep(c.timers,function(b){return a===
|
|
||||||
b.elem}).length};var vb=/^t(?:able|d|h)$/i,Fa=/^(?:body|html)$/i;c.fn.offset="getBoundingClientRect"in u.documentElement?function(a){var b=this[0],d;if(a)return this.each(function(k){c.offset.setOffset(this,a,k)});if(!b||!b.ownerDocument)return null;if(b===b.ownerDocument.body)return c.offset.bodyOffset(b);try{d=b.getBoundingClientRect()}catch(e){}var f=b.ownerDocument,h=f.documentElement;if(!d||!c.contains(h,b))return d||{top:0,left:0};b=f.body;f=ea(f);return{top:d.top+(f.pageYOffset||c.support.boxModel&&
|
|
||||||
h.scrollTop||b.scrollTop)-(h.clientTop||b.clientTop||0),left:d.left+(f.pageXOffset||c.support.boxModel&&h.scrollLeft||b.scrollLeft)-(h.clientLeft||b.clientLeft||0)}}:function(a){var b=this[0];if(a)return this.each(function(s){c.offset.setOffset(this,a,s)});if(!b||!b.ownerDocument)return null;if(b===b.ownerDocument.body)return c.offset.bodyOffset(b);c.offset.initialize();var d=b.offsetParent,e=b.ownerDocument,f,h=e.documentElement,k=e.body;f=(e=e.defaultView)?e.getComputedStyle(b,null):b.currentStyle;
|
|
||||||
for(var l=b.offsetTop,n=b.offsetLeft;(b=b.parentNode)&&b!==k&&b!==h;){if(c.offset.supportsFixedPosition&&f.position==="fixed")break;f=e?e.getComputedStyle(b,null):b.currentStyle;l-=b.scrollTop;n-=b.scrollLeft;if(b===d){l+=b.offsetTop;n+=b.offsetLeft;if(c.offset.doesNotAddBorder&&!(c.offset.doesAddBorderForTableAndCells&&vb.test(b.nodeName))){l+=parseFloat(f.borderTopWidth)||0;n+=parseFloat(f.borderLeftWidth)||0}d=b.offsetParent}if(c.offset.subtractsBorderForOverflowNotVisible&&f.overflow!=="visible"){l+=
|
|
||||||
parseFloat(f.borderTopWidth)||0;n+=parseFloat(f.borderLeftWidth)||0}f=f}if(f.position==="relative"||f.position==="static"){l+=k.offsetTop;n+=k.offsetLeft}if(c.offset.supportsFixedPosition&&f.position==="fixed"){l+=Math.max(h.scrollTop,k.scrollTop);n+=Math.max(h.scrollLeft,k.scrollLeft)}return{top:l,left:n}};c.offset={initialize:function(){var a=u.body,b=u.createElement("div"),d,e,f,h=parseFloat(c.css(a,"marginTop"))||0;c.extend(b.style,{position:"absolute",top:0,left:0,margin:0,border:0,width:"1px",
|
|
||||||
height:"1px",visibility:"hidden"});b.innerHTML="<div style='position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;'><div></div></div><table style='position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;' cellpadding='0' cellspacing='0'><tr><td></td></tr></table>";a.insertBefore(b,a.firstChild);d=b.firstChild;e=d.firstChild;f=d.nextSibling.firstChild.firstChild;this.doesNotAddBorder=e.offsetTop!==5;this.doesAddBorderForTableAndCells=
|
|
||||||
f.offsetTop===5;e.style.position="fixed";e.style.top="20px";this.supportsFixedPosition=e.offsetTop===20||e.offsetTop===15;e.style.position=e.style.top="";d.style.overflow="hidden";d.style.position="relative";this.subtractsBorderForOverflowNotVisible=e.offsetTop===-5;this.doesNotIncludeMarginInBodyOffset=a.offsetTop!==h;a.removeChild(b);c.offset.initialize=c.noop},bodyOffset:function(a){var b=a.offsetTop,d=a.offsetLeft;c.offset.initialize();if(c.offset.doesNotIncludeMarginInBodyOffset){b+=parseFloat(c.css(a,
|
|
||||||
"marginTop"))||0;d+=parseFloat(c.css(a,"marginLeft"))||0}return{top:b,left:d}},setOffset:function(a,b,d){var e=c.css(a,"position");if(e==="static")a.style.position="relative";var f=c(a),h=f.offset(),k=c.css(a,"top"),l=c.css(a,"left"),n=e==="absolute"&&c.inArray("auto",[k,l])>-1;e={};var s={};if(n)s=f.position();k=n?s.top:parseInt(k,10)||0;l=n?s.left:parseInt(l,10)||0;if(c.isFunction(b))b=b.call(a,d,h);if(b.top!=null)e.top=b.top-h.top+k;if(b.left!=null)e.left=b.left-h.left+l;"using"in b?b.using.call(a,
|
|
||||||
e):f.css(e)}};c.fn.extend({position:function(){if(!this[0])return null;var a=this[0],b=this.offsetParent(),d=this.offset(),e=Fa.test(b[0].nodeName)?{top:0,left:0}:b.offset();d.top-=parseFloat(c.css(a,"marginTop"))||0;d.left-=parseFloat(c.css(a,"marginLeft"))||0;e.top+=parseFloat(c.css(b[0],"borderTopWidth"))||0;e.left+=parseFloat(c.css(b[0],"borderLeftWidth"))||0;return{top:d.top-e.top,left:d.left-e.left}},offsetParent:function(){return this.map(function(){for(var a=this.offsetParent||u.body;a&&!Fa.test(a.nodeName)&&
|
|
||||||
c.css(a,"position")==="static";)a=a.offsetParent;return a})}});c.each(["Left","Top"],function(a,b){var d="scroll"+b;c.fn[d]=function(e){var f=this[0],h;if(!f)return null;if(e!==A)return this.each(function(){if(h=ea(this))h.scrollTo(!a?e:c(h).scrollLeft(),a?e:c(h).scrollTop());else this[d]=e});else return(h=ea(f))?"pageXOffset"in h?h[a?"pageYOffset":"pageXOffset"]:c.support.boxModel&&h.document.documentElement[d]||h.document.body[d]:f[d]}});c.each(["Height","Width"],function(a,b){var d=b.toLowerCase();
|
|
||||||
c.fn["inner"+b]=function(){return this[0]?parseFloat(c.css(this[0],d,"padding")):null};c.fn["outer"+b]=function(e){return this[0]?parseFloat(c.css(this[0],d,e?"margin":"border")):null};c.fn[d]=function(e){var f=this[0];if(!f)return e==null?null:this;if(c.isFunction(e))return this.each(function(h){var k=c(this);k[d](e.call(this,h,k[d]()))});return c.isWindow(f)?f.document.compatMode==="CSS1Compat"&&f.document.documentElement["client"+b]||f.document.body["client"+b]:f.nodeType===9?Math.max(f.documentElement["client"+
|
|
||||||
b],f.body["scroll"+b],f.documentElement["scroll"+b],f.body["offset"+b],f.documentElement["offset"+b]):e===A?parseFloat(c.css(f,d)):this.css(d,typeof e==="string"?e:e+"px")}})})(window);
|
|
151
www/js/jquery-1.4.min.js
vendored
151
www/js/jquery-1.4.min.js
vendored
@ -1,151 +0,0 @@
|
|||||||
/*!
|
|
||||||
* jQuery JavaScript Library v1.4
|
|
||||||
* http://jquery.com/
|
|
||||||
*
|
|
||||||
* Copyright 2010, John Resig
|
|
||||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
|
||||||
* http://docs.jquery.com/License
|
|
||||||
*
|
|
||||||
* Includes Sizzle.js
|
|
||||||
* http://sizzlejs.com/
|
|
||||||
* Copyright 2010, The Dojo Foundation
|
|
||||||
* Released under the MIT, BSD, and GPL Licenses.
|
|
||||||
*
|
|
||||||
* Date: Wed Jan 13 15:23:05 2010 -0500
|
|
||||||
*/
|
|
||||||
(function(A,w){function oa(){if(!c.isReady){try{s.documentElement.doScroll("left")}catch(a){setTimeout(oa,1);return}c.ready()}}function La(a,b){b.src?c.ajax({url:b.src,async:false,dataType:"script"}):c.globalEval(b.text||b.textContent||b.innerHTML||"");b.parentNode&&b.parentNode.removeChild(b)}function $(a,b,d,f,e,i){var j=a.length;if(typeof b==="object"){for(var o in b)$(a,o,b[o],f,e,d);return a}if(d!==w){f=!i&&f&&c.isFunction(d);for(o=0;o<j;o++)e(a[o],b,f?d.call(a[o],o,e(a[o],b)):d,i);return a}return j?
|
|
||||||
e(a[0],b):null}function K(){return(new Date).getTime()}function aa(){return false}function ba(){return true}function pa(a,b,d){d[0].type=a;return c.event.handle.apply(b,d)}function qa(a){var b=true,d=[],f=[],e=arguments,i,j,o,p,n,t=c.extend({},c.data(this,"events").live);for(p in t){j=t[p];if(j.live===a.type||j.altLive&&c.inArray(a.type,j.altLive)>-1){i=j.data;i.beforeFilter&&i.beforeFilter[a.type]&&!i.beforeFilter[a.type](a)||f.push(j.selector)}else delete t[p]}i=c(a.target).closest(f,a.currentTarget);
|
|
||||||
n=0;for(l=i.length;n<l;n++)for(p in t){j=t[p];o=i[n].elem;f=null;if(i[n].selector===j.selector){if(j.live==="mouseenter"||j.live==="mouseleave")f=c(a.relatedTarget).closest(j.selector)[0];if(!f||f!==o)d.push({elem:o,fn:j})}}n=0;for(l=d.length;n<l;n++){i=d[n];a.currentTarget=i.elem;a.data=i.fn.data;if(i.fn.apply(i.elem,e)===false){b=false;break}}return b}function ra(a,b){return["live",a,b.replace(/\./g,"`").replace(/ /g,"&")].join(".")}function sa(a){return!a||!a.parentNode||a.parentNode.nodeType===
|
|
||||||
11}function ta(a,b){var d=0;b.each(function(){if(this.nodeName===(a[d]&&a[d].nodeName)){var f=c.data(a[d++]),e=c.data(this,f);if(f=f&&f.events){delete e.handle;e.events={};for(var i in f)for(var j in f[i])c.event.add(this,i,f[i][j],f[i][j].data)}}})}function ua(a,b,d){var f,e,i;if(a.length===1&&typeof a[0]==="string"&&a[0].length<512&&a[0].indexOf("<option")<0){e=true;if(i=c.fragments[a[0]])if(i!==1)f=i}if(!f){b=b&&b[0]?b[0].ownerDocument||b[0]:s;f=b.createDocumentFragment();c.clean(a,b,f,d)}if(e)c.fragments[a[0]]=
|
|
||||||
i?f:1;return{fragment:f,cacheable:e}}function T(a){for(var b=0,d,f;(d=a[b])!=null;b++)if(!c.noData[d.nodeName.toLowerCase()]&&(f=d[H]))delete c.cache[f]}function L(a,b){var d={};c.each(va.concat.apply([],va.slice(0,b)),function(){d[this]=a});return d}function wa(a){return"scrollTo"in a&&a.document?a:a.nodeType===9?a.defaultView||a.parentWindow:false}var c=function(a,b){return new c.fn.init(a,b)},Ma=A.jQuery,Na=A.$,s=A.document,U,Oa=/^[^<]*(<[\w\W]+>)[^>]*$|^#([\w-]+)$/,Pa=/^.[^:#\[\.,]*$/,Qa=/\S/,
|
|
||||||
Ra=/^(\s|\u00A0)+|(\s|\u00A0)+$/g,Sa=/^<(\w+)\s*\/?>(?:<\/\1>)?$/,P=navigator.userAgent,xa=false,Q=[],M,ca=Object.prototype.toString,da=Object.prototype.hasOwnProperty,ea=Array.prototype.push,R=Array.prototype.slice,V=Array.prototype.indexOf;c.fn=c.prototype={init:function(a,b){var d,f;if(!a)return this;if(a.nodeType){this.context=this[0]=a;this.length=1;return this}if(typeof a==="string")if((d=Oa.exec(a))&&(d[1]||!b))if(d[1]){f=b?b.ownerDocument||b:s;if(a=Sa.exec(a))if(c.isPlainObject(b)){a=[s.createElement(a[1])];
|
|
||||||
c.fn.attr.call(a,b,true)}else a=[f.createElement(a[1])];else{a=ua([d[1]],[f]);a=(a.cacheable?a.fragment.cloneNode(true):a.fragment).childNodes}}else{if(b=s.getElementById(d[2])){if(b.id!==d[2])return U.find(a);this.length=1;this[0]=b}this.context=s;this.selector=a;return this}else if(!b&&/^\w+$/.test(a)){this.selector=a;this.context=s;a=s.getElementsByTagName(a)}else return!b||b.jquery?(b||U).find(a):c(b).find(a);else if(c.isFunction(a))return U.ready(a);if(a.selector!==w){this.selector=a.selector;
|
|
||||||
this.context=a.context}return c.isArray(a)?this.setArray(a):c.makeArray(a,this)},selector:"",jquery:"1.4",length:0,size:function(){return this.length},toArray:function(){return R.call(this,0)},get:function(a){return a==null?this.toArray():a<0?this.slice(a)[0]:this[a]},pushStack:function(a,b,d){a=c(a||null);a.prevObject=this;a.context=this.context;if(b==="find")a.selector=this.selector+(this.selector?" ":"")+d;else if(b)a.selector=this.selector+"."+b+"("+d+")";return a},setArray:function(a){this.length=
|
|
||||||
0;ea.apply(this,a);return this},each:function(a,b){return c.each(this,a,b)},ready:function(a){c.bindReady();if(c.isReady)a.call(s,c);else Q&&Q.push(a);return this},eq:function(a){return a===-1?this.slice(a):this.slice(a,+a+1)},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},slice:function(){return this.pushStack(R.apply(this,arguments),"slice",R.call(arguments).join(","))},map:function(a){return this.pushStack(c.map(this,function(b,d){return a.call(b,d,b)}))},end:function(){return this.prevObject||
|
|
||||||
c(null)},push:ea,sort:[].sort,splice:[].splice};c.fn.init.prototype=c.fn;c.extend=c.fn.extend=function(){var a=arguments[0]||{},b=1,d=arguments.length,f=false,e,i,j,o;if(typeof a==="boolean"){f=a;a=arguments[1]||{};b=2}if(typeof a!=="object"&&!c.isFunction(a))a={};if(d===b){a=this;--b}for(;b<d;b++)if((e=arguments[b])!=null)for(i in e){j=a[i];o=e[i];if(a!==o)if(f&&o&&(c.isPlainObject(o)||c.isArray(o))){j=j&&(c.isPlainObject(j)||c.isArray(j))?j:c.isArray(o)?[]:{};a[i]=c.extend(f,j,o)}else if(o!==w)a[i]=
|
|
||||||
o}return a};c.extend({noConflict:function(a){A.$=Na;if(a)A.jQuery=Ma;return c},isReady:false,ready:function(){if(!c.isReady){if(!s.body)return setTimeout(c.ready,13);c.isReady=true;if(Q){for(var a,b=0;a=Q[b++];)a.call(s,c);Q=null}c.fn.triggerHandler&&c(s).triggerHandler("ready")}},bindReady:function(){if(!xa){xa=true;if(s.readyState==="complete")return c.ready();if(s.addEventListener){s.addEventListener("DOMContentLoaded",M,false);A.addEventListener("load",c.ready,false)}else if(s.attachEvent){s.attachEvent("onreadystatechange",
|
|
||||||
M);A.attachEvent("onload",c.ready);var a=false;try{a=A.frameElement==null}catch(b){}s.documentElement.doScroll&&a&&oa()}}},isFunction:function(a){return ca.call(a)==="[object Function]"},isArray:function(a){return ca.call(a)==="[object Array]"},isPlainObject:function(a){if(!a||ca.call(a)!=="[object Object]"||a.nodeType||a.setInterval)return false;if(a.constructor&&!da.call(a,"constructor")&&!da.call(a.constructor.prototype,"isPrototypeOf"))return false;var b;for(b in a);return b===w||da.call(a,b)},
|
|
||||||
isEmptyObject:function(a){for(var b in a)return false;return true},noop:function(){},globalEval:function(a){if(a&&Qa.test(a)){var b=s.getElementsByTagName("head")[0]||s.documentElement,d=s.createElement("script");d.type="text/javascript";if(c.support.scriptEval)d.appendChild(s.createTextNode(a));else d.text=a;b.insertBefore(d,b.firstChild);b.removeChild(d)}},nodeName:function(a,b){return a.nodeName&&a.nodeName.toUpperCase()===b.toUpperCase()},each:function(a,b,d){var f,e=0,i=a.length,j=i===w||c.isFunction(a);
|
|
||||||
if(d)if(j)for(f in a){if(b.apply(a[f],d)===false)break}else for(;e<i;){if(b.apply(a[e++],d)===false)break}else if(j)for(f in a){if(b.call(a[f],f,a[f])===false)break}else for(d=a[0];e<i&&b.call(d,e,d)!==false;d=a[++e]);return a},trim:function(a){return(a||"").replace(Ra,"")},makeArray:function(a,b){b=b||[];if(a!=null)a.length==null||typeof a==="string"||c.isFunction(a)||typeof a!=="function"&&a.setInterval?ea.call(b,a):c.merge(b,a);return b},inArray:function(a,b){if(b.indexOf)return b.indexOf(a);for(var d=
|
|
||||||
0,f=b.length;d<f;d++)if(b[d]===a)return d;return-1},merge:function(a,b){var d=a.length,f=0;if(typeof b.length==="number")for(var e=b.length;f<e;f++)a[d++]=b[f];else for(;b[f]!==w;)a[d++]=b[f++];a.length=d;return a},grep:function(a,b,d){for(var f=[],e=0,i=a.length;e<i;e++)!d!==!b(a[e],e)&&f.push(a[e]);return f},map:function(a,b,d){for(var f=[],e,i=0,j=a.length;i<j;i++){e=b(a[i],i,d);if(e!=null)f[f.length]=e}return f.concat.apply([],f)},guid:1,proxy:function(a,b,d){if(arguments.length===2)if(typeof b===
|
|
||||||
"string"){d=a;a=d[b];b=w}else if(b&&!c.isFunction(b)){d=b;b=w}if(!b&&a)b=function(){return a.apply(d||this,arguments)};if(a)b.guid=a.guid=a.guid||b.guid||c.guid++;return b},uaMatch:function(a){var b={browser:""};a=a.toLowerCase();if(/webkit/.test(a))b={browser:"webkit",version:/webkit[\/ ]([\w.]+)/};else if(/opera/.test(a))b={browser:"opera",version:/version/.test(a)?/version[\/ ]([\w.]+)/:/opera[\/ ]([\w.]+)/};else if(/msie/.test(a))b={browser:"msie",version:/msie ([\w.]+)/};else if(/mozilla/.test(a)&&
|
|
||||||
!/compatible/.test(a))b={browser:"mozilla",version:/rv:([\w.]+)/};b.version=(b.version&&b.version.exec(a)||[0,"0"])[1];return b},browser:{}});P=c.uaMatch(P);if(P.browser){c.browser[P.browser]=true;c.browser.version=P.version}if(c.browser.webkit)c.browser.safari=true;if(V)c.inArray=function(a,b){return V.call(b,a)};U=c(s);if(s.addEventListener)M=function(){s.removeEventListener("DOMContentLoaded",M,false);c.ready()};else if(s.attachEvent)M=function(){if(s.readyState==="complete"){s.detachEvent("onreadystatechange",
|
|
||||||
M);c.ready()}};if(V)c.inArray=function(a,b){return V.call(b,a)};(function(){c.support={};var a=s.documentElement,b=s.createElement("script"),d=s.createElement("div"),f="script"+K();d.style.display="none";d.innerHTML=" <link/><table></table><a href='/a' style='color:red;float:left;opacity:.55;'>a</a><input type='checkbox'/>";var e=d.getElementsByTagName("*"),i=d.getElementsByTagName("a")[0];if(!(!e||!e.length||!i)){c.support={leadingWhitespace:d.firstChild.nodeType===3,tbody:!d.getElementsByTagName("tbody").length,
|
|
||||||
htmlSerialize:!!d.getElementsByTagName("link").length,style:/red/.test(i.getAttribute("style")),hrefNormalized:i.getAttribute("href")==="/a",opacity:/^0.55$/.test(i.style.opacity),cssFloat:!!i.style.cssFloat,checkOn:d.getElementsByTagName("input")[0].value==="on",optSelected:s.createElement("select").appendChild(s.createElement("option")).selected,scriptEval:false,noCloneEvent:true,boxModel:null};b.type="text/javascript";try{b.appendChild(s.createTextNode("window."+f+"=1;"))}catch(j){}a.insertBefore(b,
|
|
||||||
a.firstChild);if(A[f]){c.support.scriptEval=true;delete A[f]}a.removeChild(b);if(d.attachEvent&&d.fireEvent){d.attachEvent("onclick",function o(){c.support.noCloneEvent=false;d.detachEvent("onclick",o)});d.cloneNode(true).fireEvent("onclick")}c(function(){var o=s.createElement("div");o.style.width=o.style.paddingLeft="1px";s.body.appendChild(o);c.boxModel=c.support.boxModel=o.offsetWidth===2;s.body.removeChild(o).style.display="none"});a=function(o){var p=s.createElement("div");o="on"+o;var n=o in
|
|
||||||
p;if(!n){p.setAttribute(o,"return;");n=typeof p[o]==="function"}return n};c.support.submitBubbles=a("submit");c.support.changeBubbles=a("change");a=b=d=e=i=null}})();c.props={"for":"htmlFor","class":"className",readonly:"readOnly",maxlength:"maxLength",cellspacing:"cellSpacing",rowspan:"rowSpan",colspan:"colSpan",tabindex:"tabIndex",usemap:"useMap",frameborder:"frameBorder"};var H="jQuery"+K(),Ta=0,ya={},Ua={};c.extend({cache:{},expando:H,noData:{embed:true,object:true,applet:true},data:function(a,
|
|
||||||
b,d){if(!(a.nodeName&&c.noData[a.nodeName.toLowerCase()])){a=a==A?ya:a;var f=a[H],e=c.cache;if(!b&&!f)return null;f||(f=++Ta);if(typeof b==="object"){a[H]=f;e=e[f]=c.extend(true,{},b)}else e=e[f]?e[f]:typeof d==="undefined"?Ua:(e[f]={});if(d!==w){a[H]=f;e[b]=d}return typeof b==="string"?e[b]:e}},removeData:function(a,b){if(!(a.nodeName&&c.noData[a.nodeName.toLowerCase()])){a=a==A?ya:a;var d=a[H],f=c.cache,e=f[d];if(b){if(e){delete e[b];c.isEmptyObject(e)&&c.removeData(a)}}else{try{delete a[H]}catch(i){a.removeAttribute&&
|
|
||||||
a.removeAttribute(H)}delete f[d]}}}});c.fn.extend({data:function(a,b){if(typeof a==="undefined"&&this.length)return c.data(this[0]);else if(typeof a==="object")return this.each(function(){c.data(this,a)});var d=a.split(".");d[1]=d[1]?"."+d[1]:"";if(b===w){var f=this.triggerHandler("getData"+d[1]+"!",[d[0]]);if(f===w&&this.length)f=c.data(this[0],a);return f===w&&d[1]?this.data(d[0]):f}else return this.trigger("setData"+d[1]+"!",[d[0],b]).each(function(){c.data(this,a,b)})},removeData:function(a){return this.each(function(){c.removeData(this,
|
|
||||||
a)})}});c.extend({queue:function(a,b,d){if(a){b=(b||"fx")+"queue";var f=c.data(a,b);if(!d)return f||[];if(!f||c.isArray(d))f=c.data(a,b,c.makeArray(d));else f.push(d);return f}},dequeue:function(a,b){b=b||"fx";var d=c.queue(a,b),f=d.shift();if(f==="inprogress")f=d.shift();if(f){b==="fx"&&d.unshift("inprogress");f.call(a,function(){c.dequeue(a,b)})}}});c.fn.extend({queue:function(a,b){if(typeof a!=="string"){b=a;a="fx"}if(b===w)return c.queue(this[0],a);return this.each(function(){var d=c.queue(this,
|
|
||||||
a,b);a==="fx"&&d[0]!=="inprogress"&&c.dequeue(this,a)})},dequeue:function(a){return this.each(function(){c.dequeue(this,a)})},delay:function(a,b){a=c.fx?c.fx.speeds[a]||a:a;b=b||"fx";return this.queue(b,function(){var d=this;setTimeout(function(){c.dequeue(d,b)},a)})},clearQueue:function(a){return this.queue(a||"fx",[])}});var za=/[\n\t]/g,fa=/\s+/,Va=/\r/g,Wa=/href|src|style/,Xa=/(button|input)/i,Ya=/(button|input|object|select|textarea)/i,Za=/^(a|area)$/i,Aa=/radio|checkbox/;c.fn.extend({attr:function(a,
|
|
||||||
b){return $(this,a,b,true,c.attr)},removeAttr:function(a){return this.each(function(){c.attr(this,a,"");this.nodeType===1&&this.removeAttribute(a)})},addClass:function(a){if(c.isFunction(a))return this.each(function(p){var n=c(this);n.addClass(a.call(this,p,n.attr("class")))});if(a&&typeof a==="string")for(var b=(a||"").split(fa),d=0,f=this.length;d<f;d++){var e=this[d];if(e.nodeType===1)if(e.className)for(var i=" "+e.className+" ",j=0,o=b.length;j<o;j++){if(i.indexOf(" "+b[j]+" ")<0)e.className+=
|
|
||||||
" "+b[j]}else e.className=a}return this},removeClass:function(a){if(c.isFunction(a))return this.each(function(p){var n=c(this);n.removeClass(a.call(this,p,n.attr("class")))});if(a&&typeof a==="string"||a===w)for(var b=(a||"").split(fa),d=0,f=this.length;d<f;d++){var e=this[d];if(e.nodeType===1&&e.className)if(a){for(var i=(" "+e.className+" ").replace(za," "),j=0,o=b.length;j<o;j++)i=i.replace(" "+b[j]+" "," ");e.className=i.substring(1,i.length-1)}else e.className=""}return this},toggleClass:function(a,
|
|
||||||
b){var d=typeof a,f=typeof b==="boolean";if(c.isFunction(a))return this.each(function(e){var i=c(this);i.toggleClass(a.call(this,e,i.attr("class"),b),b)});return this.each(function(){if(d==="string")for(var e,i=0,j=c(this),o=b,p=a.split(fa);e=p[i++];){o=f?o:!j.hasClass(e);j[o?"addClass":"removeClass"](e)}else if(d==="undefined"||d==="boolean"){this.className&&c.data(this,"__className__",this.className);this.className=this.className||a===false?"":c.data(this,"__className__")||""}})},hasClass:function(a){a=
|
|
||||||
" "+a+" ";for(var b=0,d=this.length;b<d;b++)if((" "+this[b].className+" ").replace(za," ").indexOf(a)>-1)return true;return false},val:function(a){if(a===w){var b=this[0];if(b){if(c.nodeName(b,"option"))return(b.attributes.value||{}).specified?b.value:b.text;if(c.nodeName(b,"select")){var d=b.selectedIndex,f=[],e=b.options;b=b.type==="select-one";if(d<0)return null;var i=b?d:0;for(d=b?d+1:e.length;i<d;i++){var j=e[i];if(j.selected){a=c(j).val();if(b)return a;f.push(a)}}return f}if(Aa.test(b.type)&&
|
|
||||||
!c.support.checkOn)return b.getAttribute("value")===null?"on":b.value;return(b.value||"").replace(Va,"")}return w}var o=c.isFunction(a);return this.each(function(p){var n=c(this),t=a;if(this.nodeType===1){if(o)t=a.call(this,p,n.val());if(typeof t==="number")t+="";if(c.isArray(t)&&Aa.test(this.type))this.checked=c.inArray(n.val(),t)>=0;else if(c.nodeName(this,"select")){var z=c.makeArray(t);c("option",this).each(function(){this.selected=c.inArray(c(this).val(),z)>=0});if(!z.length)this.selectedIndex=
|
|
||||||
-1}else this.value=t}})}});c.extend({attrFn:{val:true,css:true,html:true,text:true,data:true,width:true,height:true,offset:true},attr:function(a,b,d,f){if(!a||a.nodeType===3||a.nodeType===8)return w;if(f&&b in c.attrFn)return c(a)[b](d);f=a.nodeType!==1||!c.isXMLDoc(a);var e=d!==w;b=f&&c.props[b]||b;if(a.nodeType===1){var i=Wa.test(b);if(b in a&&f&&!i){if(e){if(b==="type"&&Xa.test(a.nodeName)&&a.parentNode)throw"type property can't be changed";a[b]=d}if(c.nodeName(a,"form")&&a.getAttributeNode(b))return a.getAttributeNode(b).nodeValue;
|
|
||||||
if(b==="tabIndex")return(b=a.getAttributeNode("tabIndex"))&&b.specified?b.value:Ya.test(a.nodeName)||Za.test(a.nodeName)&&a.href?0:w;return a[b]}if(!c.support.style&&f&&b==="style"){if(e)a.style.cssText=""+d;return a.style.cssText}e&&a.setAttribute(b,""+d);a=!c.support.hrefNormalized&&f&&i?a.getAttribute(b,2):a.getAttribute(b);return a===null?w:a}return c.style(a,b,d)}});var $a=function(a){return a.replace(/[^\w\s\.\|`]/g,function(b){return"\\"+b})};c.event={add:function(a,b,d,f){if(!(a.nodeType===
|
|
||||||
3||a.nodeType===8)){if(a.setInterval&&a!==A&&!a.frameElement)a=A;if(!d.guid)d.guid=c.guid++;if(f!==w){d=c.proxy(d);d.data=f}var e=c.data(a,"events")||c.data(a,"events",{}),i=c.data(a,"handle"),j;if(!i){j=function(){return typeof c!=="undefined"&&!c.event.triggered?c.event.handle.apply(j.elem,arguments):w};i=c.data(a,"handle",j)}if(i){i.elem=a;b=b.split(/\s+/);for(var o,p=0;o=b[p++];){var n=o.split(".");o=n.shift();d.type=n.slice(0).sort().join(".");var t=e[o],z=this.special[o]||{};if(!t){t=e[o]={};
|
|
||||||
if(!z.setup||z.setup.call(a,f,n,d)===false)if(a.addEventListener)a.addEventListener(o,i,false);else a.attachEvent&&a.attachEvent("on"+o,i)}if(z.add)if((n=z.add.call(a,d,f,n,t))&&c.isFunction(n)){n.guid=n.guid||d.guid;d=n}t[d.guid]=d;this.global[o]=true}a=null}}},global:{},remove:function(a,b,d){if(!(a.nodeType===3||a.nodeType===8)){var f=c.data(a,"events"),e,i,j;if(f){if(b===w||typeof b==="string"&&b.charAt(0)===".")for(i in f)this.remove(a,i+(b||""));else{if(b.type){d=b.handler;b=b.type}b=b.split(/\s+/);
|
|
||||||
for(var o=0;i=b[o++];){var p=i.split(".");i=p.shift();var n=!p.length,t=c.map(p.slice(0).sort(),$a);t=new RegExp("(^|\\.)"+t.join("\\.(?:.*\\.)?")+"(\\.|$)");var z=this.special[i]||{};if(f[i]){if(d){j=f[i][d.guid];delete f[i][d.guid]}else for(var B in f[i])if(n||t.test(f[i][B].type))delete f[i][B];z.remove&&z.remove.call(a,p,j);for(e in f[i])break;if(!e){if(!z.teardown||z.teardown.call(a,p)===false)if(a.removeEventListener)a.removeEventListener(i,c.data(a,"handle"),false);else a.detachEvent&&a.detachEvent("on"+
|
|
||||||
i,c.data(a,"handle"));e=null;delete f[i]}}}}for(e in f)break;if(!e){if(B=c.data(a,"handle"))B.elem=null;c.removeData(a,"events");c.removeData(a,"handle")}}}},trigger:function(a,b,d,f){var e=a.type||a;if(!f){a=typeof a==="object"?a[H]?a:c.extend(c.Event(e),a):c.Event(e);if(e.indexOf("!")>=0){a.type=e=e.slice(0,-1);a.exclusive=true}if(!d){a.stopPropagation();this.global[e]&&c.each(c.cache,function(){this.events&&this.events[e]&&c.event.trigger(a,b,this.handle.elem)})}if(!d||d.nodeType===3||d.nodeType===
|
|
||||||
8)return w;a.result=w;a.target=d;b=c.makeArray(b);b.unshift(a)}a.currentTarget=d;var i=c.data(d,"handle");i&&i.apply(d,b);var j,o;try{if(!(d&&d.nodeName&&c.noData[d.nodeName.toLowerCase()])){j=d[e];o=d["on"+e]}}catch(p){}i=c.nodeName(d,"a")&&e==="click";if(!f&&j&&!a.isDefaultPrevented()&&!i){this.triggered=true;try{d[e]()}catch(n){}}else if(o&&d["on"+e].apply(d,b)===false)a.result=false;this.triggered=false;if(!a.isPropagationStopped())(d=d.parentNode||d.ownerDocument)&&c.event.trigger(a,b,d,true)},
|
|
||||||
handle:function(a){var b,d;a=arguments[0]=c.event.fix(a||A.event);a.currentTarget=this;d=a.type.split(".");a.type=d.shift();b=!d.length&&!a.exclusive;var f=new RegExp("(^|\\.)"+d.slice(0).sort().join("\\.(?:.*\\.)?")+"(\\.|$)");d=(c.data(this,"events")||{})[a.type];for(var e in d){var i=d[e];if(b||f.test(i.type)){a.handler=i;a.data=i.data;i=i.apply(this,arguments);if(i!==w){a.result=i;if(i===false){a.preventDefault();a.stopPropagation()}}if(a.isImmediatePropagationStopped())break}}return a.result},
|
|
||||||
props:"altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode layerX layerY metaKey newValue offsetX offsetY originalTarget pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" "),fix:function(a){if(a[H])return a;var b=a;a=c.Event(b);for(var d=this.props.length,f;d;){f=this.props[--d];a[f]=b[f]}if(!a.target)a.target=a.srcElement||
|
|
||||||
s;if(a.target.nodeType===3)a.target=a.target.parentNode;if(!a.relatedTarget&&a.fromElement)a.relatedTarget=a.fromElement===a.target?a.toElement:a.fromElement;if(a.pageX==null&&a.clientX!=null){b=s.documentElement;d=s.body;a.pageX=a.clientX+(b&&b.scrollLeft||d&&d.scrollLeft||0)-(b&&b.clientLeft||d&&d.clientLeft||0);a.pageY=a.clientY+(b&&b.scrollTop||d&&d.scrollTop||0)-(b&&b.clientTop||d&&d.clientTop||0)}if(!a.which&&(a.charCode||a.charCode===0?a.charCode:a.keyCode))a.which=a.charCode||a.keyCode;if(!a.metaKey&&
|
|
||||||
a.ctrlKey)a.metaKey=a.ctrlKey;if(!a.which&&a.button!==w)a.which=a.button&1?1:a.button&2?3:a.button&4?2:0;return a},guid:1E8,proxy:c.proxy,special:{ready:{setup:c.bindReady,teardown:c.noop},live:{add:function(a,b){c.extend(a,b||{});a.guid+=b.selector+b.live;c.event.add(this,b.live,qa,b)},remove:function(a){if(a.length){var b=0,d=new RegExp("(^|\\.)"+a[0]+"(\\.|$)");c.each(c.data(this,"events").live||{},function(){d.test(this.type)&&b++});b<1&&c.event.remove(this,a[0],qa)}},special:{}},beforeunload:{setup:function(a,
|
|
||||||
b,d){if(this.setInterval)this.onbeforeunload=d;return false},teardown:function(a,b){if(this.onbeforeunload===b)this.onbeforeunload=null}}}};c.Event=function(a){if(!this.preventDefault)return new c.Event(a);if(a&&a.type){this.originalEvent=a;this.type=a.type}else this.type=a;this.timeStamp=K();this[H]=true};c.Event.prototype={preventDefault:function(){this.isDefaultPrevented=ba;var a=this.originalEvent;if(a){a.preventDefault&&a.preventDefault();a.returnValue=false}},stopPropagation:function(){this.isPropagationStopped=
|
|
||||||
ba;var a=this.originalEvent;if(a){a.stopPropagation&&a.stopPropagation();a.cancelBubble=true}},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=ba;this.stopPropagation()},isDefaultPrevented:aa,isPropagationStopped:aa,isImmediatePropagationStopped:aa};var Ba=function(a){for(var b=a.relatedTarget;b&&b!==this;)try{b=b.parentNode}catch(d){break}if(b!==this){a.type=a.data;c.event.handle.apply(this,arguments)}},Ca=function(a){a.type=a.data;c.event.handle.apply(this,arguments)};c.each({mouseenter:"mouseover",
|
|
||||||
mouseleave:"mouseout"},function(a,b){c.event.special[a]={setup:function(d){c.event.add(this,b,d&&d.selector?Ca:Ba,a)},teardown:function(d){c.event.remove(this,b,d&&d.selector?Ca:Ba)}}});if(!c.support.submitBubbles)c.event.special.submit={setup:function(a,b,d){if(this.nodeName.toLowerCase()!=="form"){c.event.add(this,"click.specialSubmit."+d.guid,function(f){var e=f.target,i=e.type;if((i==="submit"||i==="image")&&c(e).closest("form").length)return pa("submit",this,arguments)});c.event.add(this,"keypress.specialSubmit."+
|
|
||||||
d.guid,function(f){var e=f.target,i=e.type;if((i==="text"||i==="password")&&c(e).closest("form").length&&f.keyCode===13)return pa("submit",this,arguments)})}else return false},remove:function(a,b){c.event.remove(this,"click.specialSubmit"+(b?"."+b.guid:""));c.event.remove(this,"keypress.specialSubmit"+(b?"."+b.guid:""))}};if(!c.support.changeBubbles){var ga=/textarea|input|select/i;function Da(a){var b=a.type,d=a.value;if(b==="radio"||b==="checkbox")d=a.checked;else if(b==="select-multiple")d=a.selectedIndex>
|
|
||||||
-1?c.map(a.options,function(f){return f.selected}).join("-"):"";else if(a.nodeName.toLowerCase()==="select")d=a.selectedIndex;return d}function ha(a,b){var d=a.target,f,e;if(!(!ga.test(d.nodeName)||d.readOnly)){f=c.data(d,"_change_data");e=Da(d);if(e!==f){if(a.type!=="focusout"||d.type!=="radio")c.data(d,"_change_data",e);if(d.type!=="select"&&(f!=null||e)){a.type="change";return c.event.trigger(a,b,this)}}}}c.event.special.change={filters:{focusout:ha,click:function(a){var b=a.target,d=b.type;if(d===
|
|
||||||
"radio"||d==="checkbox"||b.nodeName.toLowerCase()==="select")return ha.call(this,a)},keydown:function(a){var b=a.target,d=b.type;if(a.keyCode===13&&b.nodeName.toLowerCase()!=="textarea"||a.keyCode===32&&(d==="checkbox"||d==="radio")||d==="select-multiple")return ha.call(this,a)},beforeactivate:function(a){a=a.target;a.nodeName.toLowerCase()==="input"&&a.type==="radio"&&c.data(a,"_change_data",Da(a))}},setup:function(a,b,d){for(var f in W)c.event.add(this,f+".specialChange."+d.guid,W[f]);return ga.test(this.nodeName)},
|
|
||||||
remove:function(a,b){for(var d in W)c.event.remove(this,d+".specialChange"+(b?"."+b.guid:""),W[d]);return ga.test(this.nodeName)}};var W=c.event.special.change.filters}s.addEventListener&&c.each({focus:"focusin",blur:"focusout"},function(a,b){function d(f){f=c.event.fix(f);f.type=b;return c.event.handle.call(this,f)}c.event.special[b]={setup:function(){this.addEventListener(a,d,true)},teardown:function(){this.removeEventListener(a,d,true)}}});c.each(["bind","one"],function(a,b){c.fn[b]=function(d,
|
|
||||||
f,e){if(typeof d==="object"){for(var i in d)this[b](i,f,d[i],e);return this}if(c.isFunction(f)){thisObject=e;e=f;f=w}var j=b==="one"?c.proxy(e,function(o){c(this).unbind(o,j);return e.apply(this,arguments)}):e;return d==="unload"&&b!=="one"?this.one(d,f,e,thisObject):this.each(function(){c.event.add(this,d,j,f)})}});c.fn.extend({unbind:function(a,b){if(typeof a==="object"&&!a.preventDefault){for(var d in a)this.unbind(d,a[d]);return this}return this.each(function(){c.event.remove(this,a,b)})},trigger:function(a,
|
|
||||||
b){return this.each(function(){c.event.trigger(a,b,this)})},triggerHandler:function(a,b){if(this[0]){a=c.Event(a);a.preventDefault();a.stopPropagation();c.event.trigger(a,b,this[0]);return a.result}},toggle:function(a){for(var b=arguments,d=1;d<b.length;)c.proxy(a,b[d++]);return this.click(c.proxy(a,function(f){var e=(c.data(this,"lastToggle"+a.guid)||0)%d;c.data(this,"lastToggle"+a.guid,e+1);f.preventDefault();return b[e].apply(this,arguments)||false}))},hover:function(a,b){return this.mouseenter(a).mouseleave(b||
|
|
||||||
a)},live:function(a,b,d){if(c.isFunction(b)){d=b;b=w}c(this.context).bind(ra(a,this.selector),{data:b,selector:this.selector,live:a},d);return this},die:function(a,b){c(this.context).unbind(ra(a,this.selector),b?{guid:b.guid+this.selector+a}:null);return this}});c.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error".split(" "),function(a,b){c.fn[b]=function(d){return d?
|
|
||||||
this.bind(b,d):this.trigger(b)};if(c.attrFn)c.attrFn[b]=true});A.attachEvent&&!A.addEventListener&&A.attachEvent("onunload",function(){for(var a in c.cache)if(c.cache[a].handle)try{c.event.remove(c.cache[a].handle.elem)}catch(b){}});(function(){function a(g){for(var h="",k,m=0;g[m];m++){k=g[m];if(k.nodeType===3||k.nodeType===4)h+=k.nodeValue;else if(k.nodeType!==8)h+=a(k.childNodes)}return h}function b(g,h,k,m,r,q){r=0;for(var v=m.length;r<v;r++){var u=m[r];if(u){u=u[g];for(var y=false;u;){if(u.sizcache===
|
|
||||||
k){y=m[u.sizset];break}if(u.nodeType===1&&!q){u.sizcache=k;u.sizset=r}if(u.nodeName.toLowerCase()===h){y=u;break}u=u[g]}m[r]=y}}}function d(g,h,k,m,r,q){r=0;for(var v=m.length;r<v;r++){var u=m[r];if(u){u=u[g];for(var y=false;u;){if(u.sizcache===k){y=m[u.sizset];break}if(u.nodeType===1){if(!q){u.sizcache=k;u.sizset=r}if(typeof h!=="string"){if(u===h){y=true;break}}else if(p.filter(h,[u]).length>0){y=u;break}}u=u[g]}m[r]=y}}}var f=/((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|['"][^'"]*['"]|[^[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g,
|
|
||||||
e=0,i=Object.prototype.toString,j=false,o=true;[0,0].sort(function(){o=false;return 0});var p=function(g,h,k,m){k=k||[];var r=h=h||s;if(h.nodeType!==1&&h.nodeType!==9)return[];if(!g||typeof g!=="string")return k;for(var q=[],v,u,y,S,I=true,N=x(h),J=g;(f.exec(""),v=f.exec(J))!==null;){J=v[3];q.push(v[1]);if(v[2]){S=v[3];break}}if(q.length>1&&t.exec(g))if(q.length===2&&n.relative[q[0]])u=ia(q[0]+q[1],h);else for(u=n.relative[q[0]]?[h]:p(q.shift(),h);q.length;){g=q.shift();if(n.relative[g])g+=q.shift();
|
|
||||||
u=ia(g,u)}else{if(!m&&q.length>1&&h.nodeType===9&&!N&&n.match.ID.test(q[0])&&!n.match.ID.test(q[q.length-1])){v=p.find(q.shift(),h,N);h=v.expr?p.filter(v.expr,v.set)[0]:v.set[0]}if(h){v=m?{expr:q.pop(),set:B(m)}:p.find(q.pop(),q.length===1&&(q[0]==="~"||q[0]==="+")&&h.parentNode?h.parentNode:h,N);u=v.expr?p.filter(v.expr,v.set):v.set;if(q.length>0)y=B(u);else I=false;for(;q.length;){var E=q.pop();v=E;if(n.relative[E])v=q.pop();else E="";if(v==null)v=h;n.relative[E](y,v,N)}}else y=[]}y||(y=u);if(!y)throw"Syntax error, unrecognized expression: "+
|
|
||||||
(E||g);if(i.call(y)==="[object Array]")if(I)if(h&&h.nodeType===1)for(g=0;y[g]!=null;g++){if(y[g]&&(y[g]===true||y[g].nodeType===1&&F(h,y[g])))k.push(u[g])}else for(g=0;y[g]!=null;g++)y[g]&&y[g].nodeType===1&&k.push(u[g]);else k.push.apply(k,y);else B(y,k);if(S){p(S,r,k,m);p.uniqueSort(k)}return k};p.uniqueSort=function(g){if(D){j=o;g.sort(D);if(j)for(var h=1;h<g.length;h++)g[h]===g[h-1]&&g.splice(h--,1)}return g};p.matches=function(g,h){return p(g,null,null,h)};p.find=function(g,h,k){var m,r;if(!g)return[];
|
|
||||||
for(var q=0,v=n.order.length;q<v;q++){var u=n.order[q];if(r=n.leftMatch[u].exec(g)){var y=r[1];r.splice(1,1);if(y.substr(y.length-1)!=="\\"){r[1]=(r[1]||"").replace(/\\/g,"");m=n.find[u](r,h,k);if(m!=null){g=g.replace(n.match[u],"");break}}}}m||(m=h.getElementsByTagName("*"));return{set:m,expr:g}};p.filter=function(g,h,k,m){for(var r=g,q=[],v=h,u,y,S=h&&h[0]&&x(h[0]);g&&h.length;){for(var I in n.filter)if((u=n.leftMatch[I].exec(g))!=null&&u[2]){var N=n.filter[I],J,E;E=u[1];y=false;u.splice(1,1);if(E.substr(E.length-
|
|
||||||
1)!=="\\"){if(v===q)q=[];if(n.preFilter[I])if(u=n.preFilter[I](u,v,k,q,m,S)){if(u===true)continue}else y=J=true;if(u)for(var X=0;(E=v[X])!=null;X++)if(E){J=N(E,u,X,v);var Ea=m^!!J;if(k&&J!=null)if(Ea)y=true;else v[X]=false;else if(Ea){q.push(E);y=true}}if(J!==w){k||(v=q);g=g.replace(n.match[I],"");if(!y)return[];break}}}if(g===r)if(y==null)throw"Syntax error, unrecognized expression: "+g;else break;r=g}return v};var n=p.selectors={order:["ID","NAME","TAG"],match:{ID:/#((?:[\w\u00c0-\uFFFF-]|\\.)+)/,
|
|
||||||
CLASS:/\.((?:[\w\u00c0-\uFFFF-]|\\.)+)/,NAME:/\[name=['"]*((?:[\w\u00c0-\uFFFF-]|\\.)+)['"]*\]/,ATTR:/\[\s*((?:[\w\u00c0-\uFFFF-]|\\.)+)\s*(?:(\S?=)\s*(['"]*)(.*?)\3|)\s*\]/,TAG:/^((?:[\w\u00c0-\uFFFF\*-]|\\.)+)/,CHILD:/:(only|nth|last|first)-child(?:\((even|odd|[\dn+-]*)\))?/,POS:/:(nth|eq|gt|lt|first|last|even|odd)(?:\((\d*)\))?(?=[^-]|$)/,PSEUDO:/:((?:[\w\u00c0-\uFFFF-]|\\.)+)(?:\((['"]?)((?:\([^\)]+\)|[^\(\)]*)+)\2\))?/},leftMatch:{},attrMap:{"class":"className","for":"htmlFor"},attrHandle:{href:function(g){return g.getAttribute("href")}},
|
|
||||||
relative:{"+":function(g,h){var k=typeof h==="string",m=k&&!/\W/.test(h);k=k&&!m;if(m)h=h.toLowerCase();m=0;for(var r=g.length,q;m<r;m++)if(q=g[m]){for(;(q=q.previousSibling)&&q.nodeType!==1;);g[m]=k||q&&q.nodeName.toLowerCase()===h?q||false:q===h}k&&p.filter(h,g,true)},">":function(g,h){var k=typeof h==="string";if(k&&!/\W/.test(h)){h=h.toLowerCase();for(var m=0,r=g.length;m<r;m++){var q=g[m];if(q){k=q.parentNode;g[m]=k.nodeName.toLowerCase()===h?k:false}}}else{m=0;for(r=g.length;m<r;m++)if(q=g[m])g[m]=
|
|
||||||
k?q.parentNode:q.parentNode===h;k&&p.filter(h,g,true)}},"":function(g,h,k){var m=e++,r=d;if(typeof h==="string"&&!/\W/.test(h)){var q=h=h.toLowerCase();r=b}r("parentNode",h,m,g,q,k)},"~":function(g,h,k){var m=e++,r=d;if(typeof h==="string"&&!/\W/.test(h)){var q=h=h.toLowerCase();r=b}r("previousSibling",h,m,g,q,k)}},find:{ID:function(g,h,k){if(typeof h.getElementById!=="undefined"&&!k)return(g=h.getElementById(g[1]))?[g]:[]},NAME:function(g,h){if(typeof h.getElementsByName!=="undefined"){var k=[];
|
|
||||||
h=h.getElementsByName(g[1]);for(var m=0,r=h.length;m<r;m++)h[m].getAttribute("name")===g[1]&&k.push(h[m]);return k.length===0?null:k}},TAG:function(g,h){return h.getElementsByTagName(g[1])}},preFilter:{CLASS:function(g,h,k,m,r,q){g=" "+g[1].replace(/\\/g,"")+" ";if(q)return g;q=0;for(var v;(v=h[q])!=null;q++)if(v)if(r^(v.className&&(" "+v.className+" ").replace(/[\t\n]/g," ").indexOf(g)>=0))k||m.push(v);else if(k)h[q]=false;return false},ID:function(g){return g[1].replace(/\\/g,"")},TAG:function(g){return g[1].toLowerCase()},
|
|
||||||
CHILD:function(g){if(g[1]==="nth"){var h=/(-?)(\d*)n((?:\+|-)?\d*)/.exec(g[2]==="even"&&"2n"||g[2]==="odd"&&"2n+1"||!/\D/.test(g[2])&&"0n+"+g[2]||g[2]);g[2]=h[1]+(h[2]||1)-0;g[3]=h[3]-0}g[0]=e++;return g},ATTR:function(g,h,k,m,r,q){h=g[1].replace(/\\/g,"");if(!q&&n.attrMap[h])g[1]=n.attrMap[h];if(g[2]==="~=")g[4]=" "+g[4]+" ";return g},PSEUDO:function(g,h,k,m,r){if(g[1]==="not")if((f.exec(g[3])||"").length>1||/^\w/.test(g[3]))g[3]=p(g[3],null,null,h);else{g=p.filter(g[3],h,k,true^r);k||m.push.apply(m,
|
|
||||||
g);return false}else if(n.match.POS.test(g[0])||n.match.CHILD.test(g[0]))return true;return g},POS:function(g){g.unshift(true);return g}},filters:{enabled:function(g){return g.disabled===false&&g.type!=="hidden"},disabled:function(g){return g.disabled===true},checked:function(g){return g.checked===true},selected:function(g){return g.selected===true},parent:function(g){return!!g.firstChild},empty:function(g){return!g.firstChild},has:function(g,h,k){return!!p(k[3],g).length},header:function(g){return/h\d/i.test(g.nodeName)},
|
|
||||||
text:function(g){return"text"===g.type},radio:function(g){return"radio"===g.type},checkbox:function(g){return"checkbox"===g.type},file:function(g){return"file"===g.type},password:function(g){return"password"===g.type},submit:function(g){return"submit"===g.type},image:function(g){return"image"===g.type},reset:function(g){return"reset"===g.type},button:function(g){return"button"===g.type||g.nodeName.toLowerCase()==="button"},input:function(g){return/input|select|textarea|button/i.test(g.nodeName)}},
|
|
||||||
setFilters:{first:function(g,h){return h===0},last:function(g,h,k,m){return h===m.length-1},even:function(g,h){return h%2===0},odd:function(g,h){return h%2===1},lt:function(g,h,k){return h<k[3]-0},gt:function(g,h,k){return h>k[3]-0},nth:function(g,h,k){return k[3]-0===h},eq:function(g,h,k){return k[3]-0===h}},filter:{PSEUDO:function(g,h,k,m){var r=h[1],q=n.filters[r];if(q)return q(g,k,h,m);else if(r==="contains")return(g.textContent||g.innerText||a([g])||"").indexOf(h[3])>=0;else if(r==="not"){h=
|
|
||||||
h[3];k=0;for(m=h.length;k<m;k++)if(h[k]===g)return false;return true}else throw"Syntax error, unrecognized expression: "+r;},CHILD:function(g,h){var k=h[1],m=g;switch(k){case "only":case "first":for(;m=m.previousSibling;)if(m.nodeType===1)return false;if(k==="first")return true;m=g;case "last":for(;m=m.nextSibling;)if(m.nodeType===1)return false;return true;case "nth":k=h[2];var r=h[3];if(k===1&&r===0)return true;h=h[0];var q=g.parentNode;if(q&&(q.sizcache!==h||!g.nodeIndex)){var v=0;for(m=q.firstChild;m;m=
|
|
||||||
m.nextSibling)if(m.nodeType===1)m.nodeIndex=++v;q.sizcache=h}g=g.nodeIndex-r;return k===0?g===0:g%k===0&&g/k>=0}},ID:function(g,h){return g.nodeType===1&&g.getAttribute("id")===h},TAG:function(g,h){return h==="*"&&g.nodeType===1||g.nodeName.toLowerCase()===h},CLASS:function(g,h){return(" "+(g.className||g.getAttribute("class"))+" ").indexOf(h)>-1},ATTR:function(g,h){var k=h[1];g=n.attrHandle[k]?n.attrHandle[k](g):g[k]!=null?g[k]:g.getAttribute(k);k=g+"";var m=h[2];h=h[4];return g==null?m==="!=":m===
|
|
||||||
"="?k===h:m==="*="?k.indexOf(h)>=0:m==="~="?(" "+k+" ").indexOf(h)>=0:!h?k&&g!==false:m==="!="?k!==h:m==="^="?k.indexOf(h)===0:m==="$="?k.substr(k.length-h.length)===h:m==="|="?k===h||k.substr(0,h.length+1)===h+"-":false},POS:function(g,h,k,m){var r=n.setFilters[h[2]];if(r)return r(g,k,h,m)}}},t=n.match.POS;for(var z in n.match){n.match[z]=new RegExp(n.match[z].source+/(?![^\[]*\])(?![^\(]*\))/.source);n.leftMatch[z]=new RegExp(/(^(?:.|\r|\n)*?)/.source+n.match[z].source.replace(/\\(\d+)/g,function(g,
|
|
||||||
h){return"\\"+(h-0+1)}))}var B=function(g,h){g=Array.prototype.slice.call(g,0);if(h){h.push.apply(h,g);return h}return g};try{Array.prototype.slice.call(s.documentElement.childNodes,0)}catch(C){B=function(g,h){h=h||[];if(i.call(g)==="[object Array]")Array.prototype.push.apply(h,g);else if(typeof g.length==="number")for(var k=0,m=g.length;k<m;k++)h.push(g[k]);else for(k=0;g[k];k++)h.push(g[k]);return h}}var D;if(s.documentElement.compareDocumentPosition)D=function(g,h){if(!g.compareDocumentPosition||
|
|
||||||
!h.compareDocumentPosition){if(g==h)j=true;return g.compareDocumentPosition?-1:1}g=g.compareDocumentPosition(h)&4?-1:g===h?0:1;if(g===0)j=true;return g};else if("sourceIndex"in s.documentElement)D=function(g,h){if(!g.sourceIndex||!h.sourceIndex){if(g==h)j=true;return g.sourceIndex?-1:1}g=g.sourceIndex-h.sourceIndex;if(g===0)j=true;return g};else if(s.createRange)D=function(g,h){if(!g.ownerDocument||!h.ownerDocument){if(g==h)j=true;return g.ownerDocument?-1:1}var k=g.ownerDocument.createRange(),m=
|
|
||||||
h.ownerDocument.createRange();k.setStart(g,0);k.setEnd(g,0);m.setStart(h,0);m.setEnd(h,0);g=k.compareBoundaryPoints(Range.START_TO_END,m);if(g===0)j=true;return g};(function(){var g=s.createElement("div"),h="script"+(new Date).getTime();g.innerHTML="<a name='"+h+"'/>";var k=s.documentElement;k.insertBefore(g,k.firstChild);if(s.getElementById(h)){n.find.ID=function(m,r,q){if(typeof r.getElementById!=="undefined"&&!q)return(r=r.getElementById(m[1]))?r.id===m[1]||typeof r.getAttributeNode!=="undefined"&&
|
|
||||||
r.getAttributeNode("id").nodeValue===m[1]?[r]:w:[]};n.filter.ID=function(m,r){var q=typeof m.getAttributeNode!=="undefined"&&m.getAttributeNode("id");return m.nodeType===1&&q&&q.nodeValue===r}}k.removeChild(g);k=g=null})();(function(){var g=s.createElement("div");g.appendChild(s.createComment(""));if(g.getElementsByTagName("*").length>0)n.find.TAG=function(h,k){k=k.getElementsByTagName(h[1]);if(h[1]==="*"){h=[];for(var m=0;k[m];m++)k[m].nodeType===1&&h.push(k[m]);k=h}return k};g.innerHTML="<a href='#'></a>";
|
|
||||||
if(g.firstChild&&typeof g.firstChild.getAttribute!=="undefined"&&g.firstChild.getAttribute("href")!=="#")n.attrHandle.href=function(h){return h.getAttribute("href",2)};g=null})();s.querySelectorAll&&function(){var g=p,h=s.createElement("div");h.innerHTML="<p class='TEST'></p>";if(!(h.querySelectorAll&&h.querySelectorAll(".TEST").length===0)){p=function(m,r,q,v){r=r||s;if(!v&&r.nodeType===9&&!x(r))try{return B(r.querySelectorAll(m),q)}catch(u){}return g(m,r,q,v)};for(var k in g)p[k]=g[k];h=null}}();
|
|
||||||
(function(){var g=s.createElement("div");g.innerHTML="<div class='test e'></div><div class='test'></div>";if(!(!g.getElementsByClassName||g.getElementsByClassName("e").length===0)){g.lastChild.className="e";if(g.getElementsByClassName("e").length!==1){n.order.splice(1,0,"CLASS");n.find.CLASS=function(h,k,m){if(typeof k.getElementsByClassName!=="undefined"&&!m)return k.getElementsByClassName(h[1])};g=null}}})();var F=s.compareDocumentPosition?function(g,h){return g.compareDocumentPosition(h)&16}:function(g,
|
|
||||||
h){return g!==h&&(g.contains?g.contains(h):true)},x=function(g){return(g=(g?g.ownerDocument||g:0).documentElement)?g.nodeName!=="HTML":false},ia=function(g,h){var k=[],m="",r;for(h=h.nodeType?[h]:h;r=n.match.PSEUDO.exec(g);){m+=r[0];g=g.replace(n.match.PSEUDO,"")}g=n.relative[g]?g+"*":g;r=0;for(var q=h.length;r<q;r++)p(g,h[r],k);return p.filter(m,k)};c.find=p;c.expr=p.selectors;c.expr[":"]=c.expr.filters;c.unique=p.uniqueSort;c.getText=a;c.isXMLDoc=x;c.contains=F})();var ab=/Until$/,bb=/^(?:parents|prevUntil|prevAll)/,
|
|
||||||
cb=/,/;R=Array.prototype.slice;var Fa=function(a,b,d){if(c.isFunction(b))return c.grep(a,function(e,i){return!!b.call(e,i,e)===d});else if(b.nodeType)return c.grep(a,function(e){return e===b===d});else if(typeof b==="string"){var f=c.grep(a,function(e){return e.nodeType===1});if(Pa.test(b))return c.filter(b,f,!d);else b=c.filter(b,a)}return c.grep(a,function(e){return c.inArray(e,b)>=0===d})};c.fn.extend({find:function(a){for(var b=this.pushStack("","find",a),d=0,f=0,e=this.length;f<e;f++){d=b.length;
|
|
||||||
c.find(a,this[f],b);if(f>0)for(var i=d;i<b.length;i++)for(var j=0;j<d;j++)if(b[j]===b[i]){b.splice(i--,1);break}}return b},has:function(a){var b=c(a);return this.filter(function(){for(var d=0,f=b.length;d<f;d++)if(c.contains(this,b[d]))return true})},not:function(a){return this.pushStack(Fa(this,a,false),"not",a)},filter:function(a){return this.pushStack(Fa(this,a,true),"filter",a)},is:function(a){return!!a&&c.filter(a,this).length>0},closest:function(a,b){if(c.isArray(a)){var d=[],f=this[0],e,i=
|
|
||||||
{},j;if(f&&a.length){e=0;for(var o=a.length;e<o;e++){j=a[e];i[j]||(i[j]=c.expr.match.POS.test(j)?c(j,b||this.context):j)}for(;f&&f.ownerDocument&&f!==b;){for(j in i){e=i[j];if(e.jquery?e.index(f)>-1:c(f).is(e)){d.push({selector:j,elem:f});delete i[j]}}f=f.parentNode}}return d}var p=c.expr.match.POS.test(a)?c(a,b||this.context):null;return this.map(function(n,t){for(;t&&t.ownerDocument&&t!==b;){if(p?p.index(t)>-1:c(t).is(a))return t;t=t.parentNode}return null})},index:function(a){if(!a||typeof a===
|
|
||||||
"string")return c.inArray(this[0],a?c(a):this.parent().children());return c.inArray(a.jquery?a[0]:a,this)},add:function(a,b){a=typeof a==="string"?c(a,b||this.context):c.makeArray(a);b=c.merge(this.get(),a);return this.pushStack(sa(a[0])||sa(b[0])?b:c.unique(b))},andSelf:function(){return this.add(this.prevObject)}});c.each({parent:function(a){return(a=a.parentNode)&&a.nodeType!==11?a:null},parents:function(a){return c.dir(a,"parentNode")},parentsUntil:function(a,b,d){return c.dir(a,"parentNode",
|
|
||||||
d)},next:function(a){return c.nth(a,2,"nextSibling")},prev:function(a){return c.nth(a,2,"previousSibling")},nextAll:function(a){return c.dir(a,"nextSibling")},prevAll:function(a){return c.dir(a,"previousSibling")},nextUntil:function(a,b,d){return c.dir(a,"nextSibling",d)},prevUntil:function(a,b,d){return c.dir(a,"previousSibling",d)},siblings:function(a){return c.sibling(a.parentNode.firstChild,a)},children:function(a){return c.sibling(a.firstChild)},contents:function(a){return c.nodeName(a,"iframe")?
|
|
||||||
a.contentDocument||a.contentWindow.document:c.makeArray(a.childNodes)}},function(a,b){c.fn[a]=function(d,f){var e=c.map(this,b,d);ab.test(a)||(f=d);if(f&&typeof f==="string")e=c.filter(f,e);e=this.length>1?c.unique(e):e;if((this.length>1||cb.test(f))&&bb.test(a))e=e.reverse();return this.pushStack(e,a,R.call(arguments).join(","))}});c.extend({filter:function(a,b,d){if(d)a=":not("+a+")";return c.find.matches(a,b)},dir:function(a,b,d){var f=[];for(a=a[b];a&&a.nodeType!==9&&(d===w||!c(a).is(d));){a.nodeType===
|
|
||||||
1&&f.push(a);a=a[b]}return f},nth:function(a,b,d){b=b||1;for(var f=0;a;a=a[d])if(a.nodeType===1&&++f===b)break;return a},sibling:function(a,b){for(var d=[];a;a=a.nextSibling)a.nodeType===1&&a!==b&&d.push(a);return d}});var Ga=/ jQuery\d+="(?:\d+|null)"/g,Y=/^\s+/,db=/(<([\w:]+)[^>]*?)\/>/g,eb=/^(?:area|br|col|embed|hr|img|input|link|meta|param)$/i,Ha=/<([\w:]+)/,fb=/<tbody/i,gb=/<|&\w+;/,hb=function(a,b,d){return eb.test(d)?a:b+"></"+d+">"},G={option:[1,"<select multiple='multiple'>","</select>"],
|
|
||||||
legend:[1,"<fieldset>","</fieldset>"],thead:[1,"<table>","</table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],col:[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"],area:[1,"<map>","</map>"],_default:[0,"",""]};G.optgroup=G.option;G.tbody=G.tfoot=G.colgroup=G.caption=G.thead;G.th=G.td;if(!c.support.htmlSerialize)G._default=[1,"div<div>","</div>"];c.fn.extend({text:function(a){if(c.isFunction(a))return this.each(function(b){var d=c(this);
|
|
||||||
return d.text(a.call(this,b,d.text()))});if(typeof a!=="object"&&a!==w)return this.empty().append((this[0]&&this[0].ownerDocument||s).createTextNode(a));return c.getText(this)},wrapAll:function(a){if(c.isFunction(a))return this.each(function(d){c(this).wrapAll(a.call(this,d))});if(this[0]){var b=c(a,this[0].ownerDocument).eq(0).clone(true);this[0].parentNode&&b.insertBefore(this[0]);b.map(function(){for(var d=this;d.firstChild&&d.firstChild.nodeType===1;)d=d.firstChild;return d}).append(this)}return this},
|
|
||||||
wrapInner:function(a){return this.each(function(){var b=c(this),d=b.contents();d.length?d.wrapAll(a):b.append(a)})},wrap:function(a){return this.each(function(){c(this).wrapAll(a)})},unwrap:function(){return this.parent().each(function(){c.nodeName(this,"body")||c(this).replaceWith(this.childNodes)}).end()},append:function(){return this.domManip(arguments,true,function(a){this.nodeType===1&&this.appendChild(a)})},prepend:function(){return this.domManip(arguments,true,function(a){this.nodeType===1&&
|
|
||||||
this.insertBefore(a,this.firstChild)})},before:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,false,function(b){this.parentNode.insertBefore(b,this)});else if(arguments.length){var a=c(arguments[0]);a.push.apply(a,this.toArray());return this.pushStack(a,"before",arguments)}},after:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,false,function(b){this.parentNode.insertBefore(b,this.nextSibling)});else if(arguments.length){var a=this.pushStack(this,
|
|
||||||
"after",arguments);a.push.apply(a,c(arguments[0]).toArray());return a}},clone:function(a){var b=this.map(function(){if(!c.support.noCloneEvent&&!c.isXMLDoc(this)){var d=this.outerHTML,f=this.ownerDocument;if(!d){d=f.createElement("div");d.appendChild(this.cloneNode(true));d=d.innerHTML}return c.clean([d.replace(Ga,"").replace(Y,"")],f)[0]}else return this.cloneNode(true)});if(a===true){ta(this,b);ta(this.find("*"),b.find("*"))}return b},html:function(a){if(a===w)return this[0]&&this[0].nodeType===
|
|
||||||
1?this[0].innerHTML.replace(Ga,""):null;else if(typeof a==="string"&&!/<script/i.test(a)&&(c.support.leadingWhitespace||!Y.test(a))&&!G[(Ha.exec(a)||["",""])[1].toLowerCase()])try{for(var b=0,d=this.length;b<d;b++)if(this[b].nodeType===1){T(this[b].getElementsByTagName("*"));this[b].innerHTML=a}}catch(f){this.empty().append(a)}else c.isFunction(a)?this.each(function(e){var i=c(this),j=i.html();i.empty().append(function(){return a.call(this,e,j)})}):this.empty().append(a);return this},replaceWith:function(a){if(this[0]&&
|
|
||||||
this[0].parentNode){c.isFunction(a)||(a=c(a).detach());return this.each(function(){var b=this.nextSibling,d=this.parentNode;c(this).remove();b?c(b).before(a):c(d).append(a)})}else return this.pushStack(c(c.isFunction(a)?a():a),"replaceWith",a)},detach:function(a){return this.remove(a,true)},domManip:function(a,b,d){function f(t){return c.nodeName(t,"table")?t.getElementsByTagName("tbody")[0]||t.appendChild(t.ownerDocument.createElement("tbody")):t}var e,i,j=a[0],o=[];if(c.isFunction(j))return this.each(function(t){var z=
|
|
||||||
c(this);a[0]=j.call(this,t,b?z.html():w);return z.domManip(a,b,d)});if(this[0]){e=a[0]&&a[0].parentNode&&a[0].parentNode.nodeType===11?{fragment:a[0].parentNode}:ua(a,this,o);if(i=e.fragment.firstChild){b=b&&c.nodeName(i,"tr");for(var p=0,n=this.length;p<n;p++)d.call(b?f(this[p],i):this[p],e.cacheable||this.length>1||p>0?e.fragment.cloneNode(true):e.fragment)}o&&c.each(o,La)}return this}});c.fragments={};c.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},
|
|
||||||
function(a,b){c.fn[a]=function(d){var f=[];d=c(d);for(var e=0,i=d.length;e<i;e++){var j=(e>0?this.clone(true):this).get();c.fn[b].apply(c(d[e]),j);f=f.concat(j)}return this.pushStack(f,a,d.selector)}});c.each({remove:function(a,b){if(!a||c.filter(a,[this]).length){if(!b&&this.nodeType===1){T(this.getElementsByTagName("*"));T([this])}this.parentNode&&this.parentNode.removeChild(this)}},empty:function(){for(this.nodeType===1&&T(this.getElementsByTagName("*"));this.firstChild;)this.removeChild(this.firstChild)}},
|
|
||||||
function(a,b){c.fn[a]=function(){return this.each(b,arguments)}});c.extend({clean:function(a,b,d,f){b=b||s;if(typeof b.createElement==="undefined")b=b.ownerDocument||b[0]&&b[0].ownerDocument||s;var e=[];c.each(a,function(i,j){if(typeof j==="number")j+="";if(j){if(typeof j==="string"&&!gb.test(j))j=b.createTextNode(j);else if(typeof j==="string"){j=j.replace(db,hb);var o=(Ha.exec(j)||["",""])[1].toLowerCase(),p=G[o]||G._default,n=p[0];i=b.createElement("div");for(i.innerHTML=p[1]+j+p[2];n--;)i=i.lastChild;
|
|
||||||
if(!c.support.tbody){n=fb.test(j);o=o==="table"&&!n?i.firstChild&&i.firstChild.childNodes:p[1]==="<table>"&&!n?i.childNodes:[];for(p=o.length-1;p>=0;--p)c.nodeName(o[p],"tbody")&&!o[p].childNodes.length&&o[p].parentNode.removeChild(o[p])}!c.support.leadingWhitespace&&Y.test(j)&&i.insertBefore(b.createTextNode(Y.exec(j)[0]),i.firstChild);j=c.makeArray(i.childNodes)}if(j.nodeType)e.push(j);else e=c.merge(e,j)}});if(d)for(a=0;e[a];a++)if(f&&c.nodeName(e[a],"script")&&(!e[a].type||e[a].type.toLowerCase()===
|
|
||||||
"text/javascript"))f.push(e[a].parentNode?e[a].parentNode.removeChild(e[a]):e[a]);else{e[a].nodeType===1&&e.splice.apply(e,[a+1,0].concat(c.makeArray(e[a].getElementsByTagName("script"))));d.appendChild(e[a])}return e}});var ib=/z-?index|font-?weight|opacity|zoom|line-?height/i,Ia=/alpha\([^)]*\)/,Ja=/opacity=([^)]*)/,ja=/float/i,ka=/-([a-z])/ig,jb=/([A-Z])/g,kb=/^-?\d+(?:px)?$/i,lb=/^-?\d/,mb={position:"absolute",visibility:"hidden",display:"block"},nb=["Left","Right"],ob=["Top","Bottom"],pb=s.defaultView&&
|
|
||||||
s.defaultView.getComputedStyle,Ka=c.support.cssFloat?"cssFloat":"styleFloat",la=function(a,b){return b.toUpperCase()};c.fn.css=function(a,b){return $(this,a,b,true,function(d,f,e){if(e===w)return c.curCSS(d,f);if(typeof e==="number"&&!ib.test(f))e+="px";c.style(d,f,e)})};c.extend({style:function(a,b,d){if(!a||a.nodeType===3||a.nodeType===8)return w;if((b==="width"||b==="height")&&parseFloat(d)<0)d=w;var f=a.style||a,e=d!==w;if(!c.support.opacity&&b==="opacity"){if(e){f.zoom=1;b=parseInt(d,10)+""===
|
|
||||||
"NaN"?"":"alpha(opacity="+d*100+")";a=f.filter||c.curCSS(a,"filter")||"";f.filter=Ia.test(a)?a.replace(Ia,b):b}return f.filter&&f.filter.indexOf("opacity=")>=0?parseFloat(Ja.exec(f.filter)[1])/100+"":""}if(ja.test(b))b=Ka;b=b.replace(ka,la);if(e)f[b]=d;return f[b]},css:function(a,b,d,f){if(b==="width"||b==="height"){var e,i=b==="width"?nb:ob;function j(){e=b==="width"?a.offsetWidth:a.offsetHeight;f!=="border"&&c.each(i,function(){f||(e-=parseFloat(c.curCSS(a,"padding"+this,true))||0);if(f==="margin")e+=
|
|
||||||
parseFloat(c.curCSS(a,"margin"+this,true))||0;else e-=parseFloat(c.curCSS(a,"border"+this+"Width",true))||0})}a.offsetWidth!==0?j():c.swap(a,mb,j);return Math.max(0,Math.round(e))}return c.curCSS(a,b,d)},curCSS:function(a,b,d){var f,e=a.style;if(!c.support.opacity&&b==="opacity"&&a.currentStyle){f=Ja.test(a.currentStyle.filter||"")?parseFloat(RegExp.$1)/100+"":"";return f===""?"1":f}if(ja.test(b))b=Ka;if(!d&&e&&e[b])f=e[b];else if(pb){if(ja.test(b))b="float";b=b.replace(jb,"-$1").toLowerCase();e=
|
|
||||||
a.ownerDocument.defaultView;if(!e)return null;if(a=e.getComputedStyle(a,null))f=a.getPropertyValue(b);if(b==="opacity"&&f==="")f="1"}else if(a.currentStyle){d=b.replace(ka,la);f=a.currentStyle[b]||a.currentStyle[d];if(!kb.test(f)&&lb.test(f)){b=e.left;var i=a.runtimeStyle.left;a.runtimeStyle.left=a.currentStyle.left;e.left=d==="fontSize"?"1em":f||0;f=e.pixelLeft+"px";e.left=b;a.runtimeStyle.left=i}}return f},swap:function(a,b,d){var f={};for(var e in b){f[e]=a.style[e];a.style[e]=b[e]}d.call(a);for(e in b)a.style[e]=
|
|
||||||
f[e]}});if(c.expr&&c.expr.filters){c.expr.filters.hidden=function(a){var b=a.offsetWidth,d=a.offsetHeight,f=a.nodeName.toLowerCase()==="tr";return b===0&&d===0&&!f?true:b>0&&d>0&&!f?false:c.curCSS(a,"display")==="none"};c.expr.filters.visible=function(a){return!c.expr.filters.hidden(a)}}var qb=K(),rb=/<script(.|\s)*?\/script>/gi,sb=/select|textarea/i,tb=/color|date|datetime|email|hidden|month|number|password|range|search|tel|text|time|url|week/i,O=/=\?(&|$)/,ma=/\?/,ub=/(\?|&)_=.*?(&|$)/,vb=/^(\w+:)?\/\/([^\/?#]+)/,
|
|
||||||
wb=/%20/g;c.fn.extend({_load:c.fn.load,load:function(a,b,d){if(typeof a!=="string")return this._load(a);else if(!this.length)return this;var f=a.indexOf(" ");if(f>=0){var e=a.slice(f,a.length);a=a.slice(0,f)}f="GET";if(b)if(c.isFunction(b)){d=b;b=null}else if(typeof b==="object"){b=c.param(b,c.ajaxSettings.traditional);f="POST"}c.ajax({url:a,type:f,dataType:"html",data:b,context:this,complete:function(i,j){if(j==="success"||j==="notmodified")this.html(e?c("<div />").append(i.responseText.replace(rb,
|
|
||||||
"")).find(e):i.responseText);d&&this.each(d,[i.responseText,j,i])}});return this},serialize:function(){return c.param(this.serializeArray())},serializeArray:function(){return this.map(function(){return this.elements?c.makeArray(this.elements):this}).filter(function(){return this.name&&!this.disabled&&(this.checked||sb.test(this.nodeName)||tb.test(this.type))}).map(function(a,b){a=c(this).val();return a==null?null:c.isArray(a)?c.map(a,function(d){return{name:b.name,value:d}}):{name:b.name,value:a}}).get()}});
|
|
||||||
c.each("ajaxStart ajaxStop ajaxComplete ajaxError ajaxSuccess ajaxSend".split(" "),function(a,b){c.fn[b]=function(d){return this.bind(b,d)}});c.extend({get:function(a,b,d,f){if(c.isFunction(b)){f=f||d;d=b;b=null}return c.ajax({type:"GET",url:a,data:b,success:d,dataType:f})},getScript:function(a,b){return c.get(a,null,b,"script")},getJSON:function(a,b,d){return c.get(a,b,d,"json")},post:function(a,b,d,f){if(c.isFunction(b)){f=f||d;d=b;b={}}return c.ajax({type:"POST",url:a,data:b,success:d,dataType:f})},
|
|
||||||
ajaxSetup:function(a){c.extend(c.ajaxSettings,a)},ajaxSettings:{url:location.href,global:true,type:"GET",contentType:"application/x-www-form-urlencoded",processData:true,async:true,xhr:A.XMLHttpRequest&&(A.location.protocol!=="file:"||!A.ActiveXObject)?function(){return new A.XMLHttpRequest}:function(){try{return new A.ActiveXObject("Microsoft.XMLHTTP")}catch(a){}},accepts:{xml:"application/xml, text/xml",html:"text/html",script:"text/javascript, application/javascript",json:"application/json, text/javascript",
|
|
||||||
text:"text/plain",_default:"*/*"}},lastModified:{},etag:{},ajax:function(a){function b(){e.success&&e.success.call(p,o,j,x);e.global&&f("ajaxSuccess",[x,e])}function d(){e.complete&&e.complete.call(p,x,j);e.global&&f("ajaxComplete",[x,e]);e.global&&!--c.active&&c.event.trigger("ajaxStop")}function f(r,q){(e.context?c(e.context):c.event).trigger(r,q)}var e=c.extend(true,{},c.ajaxSettings,a),i,j,o,p=e.context||e,n=e.type.toUpperCase();if(e.data&&e.processData&&typeof e.data!=="string")e.data=c.param(e.data,
|
|
||||||
e.traditional);if(e.dataType==="jsonp"){if(n==="GET")O.test(e.url)||(e.url+=(ma.test(e.url)?"&":"?")+(e.jsonp||"callback")+"=?");else if(!e.data||!O.test(e.data))e.data=(e.data?e.data+"&":"")+(e.jsonp||"callback")+"=?";e.dataType="json"}if(e.dataType==="json"&&(e.data&&O.test(e.data)||O.test(e.url))){i=e.jsonpCallback||"jsonp"+qb++;if(e.data)e.data=(e.data+"").replace(O,"="+i+"$1");e.url=e.url.replace(O,"="+i+"$1");e.dataType="script";A[i]=A[i]||function(r){o=r;b();d();A[i]=w;try{delete A[i]}catch(q){}B&&
|
|
||||||
B.removeChild(C)}}if(e.dataType==="script"&&e.cache===null)e.cache=false;if(e.cache===false&&n==="GET"){var t=K(),z=e.url.replace(ub,"$1_="+t+"$2");e.url=z+(z===e.url?(ma.test(e.url)?"&":"?")+"_="+t:"")}if(e.data&&n==="GET")e.url+=(ma.test(e.url)?"&":"?")+e.data;e.global&&!c.active++&&c.event.trigger("ajaxStart");t=(t=vb.exec(e.url))&&(t[1]&&t[1]!==location.protocol||t[2]!==location.host);if(e.dataType==="script"&&n==="GET"&&t){var B=s.getElementsByTagName("head")[0]||s.documentElement,C=s.createElement("script");
|
|
||||||
C.src=e.url;if(e.scriptCharset)C.charset=e.scriptCharset;if(!i){var D=false;C.onload=C.onreadystatechange=function(){if(!D&&(!this.readyState||this.readyState==="loaded"||this.readyState==="complete")){D=true;b();d();C.onload=C.onreadystatechange=null;B&&C.parentNode&&B.removeChild(C)}}}B.insertBefore(C,B.firstChild);return w}var F=false,x=e.xhr();if(x){e.username?x.open(n,e.url,e.async,e.username,e.password):x.open(n,e.url,e.async);try{if(e.data||a&&a.contentType)x.setRequestHeader("Content-Type",
|
|
||||||
e.contentType);if(e.ifModified){c.lastModified[e.url]&&x.setRequestHeader("If-Modified-Since",c.lastModified[e.url]);c.etag[e.url]&&x.setRequestHeader("If-None-Match",c.etag[e.url])}t||x.setRequestHeader("X-Requested-With","XMLHttpRequest");x.setRequestHeader("Accept",e.dataType&&e.accepts[e.dataType]?e.accepts[e.dataType]+", */*":e.accepts._default)}catch(ia){}if(e.beforeSend&&e.beforeSend.call(p,x,e)===false){e.global&&!--c.active&&c.event.trigger("ajaxStop");x.abort();return false}e.global&&f("ajaxSend",
|
|
||||||
[x,e]);var g=x.onreadystatechange=function(r){if(!x||x.readyState===0){F||d();F=true;if(x)x.onreadystatechange=c.noop}else if(!F&&x&&(x.readyState===4||r==="timeout")){F=true;x.onreadystatechange=c.noop;j=r==="timeout"?"timeout":!c.httpSuccess(x)?"error":e.ifModified&&c.httpNotModified(x,e.url)?"notmodified":"success";if(j==="success")try{o=c.httpData(x,e.dataType,e)}catch(q){j="parsererror"}if(j==="success"||j==="notmodified")i||b();else c.handleError(e,x,j);d();r==="timeout"&&x.abort();if(e.async)x=
|
|
||||||
null}};try{var h=x.abort;x.abort=function(){if(x){h.call(x);if(x)x.readyState=0}g()}}catch(k){}e.async&&e.timeout>0&&setTimeout(function(){x&&!F&&g("timeout")},e.timeout);try{x.send(n==="POST"||n==="PUT"||n==="DELETE"?e.data:null)}catch(m){c.handleError(e,x,null,m);d()}e.async||g();return x}},handleError:function(a,b,d,f){if(a.error)a.error.call(a.context||A,b,d,f);if(a.global)(a.context?c(a.context):c.event).trigger("ajaxError",[b,a,f])},active:0,httpSuccess:function(a){try{return!a.status&&location.protocol===
|
|
||||||
"file:"||a.status>=200&&a.status<300||a.status===304||a.status===1223||a.status===0}catch(b){}return false},httpNotModified:function(a,b){var d=a.getResponseHeader("Last-Modified"),f=a.getResponseHeader("Etag");if(d)c.lastModified[b]=d;if(f)c.etag[b]=f;return a.status===304||a.status===0},httpData:function(a,b,d){var f=a.getResponseHeader("content-type")||"",e=b==="xml"||!b&&f.indexOf("xml")>=0;a=e?a.responseXML:a.responseText;if(e&&a.documentElement.nodeName==="parsererror")throw"parsererror";if(d&&
|
|
||||||
d.dataFilter)a=d.dataFilter(a,b);if(typeof a==="string")if(b==="json"||!b&&f.indexOf("json")>=0)if(/^[\],:{}\s]*$/.test(a.replace(/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g,"@").replace(/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g,"]").replace(/(?:^|:|,)(?:\s*\[)+/g,"")))a=A.JSON&&A.JSON.parse?A.JSON.parse(a):(new Function("return "+a))();else throw"Invalid JSON: "+a;else if(b==="script"||!b&&f.indexOf("javascript")>=0)c.globalEval(a);return a},param:function(a,b){function d(e,i){i=
|
|
||||||
c.isFunction(i)?i():i;f[f.length]=encodeURIComponent(e)+"="+encodeURIComponent(i)}var f=[];if(b===w)b=c.ajaxSettings.traditional;c.isArray(a)||a.jquery?c.each(a,function(){d(this.name,this.value)}):c.each(a,function e(i,j){if(c.isArray(j))c.each(j,function(o,p){b?d(i,p):e(i+"["+(typeof p==="object"||c.isArray(p)?o:"")+"]",p)});else!b&&j!=null&&typeof j==="object"?c.each(j,function(o,p){e(i+"["+o+"]",p)}):d(i,j)});return f.join("&").replace(wb,"+")}});var na={},xb=/toggle|show|hide/,yb=/^([+-]=)?([\d+-.]+)(.*)$/,
|
|
||||||
Z,va=[["height","marginTop","marginBottom","paddingTop","paddingBottom"],["width","marginLeft","marginRight","paddingLeft","paddingRight"],["opacity"]];c.fn.extend({show:function(a,b){if(a!=null)return this.animate(L("show",3),a,b);else{a=0;for(b=this.length;a<b;a++){var d=c.data(this[a],"olddisplay");this[a].style.display=d||"";if(c.css(this[a],"display")==="none"){d=this[a].nodeName;var f;if(na[d])f=na[d];else{var e=c("<"+d+" />").appendTo("body");f=e.css("display");if(f==="none")f="block";e.remove();
|
|
||||||
na[d]=f}c.data(this[a],"olddisplay",f)}}a=0;for(b=this.length;a<b;a++)this[a].style.display=c.data(this[a],"olddisplay")||"";return this}},hide:function(a,b){if(a!=null)return this.animate(L("hide",3),a,b);else{a=0;for(b=this.length;a<b;a++){var d=c.data(this[a],"olddisplay");!d&&d!=="none"&&c.data(this[a],"olddisplay",c.css(this[a],"display"))}a=0;for(b=this.length;a<b;a++)this[a].style.display="none";return this}},_toggle:c.fn.toggle,toggle:function(a,b){var d=typeof a==="boolean";if(c.isFunction(a)&&
|
|
||||||
c.isFunction(b))this._toggle.apply(this,arguments);else a==null||d?this.each(function(){var f=d?a:c(this).is(":hidden");c(this)[f?"show":"hide"]()}):this.animate(L("toggle",3),a,b);return this},fadeTo:function(a,b,d){return this.filter(":hidden").css("opacity",0).show().end().animate({opacity:b},a,d)},animate:function(a,b,d,f){var e=c.speed(b,d,f);if(c.isEmptyObject(a))return this.each(e.complete);return this[e.queue===false?"each":"queue"](function(){var i=c.extend({},e),j,o=this.nodeType===1&&c(this).is(":hidden"),
|
|
||||||
p=this;for(j in a){var n=j.replace(ka,la);if(j!==n){a[n]=a[j];delete a[j];j=n}if(a[j]==="hide"&&o||a[j]==="show"&&!o)return i.complete.call(this);if((j==="height"||j==="width")&&this.style){i.display=c.css(this,"display");i.overflow=this.style.overflow}if(c.isArray(a[j])){(i.specialEasing=i.specialEasing||{})[j]=a[j][1];a[j]=a[j][0]}}if(i.overflow!=null)this.style.overflow="hidden";i.curAnim=c.extend({},a);c.each(a,function(t,z){var B=new c.fx(p,i,t);if(xb.test(z))B[z==="toggle"?o?"show":"hide":z](a);
|
|
||||||
else{var C=yb.exec(z),D=B.cur(true)||0;if(C){z=parseFloat(C[2]);var F=C[3]||"px";if(F!=="px"){p.style[t]=(z||1)+F;D=(z||1)/B.cur(true)*D;p.style[t]=D+F}if(C[1])z=(C[1]==="-="?-1:1)*z+D;B.custom(D,z,F)}else B.custom(D,z,"")}});return true})},stop:function(a,b){var d=c.timers;a&&this.queue([]);this.each(function(){for(var f=d.length-1;f>=0;f--)if(d[f].elem===this){b&&d[f](true);d.splice(f,1)}});b||this.dequeue();return this}});c.each({slideDown:L("show",1),slideUp:L("hide",1),slideToggle:L("toggle",
|
|
||||||
1),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"}},function(a,b){c.fn[a]=function(d,f){return this.animate(b,d,f)}});c.extend({speed:function(a,b,d){var f=a&&typeof a==="object"?a:{complete:d||!d&&b||c.isFunction(a)&&a,duration:a,easing:d&&b||b&&!c.isFunction(b)&&b};f.duration=c.fx.off?0:typeof f.duration==="number"?f.duration:c.fx.speeds[f.duration]||c.fx.speeds._default;f.old=f.complete;f.complete=function(){f.queue!==false&&c(this).dequeue();c.isFunction(f.old)&&f.old.call(this)};return f},easing:{linear:function(a,
|
|
||||||
b,d,f){return d+f*a},swing:function(a,b,d,f){return(-Math.cos(a*Math.PI)/2+0.5)*f+d}},timers:[],fx:function(a,b,d){this.options=b;this.elem=a;this.prop=d;if(!b.orig)b.orig={}}});c.fx.prototype={update:function(){this.options.step&&this.options.step.call(this.elem,this.now,this);(c.fx.step[this.prop]||c.fx.step._default)(this);if((this.prop==="height"||this.prop==="width")&&this.elem.style)this.elem.style.display="block"},cur:function(a){if(this.elem[this.prop]!=null&&(!this.elem.style||this.elem.style[this.prop]==
|
|
||||||
null))return this.elem[this.prop];return(a=parseFloat(c.css(this.elem,this.prop,a)))&&a>-10000?a:parseFloat(c.curCSS(this.elem,this.prop))||0},custom:function(a,b,d){function f(i){return e.step(i)}this.startTime=K();this.start=a;this.end=b;this.unit=d||this.unit||"px";this.now=this.start;this.pos=this.state=0;var e=this;f.elem=this.elem;if(f()&&c.timers.push(f)&&!Z)Z=setInterval(c.fx.tick,13)},show:function(){this.options.orig[this.prop]=c.style(this.elem,this.prop);this.options.show=true;this.custom(this.prop===
|
|
||||||
"width"||this.prop==="height"?1:0,this.cur());c(this.elem).show()},hide:function(){this.options.orig[this.prop]=c.style(this.elem,this.prop);this.options.hide=true;this.custom(this.cur(),0)},step:function(a){var b=K(),d=true;if(a||b>=this.options.duration+this.startTime){this.now=this.end;this.pos=this.state=1;this.update();this.options.curAnim[this.prop]=true;for(var f in this.options.curAnim)if(this.options.curAnim[f]!==true)d=false;if(d){if(this.options.display!=null){this.elem.style.overflow=
|
|
||||||
this.options.overflow;a=c.data(this.elem,"olddisplay");this.elem.style.display=a?a:this.options.display;if(c.css(this.elem,"display")==="none")this.elem.style.display="block"}this.options.hide&&c(this.elem).hide();if(this.options.hide||this.options.show)for(var e in this.options.curAnim)c.style(this.elem,e,this.options.orig[e]);this.options.complete.call(this.elem)}return false}else{e=b-this.startTime;this.state=e/this.options.duration;a=this.options.easing||(c.easing.swing?"swing":"linear");this.pos=
|
|
||||||
c.easing[this.options.specialEasing&&this.options.specialEasing[this.prop]||a](this.state,e,0,1,this.options.duration);this.now=this.start+(this.end-this.start)*this.pos;this.update()}return true}};c.extend(c.fx,{tick:function(){for(var a=c.timers,b=0;b<a.length;b++)a[b]()||a.splice(b--,1);a.length||c.fx.stop()},stop:function(){clearInterval(Z);Z=null},speeds:{slow:600,fast:200,_default:400},step:{opacity:function(a){c.style(a.elem,"opacity",a.now)},_default:function(a){if(a.elem.style&&a.elem.style[a.prop]!=
|
|
||||||
null)a.elem.style[a.prop]=(a.prop==="width"||a.prop==="height"?Math.max(0,a.now):a.now)+a.unit;else a.elem[a.prop]=a.now}}});if(c.expr&&c.expr.filters)c.expr.filters.animated=function(a){return c.grep(c.timers,function(b){return a===b.elem}).length};c.fn.offset="getBoundingClientRect"in s.documentElement?function(a){var b=this[0];if(!b||!b.ownerDocument)return null;if(a)return this.each(function(e){c.offset.setOffset(this,a,e)});if(b===b.ownerDocument.body)return c.offset.bodyOffset(b);var d=b.getBoundingClientRect(),
|
|
||||||
f=b.ownerDocument;b=f.body;f=f.documentElement;return{top:d.top+(self.pageYOffset||c.support.boxModel&&f.scrollTop||b.scrollTop)-(f.clientTop||b.clientTop||0),left:d.left+(self.pageXOffset||c.support.boxModel&&f.scrollLeft||b.scrollLeft)-(f.clientLeft||b.clientLeft||0)}}:function(a){var b=this[0];if(!b||!b.ownerDocument)return null;if(a)return this.each(function(t){c.offset.setOffset(this,a,t)});if(b===b.ownerDocument.body)return c.offset.bodyOffset(b);c.offset.initialize();var d=b.offsetParent,f=
|
|
||||||
b,e=b.ownerDocument,i,j=e.documentElement,o=e.body;f=(e=e.defaultView)?e.getComputedStyle(b,null):b.currentStyle;for(var p=b.offsetTop,n=b.offsetLeft;(b=b.parentNode)&&b!==o&&b!==j;){if(c.offset.supportsFixedPosition&&f.position==="fixed")break;i=e?e.getComputedStyle(b,null):b.currentStyle;p-=b.scrollTop;n-=b.scrollLeft;if(b===d){p+=b.offsetTop;n+=b.offsetLeft;if(c.offset.doesNotAddBorder&&!(c.offset.doesAddBorderForTableAndCells&&/^t(able|d|h)$/i.test(b.nodeName))){p+=parseFloat(i.borderTopWidth)||
|
|
||||||
0;n+=parseFloat(i.borderLeftWidth)||0}f=d;d=b.offsetParent}if(c.offset.subtractsBorderForOverflowNotVisible&&i.overflow!=="visible"){p+=parseFloat(i.borderTopWidth)||0;n+=parseFloat(i.borderLeftWidth)||0}f=i}if(f.position==="relative"||f.position==="static"){p+=o.offsetTop;n+=o.offsetLeft}if(c.offset.supportsFixedPosition&&f.position==="fixed"){p+=Math.max(j.scrollTop,o.scrollTop);n+=Math.max(j.scrollLeft,o.scrollLeft)}return{top:p,left:n}};c.offset={initialize:function(){var a=s.body,b=s.createElement("div"),
|
|
||||||
d,f,e,i=parseFloat(c.curCSS(a,"marginTop",true))||0;c.extend(b.style,{position:"absolute",top:0,left:0,margin:0,border:0,width:"1px",height:"1px",visibility:"hidden"});b.innerHTML="<div style='position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;'><div></div></div><table style='position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;' cellpadding='0' cellspacing='0'><tr><td></td></tr></table>";a.insertBefore(b,a.firstChild);
|
|
||||||
d=b.firstChild;f=d.firstChild;e=d.nextSibling.firstChild.firstChild;this.doesNotAddBorder=f.offsetTop!==5;this.doesAddBorderForTableAndCells=e.offsetTop===5;f.style.position="fixed";f.style.top="20px";this.supportsFixedPosition=f.offsetTop===20||f.offsetTop===15;f.style.position=f.style.top="";d.style.overflow="hidden";d.style.position="relative";this.subtractsBorderForOverflowNotVisible=f.offsetTop===-5;this.doesNotIncludeMarginInBodyOffset=a.offsetTop!==i;a.removeChild(b);c.offset.initialize=c.noop},
|
|
||||||
bodyOffset:function(a){var b=a.offsetTop,d=a.offsetLeft;c.offset.initialize();if(c.offset.doesNotIncludeMarginInBodyOffset){b+=parseFloat(c.curCSS(a,"marginTop",true))||0;d+=parseFloat(c.curCSS(a,"marginLeft",true))||0}return{top:b,left:d}},setOffset:function(a,b,d){if(/static/.test(c.curCSS(a,"position")))a.style.position="relative";var f=c(a),e=f.offset(),i=parseInt(c.curCSS(a,"top",true),10)||0,j=parseInt(c.curCSS(a,"left",true),10)||0;if(c.isFunction(b))b=b.call(a,d,e);d={top:b.top-e.top+i,left:b.left-
|
|
||||||
e.left+j};"using"in b?b.using.call(a,d):f.css(d)}};c.fn.extend({position:function(){if(!this[0])return null;var a=this[0],b=this.offsetParent(),d=this.offset(),f=/^body|html$/i.test(b[0].nodeName)?{top:0,left:0}:b.offset();d.top-=parseFloat(c.curCSS(a,"marginTop",true))||0;d.left-=parseFloat(c.curCSS(a,"marginLeft",true))||0;f.top+=parseFloat(c.curCSS(b[0],"borderTopWidth",true))||0;f.left+=parseFloat(c.curCSS(b[0],"borderLeftWidth",true))||0;return{top:d.top-f.top,left:d.left-f.left}},offsetParent:function(){return this.map(function(){for(var a=
|
|
||||||
this.offsetParent||s.body;a&&!/^body|html$/i.test(a.nodeName)&&c.css(a,"position")==="static";)a=a.offsetParent;return a})}});c.each(["Left","Top"],function(a,b){var d="scroll"+b;c.fn[d]=function(f){var e=this[0],i;if(!e)return null;if(f!==w)return this.each(function(){if(i=wa(this))i.scrollTo(!a?f:c(i).scrollLeft(),a?f:c(i).scrollTop());else this[d]=f});else return(i=wa(e))?"pageXOffset"in i?i[a?"pageYOffset":"pageXOffset"]:c.support.boxModel&&i.document.documentElement[d]||i.document.body[d]:e[d]}});
|
|
||||||
c.each(["Height","Width"],function(a,b){var d=b.toLowerCase();c.fn["inner"+b]=function(){return this[0]?c.css(this[0],d,false,"padding"):null};c.fn["outer"+b]=function(f){return this[0]?c.css(this[0],d,false,f?"margin":"border"):null};c.fn[d]=function(f){var e=this[0];if(!e)return f==null?null:this;return"scrollTo"in e&&e.document?e.document.compatMode==="CSS1Compat"&&e.document.documentElement["client"+b]||e.document.body["client"+b]:e.nodeType===9?Math.max(e.documentElement["client"+b],e.body["scroll"+
|
|
||||||
b],e.documentElement["scroll"+b],e.body["offset"+b],e.documentElement["offset"+b]):f===w?c.css(e,d):this.css(d,typeof f==="string"?f:f+"px")}});A.jQuery=A.$=c})(window);
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user