From 509afeef17b12a9b11fd7a0b07169cdb01ae0963 Mon Sep 17 00:00:00 2001 From: "Ian M. Jones" Date: Wed, 7 Dec 2022 10:50:02 +0000 Subject: [PATCH] Deploying version 3.1.0 --- assets/js/settings.js | 238 +++-- assets/js/settings.js.map | 2 +- assets/js/settings.min.js | 2 +- classes/amazon-s3-and-cloudfront.php | 133 ++- classes/as3cf-filter.php | 30 +- classes/as3cf-utils.php | 36 +- classes/integrations/media-library.php | 34 +- classes/items/item.php | 107 +++ classes/items/media-library-item.php | 101 +-- classes/providers/storage/aws-provider.php | 4 + .../storage/digitalocean-provider.php | 1 + classes/providers/storage/gcp-provider.php | 80 +- .../providers/storage/storage-provider.php | 5 +- .../storage/streams/aws-s3-stream-wrapper.php | 13 +- .../upgrades/fix-broken-item-extra-data.php | 74 -- ...e.php => upgrade-clear-postmeta-cache.php} | 4 +- .../upgrade-fix-broken-item-extra-data.php | 159 ++++ classes/upgrades/upgrade-item-extra-data.php | 90 +- classes/upgrades/upgrade.php | 4 + languages/amazon-s3-and-cloudfront-en.pot | 506 +++++------ readme.txt | 23 +- ui/components/BucketSettingsSubPage.svelte | 4 +- ui/components/MediaPage.svelte | 31 +- .../Aws/Api/Parser/AbstractRestParser.php | 2 +- vendor/Aws3/Aws/Api/Serializer/JsonBody.php | 10 +- .../Aws/Api/Serializer/RestJsonSerializer.php | 2 +- vendor/Aws3/Aws/Api/Validator.php | 1 + vendor/Aws3/Aws/Arn/ArnParser.php | 2 +- vendor/Aws3/Aws/ClientResolver.php | 23 +- .../ConfigurationProvider.php | 4 +- .../Aws3/Aws/CloudFront/CloudFrontClient.php | 12 + vendor/Aws3/Aws/CloudFront/Signer.php | 13 +- vendor/Aws3/Aws/CommandPool.php | 3 +- ...eRoleWithWebIdentityCredentialProvider.php | 8 +- .../Aws/Credentials/CredentialProvider.php | 2 +- .../Credentials/InstanceProfileProvider.php | 4 +- .../DefaultsMode/ConfigurationProvider.php | 2 +- .../ConfigurationProvider.php | 4 +- .../UseFipsEndpoint/ConfigurationProvider.php | 4 +- .../ConfigurationProvider.php | 4 +- vendor/Aws3/Aws/Middleware.php | 10 +- vendor/Aws3/Aws/MockHandler.php | 2 +- .../Aws3/Aws/Retry/ConfigurationProvider.php | 2 +- vendor/Aws3/Aws/S3/BatchDelete.php | 3 + vendor/Aws3/Aws/S3/ObjectCopier.php | 5 +- vendor/Aws3/Aws/S3/ObjectUploader.php | 4 + .../ConfigurationProvider.php | 4 +- vendor/Aws3/Aws/S3/S3Client.php | 23 +- vendor/Aws3/Aws/S3/S3ClientInterface.php | 7 + vendor/Aws3/Aws/S3/S3ClientTrait.php | 7 + vendor/Aws3/Aws/S3/StreamWrapper.php | 23 +- vendor/Aws3/Aws/S3/Transfer.php | 24 +- .../S3/UseArnRegion/ConfigurationProvider.php | 4 +- vendor/Aws3/Aws/Sdk.php | 28 +- .../Aws3/Aws/Signature/SignatureProvider.php | 2 +- vendor/Aws3/Aws/Signature/SignatureV4.php | 2 +- .../ConfigurationProvider.php | 4 +- vendor/Aws3/Aws/Waiter.php | 7 +- .../accessanalyzer/2019-11-01/api-2.json.php | 2 +- .../data/account/2021-02-01/api-2.json.php | 2 +- .../Aws/data/acm/2015-12-08/api-2.json.php | 2 +- .../Aws/data/amp/2020-08-01/api-2.json.php | 2 +- .../2021-08-11/api-2.json.php | 2 +- .../2021-08-11/paginators-1.json.php | 2 +- .../data/appconfig/2019-10-09/api-2.json.php | 2 +- .../2019-10-09/paginators-1.json.php | 2 +- .../data/appflow/2020-08-23/api-2.json.php | 2 +- .../2018-11-25/api-2.json.php | 2 +- .../data/appmesh/2019-01-25/api-2.json.php | 2 +- .../data/apprunner/2020-05-15/api-2.json.php | 2 +- .../data/appstream/2016-12-01/api-2.json.php | 2 +- .../data/appsync/2017-07-25/api-2.json.php | 2 +- .../Aws/data/athena/2017-05-18/api-2.json.php | 2 +- .../athena/2017-05-18/paginators-1.json.php | 2 +- .../auditmanager/2017-07-25/api-2.json.php | 2 +- .../backup-gateway/2021-01-01/api-2.json.php | 2 +- .../Aws/data/backup/2018-11-15/api-2.json.php | 2 +- .../backup/2018-11-15/paginators-1.json.php | 2 +- .../backupstorage/2018-04-10/api-2.json.php | 6 + .../2018-04-10/paginators-1.json.php | 6 + .../data/budgets/2016-10-20/api-2.json.php | 2 +- .../Aws/data/ce/2017-10-25/api-2.json.php | 2 +- .../data/ce/2017-10-25/paginators-1.json.php | 2 +- .../2021-07-15/api-2.json.php | 2 +- .../2021-07-15/paginators-1.json.php | 2 +- .../2021-07-15/api-2.json.php | 2 +- .../2021-05-15/api-2.json.php | 2 +- .../2021-05-15/paginators-1.json.php | 2 +- .../Aws/data/chime/2018-05-01/api-2.json.php | 2 +- .../cloudcontrol/2021-09-30/api-2.json.php | 2 +- .../2021-09-30/paginators-1.json.php | 2 +- .../cloudcontrol/2021-09-30/smoke.json.php | 6 + .../2021-09-30/waiters-2.json.php | 2 +- .../cloudformation/2010-05-15/api-2.json.php | 2 +- .../data/cloudfront/2020-05-31/api-2.json.php | 2 +- .../data/cloudtrail/2013-11-01/api-2.json.php | 2 +- .../2013-11-01/paginators-1.json.php | 2 +- .../codeartifact/2018-09-22/api-2.json.php | 2 +- .../data/codedeploy/2014-10-06/api-2.json.php | 2 +- .../2019-09-19/api-2.json.php | 2 +- .../2019-10-15/api-2.json.php | 2 +- .../cognito-idp/2016-04-18/api-2.json.php | 2 +- .../data/comprehend/2017-11-27/api-2.json.php | 2 +- .../Aws/data/config/2014-11-12/api-2.json.php | 2 +- .../config/2014-11-12/paginators-1.json.php | 2 +- .../data/connect/2017-08-08/api-2.json.php | 2 +- .../connect/2017-08-08/paginators-1.json.php | 2 +- .../2021-01-30/api-2.json.php | 6 + .../2021-01-30/paginators-1.json.php | 6 + .../connectcases/2022-10-03/api-2.json.php | 6 + .../2022-10-03/paginators-1.json.php | 6 + .../controltower/2018-05-10/api-2.json.php | 6 + .../2018-05-10/paginators-1.json.php | 6 + .../Aws/data/cur/2017-01-06/api-2.json.php | 2 +- .../2020-08-15/api-2.json.php | 2 +- .../dataexchange/2017-07-25/api-2.json.php | 2 +- .../dataexchange/2017-07-25/smoke.json.php | 6 + .../2017-07-25/waiters-2.json.php | 6 + .../data/datasync/2018-11-09/api-2.json.php | 2 +- .../datasync/2018-11-09/paginators-1.json.php | 2 +- .../data/detective/2018-10-26/api-2.json.php | 2 +- .../2018-10-26/paginators-1.json.php | 2 +- .../data/devicefarm/2015-06-23/api-2.json.php | 2 +- .../devops-guru/2020-12-01/api-2.json.php | 2 +- .../2020-12-01/paginators-1.json.php | 2 +- .../data/discovery/2015-11-01/api-2.json.php | 2 +- .../Aws/data/dlm/2018-01-12/api-2.json.php | 2 +- .../Aws/data/dms/2016-01-01/api-2.json.php | 2 +- .../data/dms/2016-01-01/paginators-1.json.php | 2 +- .../Aws/data/docdb/2014-10-31/api-2.json.php | 2 +- .../Aws/data/drs/2020-02-26/api-2.json.php | 2 +- .../data/drs/2020-02-26/paginators-1.json.php | 2 +- .../Aws/data/ds/2015-04-16/api-2.json.php | 2 +- .../data/ds/2015-04-16/paginators-1.json.php | 2 +- .../data/dynamodb/2012-08-10/api-2.json.php | 2 +- .../dynamodb/2012-08-10/paginators-1.json.php | 2 +- .../2018-04-02/api-2.json.php | 2 +- .../Aws/data/ec2/2016-11-15/api-2.json.php | 2 +- .../data/ec2/2016-11-15/paginators-1.json.php | 2 +- .../Aws/data/eks/2017-11-01/api-2.json.php | 2 +- .../elasticache/2015-02-02/api-2.json.php | 2 +- .../2009-03-31/api-2.json.php | 2 +- .../emr-containers/2020-10-01/api-2.json.php | 2 +- .../emr-serverless/2021-07-13/api-2.json.php | 6 + .../2021-07-13/paginators-1.json.php | 6 + vendor/Aws3/Aws/data/endpoints.json.php | 2 +- .../Aws/data/es/2015-01-01/api-2.json.php | 2 +- .../data/evidently/2021-02-01/api-2.json.php | 2 +- .../2021-02-01/paginators-1.json.php | 2 +- .../finspace-data/2020-07-13/api-2.json.php | 2 +- .../Aws/data/fms/2018-01-01/api-2.json.php | 2 +- .../data/forecast/2018-06-26/api-2.json.php | 2 +- .../forecast/2018-06-26/paginators-1.json.php | 2 +- .../forecastquery/2018-06-26/api-2.json.php | 2 +- .../frauddetector/2019-11-15/api-2.json.php | 2 +- .../Aws/data/fsx/2018-03-01/api-2.json.php | 2 +- .../data/fsx/2018-03-01/paginators-1.json.php | 2 +- .../data/gamelift/2015-10-01/api-2.json.php | 2 +- .../data/gamesparks/2021-08-17/api-2.json.php | 2 +- .../2018-08-08/api-2.json.php | 2 +- .../Aws/data/glue/2017-03-31/api-2.json.php | 2 +- .../data/grafana/2020-08-18/api-2.json.php | 2 +- .../Aws/data/grandfathered-services.json.php | 6 + .../data/greengrass/2017-06-07/api-2.json.php | 2 +- .../2017-06-07/endpoint-rule-set-1.json.php | 6 + .../2017-06-07/endpoint-tests-1.json.php | 6 + .../greengrassv2/2020-11-30/api-2.json.php | 2 +- .../data/guardduty/2017-11-28/api-2.json.php | 2 +- .../2017-11-28/paginators-1.json.php | 2 +- .../identitystore/2020-06-15/api-2.json.php | 2 +- .../2020-06-15/paginators-1.json.php | 2 +- .../data/inspector2/2020-06-08/api-2.json.php | 2 +- .../Aws/data/iot/2015-05-28/api-2.json.php | 2 +- .../2020-09-18/api-2.json.php | 2 +- .../iotevents-data/2018-10-23/api-2.json.php | 2 +- .../iotfleetwise/2021-06-17/api-2.json.php | 6 + .../2021-06-17/paginators-1.json.php | 6 + .../iotfleetwise/2021-06-17/smoke.json.php | 6 + .../2021-06-17/waiters-2.json.php | 6 + .../2018-10-05/api-2.json.php | 2 +- .../iotsitewise/2019-12-02/api-2.json.php | 2 +- .../2019-12-02/paginators-1.json.php | 2 +- .../iotthingsgraph/2018-09-06/api-2.json.php | 2 +- .../iotwireless/2020-11-22/api-2.json.php | 2 +- .../2020-11-22/paginators-1.json.php | 2 +- .../Aws/data/ivs/2020-07-14/api-2.json.php | 2 +- .../data/ivschat/2020-07-14/api-2.json.php | 2 +- .../Aws/data/kendra/2019-02-03/api-2.json.php | 2 +- .../kendra/2019-02-03/paginators-1.json.php | 2 +- .../2017-09-30/api-2.json.php | 2 +- .../2017-09-30/paginators-1.json.php | 2 +- .../kinesisvideo/2017-09-30/api-2.json.php | 2 +- .../Aws/data/kms/2014-11-01/api-2.json.php | 2 +- .../data/kms/2014-11-01/paginators-1.json.php | 2 +- .../lakeformation/2017-03-31/api-2.json.php | 2 +- .../Aws/data/lambda/2015-03-31/api-2.json.php | 2 +- .../2018-05-10/api-2.json.php | 6 + .../2018-05-10/paginators-1.json.php | 6 + .../data/lightsail/2016-11-28/api-2.json.php | 2 +- .../data/location/2020-11-19/api-2.json.php | 2 +- .../location/2020-11-19/paginators-1.json.php | 2 +- .../2020-12-15/api-2.json.php | 2 +- .../2020-12-15/paginators-1.json.php | 2 +- .../lookoutmetrics/2017-07-25/api-2.json.php | 2 +- .../lookoutvision/2020-11-20/api-2.json.php | 2 +- .../Aws/data/m2/2021-04-28/api-2.json.php | 6 + .../data/m2/2021-04-28/paginators-1.json.php | 6 + .../Aws/data/macie2/2020-01-01/api-2.json.php | 2 +- .../data/macie2/2020-01-01/waiters-2.json.php | 6 + vendor/Aws3/Aws/data/manifest.json.php | 2 +- .../2018-09-17/api-2.json.php | 2 +- .../mediaconnect/2018-11-14/api-2.json.php | 2 +- .../mediaconvert/2017-08-29/api-2.json.php | 2 +- .../data/medialive/2017-10-14/api-2.json.php | 2 +- .../2018-11-07/api-2.json.php | 2 +- .../mediapackage/2017-10-12/api-2.json.php | 2 +- .../Aws/data/mgn/2020-02-26/api-2.json.php | 2 +- .../data/mgn/2020-02-26/paginators-1.json.php | 2 +- .../2021-10-26/api-2.json.php | 2 +- .../2021-08-28/api-2.json.php | 6 + .../2021-08-28/paginators-1.json.php | 6 + .../2021-08-28/smoke.json.php | 6 + .../2021-08-28/waiters-2.json.php | 6 + .../models.lex.v2/2020-08-07/api-2.json.php | 2 +- .../data/monitoring/2010-08-01/api-2.json.php | 2 +- .../2010-08-01/paginators-1.json.php | 2 +- .../Aws/data/mwaa/2020-07-01/api-2.json.php | 2 +- .../data/neptune/2014-10-31/api-2.json.php | 2 +- .../2020-11-12/api-2.json.php | 2 +- .../networkmanager/2019-07-05/api-2.json.php | 2 +- .../2019-07-05/paginators-1.json.php | 2 +- .../Aws/data/nimble/2020-08-01/api-2.json.php | 2 +- .../data/nimble/2020-08-01/waiters-2.json.php | 2 +- .../data/opensearch/2021-01-01/api-2.json.php | 2 +- .../organizations/2016-11-28/api-2.json.php | 2 +- .../data/outposts/2019-12-03/api-2.json.php | 2 +- .../outposts/2019-12-03/paginators-1.json.php | 2 +- .../data/panorama/2019-07-24/api-2.json.php | 2 +- .../2018-05-22/api-2.json.php | 2 +- .../personalize/2018-05-22/api-2.json.php | 2 +- .../Aws/data/pi/2018-02-27/api-2.json.php | 2 +- .../data/pinpoint/2016-12-01/api-2.json.php | 2 +- .../Aws/data/polly/2016-06-10/api-2.json.php | 2 +- .../data/pricing/2017-10-15/api-2.json.php | 2 +- .../privatenetworks/2021-12-03/api-2.json.php | 6 + .../2021-12-03/paginators-1.json.php | 6 + .../Aws/data/proton/2020-07-20/api-2.json.php | 2 +- .../proton/2020-07-20/paginators-1.json.php | 2 +- .../data/proton/2020-07-20/waiters-2.json.php | 2 +- .../data/quicksight/2018-04-01/api-2.json.php | 2 +- .../data/rds-data/2018-08-01/api-2.json.php | 2 +- .../Aws/data/rds/2014-10-31/api-2.json.php | 2 +- .../data/rds/2014-10-31/waiters-2.json.php | 2 +- .../redshift-data/2019-12-20/api-2.json.php | 2 +- .../2021-04-21/api-2.json.php | 6 + .../2021-04-21/paginators-1.json.php | 6 + .../data/redshift/2012-12-01/api-2.json.php | 2 +- .../rekognition/2016-06-27/api-2.json.php | 2 +- .../2016-06-27/paginators-1.json.php | 2 +- .../resiliencehub/2020-04-30/api-2.json.php | 2 +- .../rolesanywhere/2018-05-10/api-2.json.php | 6 + .../2018-05-10/paginators-1.json.php | 6 + .../data/route53/2013-04-01/api-2.json.php | 2 +- .../route53/2013-04-01/paginators-1.json.php | 2 +- .../runtime.lex.v2/2020-08-07/api-2.json.php | 2 +- .../2017-05-13/api-2.json.php | 2 +- .../data/s3control/2018-08-20/api-2.json.php | 2 +- .../2019-11-07/api-2.json.php | 2 +- .../sagemaker-edge/2020-09-23/api-2.json.php | 2 +- .../data/sagemaker/2017-07-24/api-2.json.php | 2 +- .../2017-07-24/endpoint-rule-set-1.json.php | 6 + .../2017-07-24/endpoint-tests-1.json.php | 6 + .../2017-07-24/paginators-1.json.php | 2 +- .../securityhub/2018-10-26/api-2.json.php | 2 +- .../2020-06-24/api-2.json.php | 2 +- .../2020-06-24/paginators-1.json.php | 2 +- .../Aws/data/shield/2016-06-02/api-2.json.php | 2 +- .../data/snowball/2016-06-30/api-2.json.php | 2 +- .../snowball/2016-06-30/paginators-1.json.php | 2 +- .../Aws/data/sns/2010-03-31/api-2.json.php | 2 +- .../ssm-incidents/2018-05-10/api-2.json.php | 2 +- .../Aws/data/ssm/2014-11-06/api-2.json.php | 2 +- .../data/sso-admin/2020-07-20/api-2.json.php | 2 +- .../2020-07-20/paginators-1.json.php | 2 +- .../data/sso-oidc/2019-06-10/api-2.json.php | 2 +- .../support-app/2021-08-20/api-2.json.php | 6 + .../2021-08-20/paginators-1.json.php | 6 + .../data/synthetics/2017-10-11/api-2.json.php | 2 +- .../2017-10-11/paginators-1.json.php | 2 +- .../data/transcribe/2017-10-26/api-2.json.php | 2 +- .../data/transfer/2018-11-05/api-2.json.php | 2 +- .../transfer/2018-11-05/paginators-1.json.php | 2 +- .../data/translate/2017-07-01/api-2.json.php | 2 +- .../2017-07-01/paginators-1.json.php | 2 +- .../data/voice-id/2021-09-27/api-2.json.php | 2 +- .../voice-id/2021-09-27/paginators-1.json.php | 2 +- .../Aws/data/wafv2/2019-07-29/api-2.json.php | 2 +- .../wellarchitected/2020-03-31/api-2.json.php | 2 +- .../data/workmail/2017-10-01/api-2.json.php | 2 +- .../workmail/2017-10-01/paginators-1.json.php | 2 +- .../workspaces-web/2020-07-08/api-2.json.php | 2 +- .../data/workspaces/2015-04-08/api-2.json.php | 2 +- vendor/Aws3/CHANGELOG.md | 832 ++++++++++++++++++ vendor/Aws3/GuzzleHttp/Cookie/CookieJar.php | 5 + vendor/Aws3/GuzzleHttp/Cookie/SetCookie.php | 9 +- .../Aws3/GuzzleHttp/Promise/EachPromise.php | 8 - vendor/Aws3/GuzzleHttp/Psr7/UriComparator.php | 47 + vendor/Aws3/GuzzleHttp/RedirectMiddleware.php | 17 +- vendor/Aws3/README.md | 12 +- vendor/Aws3/aws-autoloader.php | 2 +- vendor/Gcp/autoload.php | 16 +- vendor/Gcp/bin/google-cloud-batch | 2 +- vendor/Gcp/composer/InstalledVersions.php | 14 +- vendor/Gcp/composer/autoload_classmap.php | 2 +- vendor/Gcp/composer/autoload_real.php | 14 +- vendor/Gcp/composer/autoload_static.php | 10 +- vendor/Gcp/composer/installed.json | 208 +++-- vendor/Gcp/composer/installed.php | 2 +- vendor/Gcp/firebase/php-jwt/README.md | 99 ++- vendor/Gcp/firebase/php-jwt/composer.json | 7 +- vendor/Gcp/firebase/php-jwt/phpstan.neon.dist | 5 - .../Gcp/firebase/php-jwt/src/CachedKeySet.php | 199 +++++ vendor/Gcp/firebase/php-jwt/src/JWK.php | 115 ++- vendor/Gcp/firebase/php-jwt/src/JWT.php | 29 +- vendor/Gcp/firebase/php-jwt/src/Key.php | 2 +- vendor/Gcp/google/auth/phpstan.neon.dist | 10 - vendor/Gcp/google/auth/src/AccessToken.php | 7 +- vendor/Gcp/google/auth/src/Cache/Item.php | 4 + .../auth/src/Cache/SysVCacheItemPool.php | 3 +- .../Gcp/google/auth/src/Cache/TypedItem.php | 4 + .../auth/src/Credentials/GCECredentials.php | 2 +- .../auth/src/Credentials/IAMCredentials.php | 2 +- .../Gcp/google/auth/src/CredentialsLoader.php | 11 +- .../google/auth/src/FetchAuthTokenCache.php | 6 +- .../src/HttpHandler/HttpHandlerFactory.php | 15 +- .../src/Middleware/AuthTokenMiddleware.php | 2 +- vendor/Gcp/google/auth/src/OAuth2.php | 10 +- vendor/Gcp/google/cloud-core/VERSION | 2 +- vendor/Gcp/google/cloud-core/composer.json | 12 +- vendor/Gcp/google/cloud-core/src/Blob.php | 13 +- .../google/cloud-core/src/EmulatorTrait.php | 2 +- .../src/Exception/ServiceException.php | 92 +- vendor/Gcp/google/cloud-core/src/GeoPoint.php | 20 +- .../src/InsecureCredentialsWrapper.php | 33 + vendor/Gcp/google/cloud-core/src/Int64.php | 13 +- .../Gcp/google/cloud-core/src/Timestamp.php | 13 +- .../Gcp/google/cloud-core/unit-bootstrap.php | 1 - vendor/Gcp/google/cloud-storage/VERSION | 2 +- vendor/Gcp/google/cloud-storage/composer.json | 8 +- .../ServiceDefinition/storage-v1.json | 392 +++------ .../cloud-storage/src/EncryptionTrait.php | 13 +- .../google/cloud-storage/src/Lifecycle.php | 8 + .../cloud-storage/src/StorageClient.php | 11 +- vendor/Gcp/guzzlehttp/guzzle/CHANGELOG.md | 21 + vendor/Gcp/guzzlehttp/guzzle/README.md | 28 +- vendor/Gcp/guzzlehttp/guzzle/composer.json | 12 +- .../guzzle/src/Cookie/CookieJar.php | 5 + .../guzzle/src/Cookie/SetCookie.php | 5 +- .../guzzle/src/Handler/CurlMultiHandler.php | 1 + .../guzzle/src/RedirectMiddleware.php | 17 +- .../guzzlehttp/guzzle/src/RetryMiddleware.php | 2 +- vendor/Gcp/guzzlehttp/guzzle/src/Utils.php | 14 +- vendor/Gcp/guzzlehttp/promises/CHANGELOG.md | 9 +- vendor/Gcp/guzzlehttp/promises/Makefile | 13 - vendor/Gcp/guzzlehttp/promises/README.md | 57 +- .../guzzlehttp/promises/src/EachPromise.php | 8 - vendor/Gcp/guzzlehttp/psr7/CHANGELOG.md | 30 + vendor/Gcp/guzzlehttp/psr7/README.md | 35 +- vendor/Gcp/guzzlehttp/psr7/composer.json | 10 +- .../Gcp/guzzlehttp/psr7/src/CachingStream.php | 4 + .../guzzlehttp/psr7/src/DroppingStream.php | 2 + vendor/Gcp/guzzlehttp/psr7/src/FnStream.php | 1 + vendor/Gcp/guzzlehttp/psr7/src/Header.php | 95 +- .../Gcp/guzzlehttp/psr7/src/InflateStream.php | 2 + .../guzzlehttp/psr7/src/LazyOpenStream.php | 1 + .../Gcp/guzzlehttp/psr7/src/LimitStream.php | 2 + vendor/Gcp/guzzlehttp/psr7/src/Message.php | 3 + .../Gcp/guzzlehttp/psr7/src/MessageTrait.php | 7 +- vendor/Gcp/guzzlehttp/psr7/src/MimeType.php | 2 +- .../guzzlehttp/psr7/src/MultipartStream.php | 5 + .../Gcp/guzzlehttp/psr7/src/NoSeekStream.php | 2 + vendor/Gcp/guzzlehttp/psr7/src/Stream.php | 13 +- .../Gcp/guzzlehttp/psr7/src/UriComparator.php | 43 + vendor/Gcp/guzzlehttp/psr7/src/Utils.php | 34 + vendor/Gcp/monolog/monolog/CHANGELOG.md | 35 +- vendor/Gcp/monolog/monolog/composer.json | 26 +- .../monolog/src/Monolog/ErrorHandler.php | 15 +- .../Formatter/GoogleCloudLoggingFormatter.php | 35 + .../src/Monolog/Formatter/JsonFormatter.php | 20 +- .../src/Monolog/Formatter/LineFormatter.php | 30 +- .../Monolog/Formatter/NormalizerFormatter.php | 3 + .../src/Monolog/Handler/AmqpHandler.php | 29 +- .../src/Monolog/Handler/ChromePHPHandler.php | 6 +- .../src/Monolog/Handler/CubeHandler.php | 3 +- .../Monolog/Handler/ElasticsearchHandler.php | 40 +- .../monolog/src/Monolog/Handler/Handler.php | 9 +- .../src/Monolog/Handler/PHPConsoleHandler.php | 3 +- .../src/Monolog/Handler/RedisHandler.php | 4 +- .../Monolog/Handler/RedisPubSubHandler.php | 4 +- .../Monolog/Handler/RotatingFileHandler.php | 2 +- .../src/Monolog/Handler/StreamHandler.php | 2 +- .../Monolog/Handler/SwiftMailerHandler.php | 2 + .../Monolog/Handler/SymfonyMailerHandler.php | 101 +++ .../Monolog/Handler/SyslogUdp/UdpSocket.php | 36 +- .../monolog/monolog/src/Monolog/Logger.php | 92 +- .../Gcp/monolog/monolog/src/Monolog/Utils.php | 2 +- vendor/Gcp/rize/uri-template/README.md | 2 +- .../src/Rize/UriTemplate/Node/Expression.php | 2 +- wordpress-s3.php | 4 +- 409 files changed, 4223 insertions(+), 1720 deletions(-) delete mode 100644 classes/upgrades/fix-broken-item-extra-data.php rename classes/upgrades/{clear-postmeta-cache.php => upgrade-clear-postmeta-cache.php} (93%) create mode 100644 classes/upgrades/upgrade-fix-broken-item-extra-data.php create mode 100644 vendor/Aws3/Aws/data/backupstorage/2018-04-10/api-2.json.php create mode 100644 vendor/Aws3/Aws/data/backupstorage/2018-04-10/paginators-1.json.php create mode 100644 vendor/Aws3/Aws/data/cloudcontrol/2021-09-30/smoke.json.php create mode 100644 vendor/Aws3/Aws/data/connectcampaigns/2021-01-30/api-2.json.php create mode 100644 vendor/Aws3/Aws/data/connectcampaigns/2021-01-30/paginators-1.json.php create mode 100644 vendor/Aws3/Aws/data/connectcases/2022-10-03/api-2.json.php create mode 100644 vendor/Aws3/Aws/data/connectcases/2022-10-03/paginators-1.json.php create mode 100644 vendor/Aws3/Aws/data/controltower/2018-05-10/api-2.json.php create mode 100644 vendor/Aws3/Aws/data/controltower/2018-05-10/paginators-1.json.php create mode 100644 vendor/Aws3/Aws/data/dataexchange/2017-07-25/smoke.json.php create mode 100644 vendor/Aws3/Aws/data/dataexchange/2017-07-25/waiters-2.json.php create mode 100644 vendor/Aws3/Aws/data/emr-serverless/2021-07-13/api-2.json.php create mode 100644 vendor/Aws3/Aws/data/emr-serverless/2021-07-13/paginators-1.json.php create mode 100644 vendor/Aws3/Aws/data/grandfathered-services.json.php create mode 100644 vendor/Aws3/Aws/data/greengrass/2017-06-07/endpoint-rule-set-1.json.php create mode 100644 vendor/Aws3/Aws/data/greengrass/2017-06-07/endpoint-tests-1.json.php create mode 100644 vendor/Aws3/Aws/data/iotfleetwise/2021-06-17/api-2.json.php create mode 100644 vendor/Aws3/Aws/data/iotfleetwise/2021-06-17/paginators-1.json.php create mode 100644 vendor/Aws3/Aws/data/iotfleetwise/2021-06-17/smoke.json.php create mode 100644 vendor/Aws3/Aws/data/iotfleetwise/2021-06-17/waiters-2.json.php create mode 100644 vendor/Aws3/Aws/data/license-manager-user-subscriptions/2018-05-10/api-2.json.php create mode 100644 vendor/Aws3/Aws/data/license-manager-user-subscriptions/2018-05-10/paginators-1.json.php create mode 100644 vendor/Aws3/Aws/data/m2/2021-04-28/api-2.json.php create mode 100644 vendor/Aws3/Aws/data/m2/2021-04-28/paginators-1.json.php create mode 100644 vendor/Aws3/Aws/data/macie2/2020-01-01/waiters-2.json.php create mode 100644 vendor/Aws3/Aws/data/migrationhuborchestrator/2021-08-28/api-2.json.php create mode 100644 vendor/Aws3/Aws/data/migrationhuborchestrator/2021-08-28/paginators-1.json.php create mode 100644 vendor/Aws3/Aws/data/migrationhuborchestrator/2021-08-28/smoke.json.php create mode 100644 vendor/Aws3/Aws/data/migrationhuborchestrator/2021-08-28/waiters-2.json.php create mode 100644 vendor/Aws3/Aws/data/privatenetworks/2021-12-03/api-2.json.php create mode 100644 vendor/Aws3/Aws/data/privatenetworks/2021-12-03/paginators-1.json.php create mode 100644 vendor/Aws3/Aws/data/redshift-serverless/2021-04-21/api-2.json.php create mode 100644 vendor/Aws3/Aws/data/redshift-serverless/2021-04-21/paginators-1.json.php create mode 100644 vendor/Aws3/Aws/data/rolesanywhere/2018-05-10/api-2.json.php create mode 100644 vendor/Aws3/Aws/data/rolesanywhere/2018-05-10/paginators-1.json.php create mode 100644 vendor/Aws3/Aws/data/sagemaker/2017-07-24/endpoint-rule-set-1.json.php create mode 100644 vendor/Aws3/Aws/data/sagemaker/2017-07-24/endpoint-tests-1.json.php create mode 100644 vendor/Aws3/Aws/data/support-app/2021-08-20/api-2.json.php create mode 100644 vendor/Aws3/Aws/data/support-app/2021-08-20/paginators-1.json.php create mode 100644 vendor/Aws3/GuzzleHttp/Psr7/UriComparator.php delete mode 100644 vendor/Gcp/firebase/php-jwt/phpstan.neon.dist create mode 100644 vendor/Gcp/firebase/php-jwt/src/CachedKeySet.php delete mode 100644 vendor/Gcp/google/auth/phpstan.neon.dist create mode 100644 vendor/Gcp/google/cloud-core/src/InsecureCredentialsWrapper.php delete mode 100644 vendor/Gcp/guzzlehttp/promises/Makefile create mode 100644 vendor/Gcp/guzzlehttp/psr7/src/UriComparator.php create mode 100644 vendor/Gcp/monolog/monolog/src/Monolog/Formatter/GoogleCloudLoggingFormatter.php create mode 100644 vendor/Gcp/monolog/monolog/src/Monolog/Handler/SymfonyMailerHandler.php diff --git a/assets/js/settings.js b/assets/js/settings.js index 2e4d080c..03007b6d 100644 --- a/assets/js/settings.js +++ b/assets/js/settings.js @@ -3696,7 +3696,7 @@ } // (121:3) {#if extra} - function create_if_block_1$b(ctx) { + function create_if_block_1$c(ctx) { let p; const block = { @@ -3717,7 +3717,7 @@ dispatch_dev("SvelteRegisterBlock", { block, - id: create_if_block_1$b.name, + id: create_if_block_1$c.name, type: "if", source: "(121:3) {#if extra}", ctx @@ -3774,7 +3774,7 @@ let if_block1 = (/*heading*/ ctx[8] || /*dismissible*/ ctx[9] || /*expandable*/ ctx[12]) && create_if_block_2$8(ctx); const default_slot_template = /*#slots*/ ctx[23].default; const default_slot = create_slot(default_slot_template, ctx, /*$$scope*/ ctx[22], null); - let if_block2 = /*extra*/ ctx[11] && create_if_block_1$b(ctx); + let if_block2 = /*extra*/ ctx[11] && create_if_block_1$c(ctx); let if_block3 = /*linksHTML*/ ctx[16] && create_if_block$p(ctx); const details_slot_template = /*#slots*/ ctx[23].details; const details_slot = create_slot(details_slot_template, ctx, /*$$scope*/ ctx[22], get_details_slot_context); @@ -3887,7 +3887,7 @@ if (if_block2) { if_block2.p(ctx, dirty); } else { - if_block2 = create_if_block_1$b(ctx); + if_block2 = create_if_block_1$c(ctx); if_block2.c(); if_block2.m(div0, t3); } @@ -4498,7 +4498,7 @@ } // (13:3) {#if !notification.dismissed && (notification.only_show_on_tab === tab || notification.only_show_on_tab === tabParent || !notification.only_show_on_tab)} - function create_if_block_1$a(ctx) { + function create_if_block_1$b(ctx) { let switch_instance; let switch_instance_anchor; let current; @@ -4581,7 +4581,7 @@ dispatch_dev("SvelteRegisterBlock", { block, - id: create_if_block_1$a.name, + id: create_if_block_1$b.name, type: "if", source: "(13:3) {#if !notification.dismissed && (notification.only_show_on_tab === tab || notification.only_show_on_tab === tabParent || !notification.only_show_on_tab)}", ctx @@ -4672,7 +4672,7 @@ let first; let if_block_anchor; let current; - let if_block = !/*notification*/ ctx[4].dismissed && (/*notification*/ ctx[4].only_show_on_tab === /*tab*/ ctx[1] || /*notification*/ ctx[4].only_show_on_tab === /*tabParent*/ ctx[2] || !/*notification*/ ctx[4].only_show_on_tab) && create_if_block_1$a(ctx); + let if_block = !/*notification*/ ctx[4].dismissed && (/*notification*/ ctx[4].only_show_on_tab === /*tab*/ ctx[1] || /*notification*/ ctx[4].only_show_on_tab === /*tabParent*/ ctx[2] || !/*notification*/ ctx[4].only_show_on_tab) && create_if_block_1$b(ctx); const block = { key: key_1, @@ -4700,7 +4700,7 @@ transition_in(if_block, 1); } } else { - if_block = create_if_block_1$a(ctx); + if_block = create_if_block_1$b(ctx); if_block.c(); transition_in(if_block, 1); if_block.m(if_block_anchor.parentNode, if_block_anchor); @@ -5603,7 +5603,7 @@ } // (18:3) {#if progress && index < (displayItems.length - 1)} - function create_if_block_1$9(ctx) { + function create_if_block_1$a(ctx) { let li; let img; let img_src_value; @@ -5637,7 +5637,7 @@ dispatch_dev("SvelteRegisterBlock", { block, - id: create_if_block_1$9.name, + id: create_if_block_1$a.name, type: "if", source: "(18:3) {#if progress && index < (displayItems.length - 1)}", ctx @@ -5658,7 +5658,7 @@ $$inline: true }); - let if_block = /*progress*/ ctx[2] && /*index*/ ctx[8] < /*displayItems*/ ctx[3].length - 1 && create_if_block_1$9(ctx); + let if_block = /*progress*/ ctx[2] && /*index*/ ctx[8] < /*displayItems*/ ctx[3].length - 1 && create_if_block_1$a(ctx); const block = { c: function create() { @@ -5683,7 +5683,7 @@ if (if_block) { if_block.p(ctx, dirty); } else { - if_block = create_if_block_1$9(ctx); + if_block = create_if_block_1$a(ctx); if_block.c(); if_block.m(if_block_anchor.parentNode, if_block_anchor); } @@ -7836,7 +7836,7 @@ } // (81:4) {#if helpURL} - function create_if_block_1$8(ctx) { + function create_if_block_1$9(ctx) { let helpbutton; let current; @@ -7878,7 +7878,7 @@ dispatch_dev("SvelteRegisterBlock", { block, - id: create_if_block_1$8.name, + id: create_if_block_1$9.name, type: "if", source: "(81:4) {#if helpURL}", ctx @@ -7916,7 +7916,7 @@ }); let if_block1 = /*storageProvider*/ ctx[9] && create_if_block_3$4(ctx); - const if_block_creators_1 = [create_if_block_1$8, create_if_block_2$6]; + const if_block_creators_1 = [create_if_block_1$9, create_if_block_2$6]; const if_blocks_1 = []; function select_block_type_2(ctx, dirty) { @@ -10095,7 +10095,7 @@ } // (126:1) {#if toggleName} - function create_if_block_1$7(ctx) { + function create_if_block_1$8(ctx) { let settingnotifications; let current; @@ -10133,7 +10133,7 @@ dispatch_dev("SvelteRegisterBlock", { block, - id: create_if_block_1$7.name, + id: create_if_block_1$8.name, type: "if", source: "(126:1) {#if toggleName}", ctx @@ -10220,7 +10220,7 @@ }); let if_block0 = /*input*/ ctx[10] && create_if_block_2$5(ctx); - let if_block1 = /*toggleName*/ ctx[7] && create_if_block_1$7(ctx); + let if_block1 = /*toggleName*/ ctx[7] && create_if_block_1$8(ctx); let if_block2 = /*textName*/ ctx[8] && create_if_block$e(ctx); const default_slot_template = /*#slots*/ ctx[22].default; const default_slot = create_slot(default_slot_template, ctx, /*$$scope*/ ctx[25], null); @@ -10313,7 +10313,7 @@ transition_in(if_block1, 1); } } else { - if_block1 = create_if_block_1$7(ctx); + if_block1 = create_if_block_1$8(ctx); if_block1.c(); transition_in(if_block1, 1); if_block1.m(div, t3); @@ -11728,7 +11728,7 @@ binding_callbacks.push(() => bind(settingspaneloption, 'toggle', settingspaneloption_toggle_binding)); binding_callbacks.push(() => bind(settingspaneloption, 'text', settingspaneloption_text_binding)); - let if_block = /*$delivery_provider*/ ctx[1].use_signed_urls_key_file_allowed && /*$settings*/ ctx[2]["enable-delivery-domain"] && create_if_block_1$6(ctx); + let if_block = /*$delivery_provider*/ ctx[1].use_signed_urls_key_file_allowed && /*$settings*/ ctx[2]["enable-delivery-domain"] && create_if_block_1$7(ctx); const block = { c: function create() { @@ -11771,7 +11771,7 @@ transition_in(if_block, 1); } } else { - if_block = create_if_block_1$6(ctx); + if_block = create_if_block_1$7(ctx); if_block.c(); transition_in(if_block, 1); if_block.m(if_block_anchor.parentNode, if_block_anchor); @@ -11817,7 +11817,7 @@ } // (51:2) {#if $delivery_provider.use_signed_urls_key_file_allowed && $settings[ "enable-delivery-domain" ]} - function create_if_block_1$6(ctx) { + function create_if_block_1$7(ctx) { let settingspaneloption; let updating_toggle; let current; @@ -11886,7 +11886,7 @@ dispatch_dev("SvelteRegisterBlock", { block, - id: create_if_block_1$6.name, + id: create_if_block_1$7.name, type: "if", source: "(51:2) {#if $delivery_provider.use_signed_urls_key_file_allowed && $settings[ \\\"enable-delivery-domain\\\" ]}", ctx @@ -13661,8 +13661,8 @@ /* src/amazon-s3-and-cloudfront/ui/components/MediaPage.svelte generated by Svelte v3.49.0 */ const file$r = "src/amazon-s3-and-cloudfront/ui/components/MediaPage.svelte"; - // (44:0) - function create_default_slot$c(ctx) { + // (52:1) {#if render} + function create_if_block_1$6(ctx) { let notifications; let t0; let div; @@ -13688,7 +13688,7 @@ subnav = new SubNav({ props: { name: /*name*/ ctx[0], - items: /*items*/ ctx[3], + items: /*items*/ ctx[4], subpage: true }, $$inline: true @@ -13697,7 +13697,7 @@ subpages = new SubPages({ props: { name: /*name*/ ctx[0], - routes: /*routes*/ ctx[2] + routes: /*routes*/ ctx[3] }, $$inline: true }); @@ -13720,7 +13720,7 @@ create_component(urlpreview.$$.fragment); attr_dev(div, "id", "provider-warning-notifications"); attr_dev(div, "class", "notifications wrapper"); - add_location(div, file$r, 45, 1, 1496); + add_location(div, file$r, 53, 2, 1633); }, m: function mount(target, anchor) { mount_component(notifications, target, anchor); @@ -13782,18 +13782,84 @@ } }; + dispatch_dev("SvelteRegisterBlock", { + block, + id: create_if_block_1$6.name, + type: "if", + source: "(52:1) {#if render}", + ctx + }); + + return block; + } + + // (51:0) + function create_default_slot$c(ctx) { + let if_block_anchor; + let current; + let if_block = /*render*/ ctx[2] && create_if_block_1$6(ctx); + + const block = { + c: function create() { + if (if_block) if_block.c(); + if_block_anchor = empty(); + }, + m: function mount(target, anchor) { + if (if_block) if_block.m(target, anchor); + insert_dev(target, if_block_anchor, anchor); + current = true; + }, + p: function update(ctx, dirty) { + if (/*render*/ ctx[2]) { + if (if_block) { + if_block.p(ctx, dirty); + + if (dirty & /*render*/ 4) { + transition_in(if_block, 1); + } + } else { + if_block = create_if_block_1$6(ctx); + if_block.c(); + transition_in(if_block, 1); + if_block.m(if_block_anchor.parentNode, if_block_anchor); + } + } else if (if_block) { + group_outros(); + + transition_out(if_block, 1, 1, () => { + if_block = null; + }); + + check_outros(); + } + }, + i: function intro(local) { + if (current) return; + transition_in(if_block); + current = true; + }, + o: function outro(local) { + transition_out(if_block); + current = false; + }, + d: function destroy(detaching) { + if (if_block) if_block.d(detaching); + if (detaching) detach_dev(if_block_anchor); + } + }; + dispatch_dev("SvelteRegisterBlock", { block, id: create_default_slot$c.name, type: "slot", - source: "(44:0) ", + source: "(51:0) ", ctx }); return block; } - // (55:0) {#if sidebar} + // (64:0) {#if sidebar && render} function create_if_block$a(ctx) { let switch_instance; let switch_instance_anchor; @@ -13863,7 +13929,7 @@ block, id: create_if_block$a.name, type: "if", - source: "(55:0) {#if sidebar}", + source: "(64:0) {#if sidebar && render}", ctx }); @@ -13886,10 +13952,10 @@ $$inline: true }); - page.$on("routeEvent", /*routeEvent_handler*/ ctx[5]); - let if_block = /*sidebar*/ ctx[1] && create_if_block$a(ctx); + page.$on("routeEvent", /*routeEvent_handler*/ ctx[6]); + let if_block = /*sidebar*/ ctx[1] && /*render*/ ctx[2] && create_if_block$a(ctx); footer = new Footer({ $$inline: true }); - footer.$on("routeEvent", /*routeEvent_handler_1*/ ctx[6]); + footer.$on("routeEvent", /*routeEvent_handler_1*/ ctx[7]); const block = { c: function create() { @@ -13914,17 +13980,17 @@ const page_changes = {}; if (dirty & /*name*/ 1) page_changes.name = /*name*/ ctx[0]; - if (dirty & /*$$scope, name*/ 513) { + if (dirty & /*$$scope, name, render*/ 2053) { page_changes.$$scope = { dirty, ctx }; } page.$set(page_changes); - if (/*sidebar*/ ctx[1]) { + if (/*sidebar*/ ctx[1] && /*render*/ ctx[2]) { if (if_block) { if_block.p(ctx, dirty); - if (dirty & /*sidebar*/ 2) { + if (dirty & /*sidebar, render*/ 6) { transition_in(if_block, 1); } } else { @@ -13977,15 +14043,19 @@ } function instance$t($$self, $$props, $$invalidate) { + let $is_plugin_setup; let $strings; + validate_store(is_plugin_setup, 'is_plugin_setup'); + component_subscribe($$self, is_plugin_setup, $$value => $$invalidate(8, $is_plugin_setup = $$value)); validate_store(strings, 'strings'); - component_subscribe($$self, strings, $$value => $$invalidate(7, $strings = $$value)); + component_subscribe($$self, strings, $$value => $$invalidate(9, $strings = $$value)); let { $$slots: slots = {}, $$scope } = $$props; validate_slots('MediaPage', slots, []); let { name = "media" } = $$props; let { params = {} } = $$props; const _params = params; // Stops compiler warning for params; let sidebar = null; + let render = false; if (hasContext('sidebar')) { sidebar = getContext('sidebar'); @@ -14010,6 +14080,12 @@ } ]; + onMount(() => { + if ($is_plugin_setup) { + $$invalidate(2, render = true); + } + }); + const writable_props = ['name', 'params']; Object.keys($$props).forEach(key => { @@ -14026,13 +14102,15 @@ $$self.$$set = $$props => { if ('name' in $$props) $$invalidate(0, name = $$props.name); - if ('params' in $$props) $$invalidate(4, params = $$props.params); + if ('params' in $$props) $$invalidate(5, params = $$props.params); }; $$self.$capture_state = () => ({ getContext, hasContext, + onMount, setContext, + is_plugin_setup, settingsLocked, strings, Page, @@ -14048,28 +14126,40 @@ params, _params, sidebar, + render, routes, items, + $is_plugin_setup, $strings }); $$self.$inject_state = $$props => { if ('name' in $$props) $$invalidate(0, name = $$props.name); - if ('params' in $$props) $$invalidate(4, params = $$props.params); + if ('params' in $$props) $$invalidate(5, params = $$props.params); if ('sidebar' in $$props) $$invalidate(1, sidebar = $$props.sidebar); + if ('render' in $$props) $$invalidate(2, render = $$props.render); }; if ($$props && "$$inject" in $$props) { $$self.$inject_state($$props.$$inject); } - return [name, sidebar, routes, items, params, routeEvent_handler, routeEvent_handler_1]; + return [ + name, + sidebar, + render, + routes, + items, + params, + routeEvent_handler, + routeEvent_handler_1 + ]; } class MediaPage extends SvelteComponentDev { constructor(options) { super(options); - init(this, options, instance$t, create_fragment$t, safe_not_equal, { name: 0, params: 4 }); + init(this, options, instance$t, create_fragment$t, safe_not_equal, { name: 0, params: 5 }); dispatch_dev("SvelteRegisterComponent", { component: this, @@ -19209,7 +19299,7 @@ if (if_block) if_block.c(); attr_dev(label, "class", "input-label"); attr_dev(label, "for", "bucket-name"); - add_location(label, file$f, 286, 7, 7764); + add_location(label, file$f, 286, 7, 7863); attr_dev(input, "type", "text"); attr_dev(input, "id", "bucket-name"); attr_dev(input, "class", "bucket-name"); @@ -19218,11 +19308,11 @@ attr_dev(input, "placeholder", input_placeholder_value = /*$strings*/ ctx[14].enter_bucket_name_placeholder); input.disabled = /*disabled*/ ctx[11]; toggle_class(input, "disabled", /*disabled*/ ctx[11]); - add_location(input, file$f, 287, 7, 7847); + add_location(input, file$f, 287, 7, 7946); attr_dev(div0, "class", "new-bucket-details flex-column"); - add_location(div0, file$f, 285, 6, 7712); + add_location(div0, file$f, 285, 6, 7811); attr_dev(div1, "class", "flex-row align-center row"); - add_location(div1, file$f, 284, 5, 7666); + add_location(div1, file$f, 284, 5, 7765); }, m: function mount(target, anchor) { insert_dev(target, div1, anchor); @@ -19354,15 +19444,15 @@ attr_dev(label, "class", "input-label"); attr_dev(label, "for", "region"); - add_location(label, file$f, 301, 8, 8221); + add_location(label, file$f, 301, 8, 8320); attr_dev(select, "name", "region"); attr_dev(select, "id", "region"); select.disabled = /*newRegionDisabled*/ ctx[12]; if (/*newRegion*/ ctx[8] === void 0) add_render_callback(() => /*select_change_handler*/ ctx[26].call(select)); toggle_class(select, "disabled", /*newRegionDisabled*/ ctx[12]); - add_location(select, file$f, 304, 8, 8367); + add_location(select, file$f, 304, 8, 8466); attr_dev(div, "class", "region flex-column"); - add_location(div, file$f, 300, 7, 8180); + add_location(div, file$f, 300, 7, 8279); }, m: function mount(target, anchor) { insert_dev(target, div, anchor); @@ -19473,7 +19563,7 @@ option.__value = option_value_value = /*regionKey*/ ctx[39]; option.value = option.__value; option.selected = option_selected_value = /*regionKey*/ ctx[39] === /*newRegion*/ ctx[8]; - add_location(option, file$f, 306, 10, 8594); + add_location(option, file$f, 306, 10, 8693); }, m: function mount(target, anchor) { insert_dev(target, option, anchor); @@ -19656,13 +19746,13 @@ attr_dev(label, "class", "input-label"); attr_dev(label, "for", "list-region"); - add_location(label, file$f, 321, 6, 8913); + add_location(label, file$f, 321, 6, 9012); attr_dev(select, "name", "region"); attr_dev(select, "id", "list-region"); select.disabled = /*newRegionDisabled*/ ctx[12]; if (/*newRegion*/ ctx[8] === void 0) add_render_callback(() => /*select_change_handler_1*/ ctx[27].call(select)); toggle_class(select, "disabled", /*newRegionDisabled*/ ctx[12]); - add_location(select, file$f, 324, 6, 9058); + add_location(select, file$f, 324, 6, 9157); }, m: function mount(target, anchor) { insert_dev(target, label, anchor); @@ -19774,7 +19864,7 @@ option.__value = option_value_value = /*regionKey*/ ctx[39]; option.value = option.__value; option.selected = option_selected_value = /*regionKey*/ ctx[39] === /*newRegion*/ ctx[8]; - add_location(option, file$f, 326, 8, 9286); + add_location(option, file$f, 326, 8, 9385); }, m: function mount(target, anchor) { insert_dev(target, option, anchor); @@ -19848,7 +19938,7 @@ ul = element("ul"); if_block.c(); attr_dev(ul, "class", "bucket-list"); - add_location(ul, file$f, 338, 6, 9539); + add_location(ul, file$f, 338, 6, 9638); }, m: function mount(target, anchor) { insert_dev(target, ul, anchor); @@ -19898,9 +19988,9 @@ li = element("li"); p = element("p"); t = text(t_value); - add_location(p, file$f, 357, 9, 10304); + add_location(p, file$f, 357, 9, 10403); attr_dev(li, "class", "row nothing-found"); - add_location(li, file$f, 356, 8, 10264); + add_location(li, file$f, 356, 8, 10363); }, m: function mount(target, anchor) { insert_dev(target, li, anchor); @@ -20007,7 +20097,7 @@ if (!src_url_equal(img.src, img_src_value = /*$urls*/ ctx[15].assets + 'img/icon/licence-checked.svg')) attr_dev(img, "src", img_src_value); attr_dev(img, "type", "image/svg+xml"); attr_dev(img, "alt", img_alt_value = /*$strings*/ ctx[14].selected_desc); - add_location(img, file$f, 351, 11, 10064); + add_location(img, file$f, 351, 11, 10163); }, m: function mount(target, anchor) { insert_dev(target, img, anchor); @@ -20072,12 +20162,12 @@ attr_dev(img, "class", "icon bucket"); if (!src_url_equal(img.src, img_src_value = /*$urls*/ ctx[15].assets + 'img/icon/bucket.svg')) attr_dev(img, "src", img_src_value); attr_dev(img, "alt", img_alt_value = /*$strings*/ ctx[14].bucket_icon); - add_location(img, file$f, 348, 10, 9882); - add_location(p, file$f, 349, 10, 9990); + add_location(img, file$f, 348, 10, 9981); + add_location(p, file$f, 349, 10, 10089); attr_dev(li, "class", "row"); attr_dev(li, "data-bucket-name", li_data_bucket_name_value = /*bucket*/ ctx[44].Name); toggle_class(li, "active", /*newBucket*/ ctx[2] === /*bucket*/ ctx[44].Name); - add_location(li, file$f, 341, 9, 9635); + add_location(li, file$f, 341, 9, 9734); }, m: function mount(target, anchor) { insert_dev(target, li, anchor); @@ -20205,7 +20295,7 @@ p = element("p"); t = text(/*invalidBucketNameMessage*/ ctx[10]); attr_dev(p, "class", "input-error"); - add_location(p, file$f, 364, 5, 10439); + add_location(p, file$f, 364, 5, 10538); }, m: function mount(target, anchor) { insert_dev(target, p, anchor); @@ -20329,7 +20419,7 @@ if (if_block2) if_block2.c(); if_block2_anchor = empty(); attr_dev(div, "class", "flex-row align-center row radio-btns"); - add_location(div, file$f, 278, 4, 7304); + add_location(div, file$f, 278, 4, 7403); }, m: function mount(target, anchor) { insert_dev(target, div, anchor); @@ -20621,7 +20711,7 @@ option.__value = option_value_value = /*regionKey*/ ctx[39]; option.value = option.__value; option.selected = option_selected_value = /*regionKey*/ ctx[39] === /*newRegion*/ ctx[8]; - add_location(option, file$f, 394, 8, 11601); + add_location(option, file$f, 394, 8, 11700); }, m: function mount(target, anchor) { insert_dev(target, option, anchor); @@ -20668,7 +20758,7 @@ p = element("p"); t = text(/*invalidBucketNameMessage*/ ctx[10]); attr_dev(p, "class", "input-error"); - add_location(p, file$f, 405, 5, 11824); + add_location(p, file$f, 405, 5, 11923); }, m: function mount(target, anchor) { insert_dev(target, p, anchor); @@ -20781,7 +20871,7 @@ if_block_anchor = empty(); attr_dev(label0, "class", "input-label"); attr_dev(label0, "for", "new-bucket-name"); - add_location(label0, file$f, 375, 6, 10827); + add_location(label0, file$f, 375, 6, 10926); attr_dev(input, "type", "text"); attr_dev(input, "id", "new-bucket-name"); attr_dev(input, "class", "bucket-name"); @@ -20790,22 +20880,22 @@ attr_dev(input, "placeholder", input_placeholder_value = /*$strings*/ ctx[14].enter_bucket_name_placeholder); input.disabled = /*disabled*/ ctx[11]; toggle_class(input, "disabled", /*disabled*/ ctx[11]); - add_location(input, file$f, 376, 6, 10913); + add_location(input, file$f, 376, 6, 11012); attr_dev(div0, "class", "new-bucket-details flex-column"); - add_location(div0, file$f, 374, 5, 10776); + add_location(div0, file$f, 374, 5, 10875); attr_dev(label1, "class", "input-label"); attr_dev(label1, "for", "new-region"); - add_location(label1, file$f, 389, 6, 11230); + add_location(label1, file$f, 389, 6, 11329); attr_dev(select, "name", "region"); attr_dev(select, "id", "new-region"); select.disabled = /*newRegionDisabled*/ ctx[12]; if (/*newRegion*/ ctx[8] === void 0) add_render_callback(() => /*select_change_handler_2*/ ctx[30].call(select)); toggle_class(select, "disabled", /*newRegionDisabled*/ ctx[12]); - add_location(select, file$f, 392, 6, 11374); + add_location(select, file$f, 392, 6, 11473); attr_dev(div1, "class", "region flex-column"); - add_location(div1, file$f, 388, 5, 11191); + add_location(div1, file$f, 388, 5, 11290); attr_dev(div2, "class", "flex-row align-center row"); - add_location(div2, file$f, 373, 4, 10731); + add_location(div2, file$f, 373, 4, 10830); }, m: function mount(target, anchor) { insert_dev(target, div2, anchor); @@ -21380,7 +21470,7 @@ return $strings.defined_region_invalid; } - const bucketNamePattern = /[^a-z0-9.-]/; + const bucketNamePattern = source === "new" ? /[^a-z0-9.\-]/ : /[^a-zA-Z0-9.\-_]/; let message = ""; if (bucket.trim().length < 1) { @@ -21390,7 +21480,9 @@ message = $strings.create_bucket_name_missing; } } else if (true === bucketNamePattern.test(bucket)) { - message = $strings.create_bucket_invalid_chars; + message = source === "new" + ? $strings.create_bucket_invalid_chars + : $strings.select_bucket_invalid_chars; } else if (bucket.length < 3) { message = $strings.create_bucket_name_short; } else if (bucket.length > 63) { diff --git a/assets/js/settings.js.map b/assets/js/settings.js.map index c44d6d2a..8373aa23 100644 --- a/assets/js/settings.js.map +++ b/assets/js/settings.js.map @@ -1 +1 @@ -{"version":3,"file":"settings.js","sources":["../../../../node_modules/svelte/internal/index.mjs","../../../../node_modules/svelte/store/index.mjs","../js/objectsDiffer.js","../js/stores.js","../../../../node_modules/svelte-spa-router/wrap.js","../js/routes.js","../../../../node_modules/regexparam/dist/index.mjs","../../../../node_modules/svelte-spa-router/Router.svelte","../components/Page.svelte","../../../../node_modules/svelte/easing/index.mjs","../../../../node_modules/svelte/transition/index.mjs","../components/Notification.svelte","../components/Notifications.svelte","../components/BlockPublicAccessWarning.svelte","../components/ObjectOwnershipEnforcedWarning.svelte","../components/SubNavItem.svelte","../components/SubNav.svelte","../components/SubPages.svelte","../../../../node_modules/svelte-spa-router/active.js","../components/SubPage.svelte","../components/PanelContainer.svelte","../components/PanelRow.svelte","../components/DefinedInWPConfig.svelte","../components/ToggleSwitch.svelte","../components/HelpButton.svelte","../components/Panel.svelte","../components/Button.svelte","../components/StorageSettingsHeadingRow.svelte","../components/SettingNotifications.svelte","../components/SettingsPanelOption.svelte","../components/StorageSettingsPanel.svelte","../components/DeliverySettingsHeadingRow.svelte","../components/DeliverySettingsPanel.svelte","../components/MediaSettings.svelte","../components/UrlPreview.svelte","../js/scrollNotificationsIntoView.js","../components/Footer.svelte","../components/MediaPage.svelte","../components/StoragePage.svelte","../js/needsRefresh.js","../components/TabButton.svelte","../components/RadioButton.svelte","../components/AccessKeysDefine.svelte","../components/BackNextButtonsRow.svelte","../components/KeyFileDefine.svelte","../components/UseServerRolesDefine.svelte","../components/AccessKeysEntry.svelte","../components/KeyFileEntry.svelte","../components/StorageProviderSubPage.svelte","../js/scrollIntoView.js","../components/Loading.svelte","../components/BucketSettingsSubPage.svelte","../components/Checkbox.svelte","../components/SecuritySubPage.svelte","../components/DeliveryPage.svelte","../js/defaultPages.js","../components/Upsell.svelte","../components/AssetsUpgrade.svelte","../components/AssetsPage.svelte","../components/ToolsUpgrade.svelte","../components/ToolsPage.svelte","../components/SupportPage.svelte","../lite/pages.js","../js/settingsNotifications.js","../components/Header.svelte","../components/Settings.svelte","../lite/Header.svelte","../components/NavItem.svelte","../components/Nav.svelte","../components/Pages.svelte","../lite/Sidebar.svelte","../lite/Settings.svelte"],"sourcesContent":["function noop() { }\nconst identity = x => x;\nfunction assign(tar, src) {\n // @ts-ignore\n for (const k in src)\n tar[k] = src[k];\n return tar;\n}\nfunction is_promise(value) {\n return value && typeof value === 'object' && typeof value.then === 'function';\n}\nfunction add_location(element, file, line, column, char) {\n element.__svelte_meta = {\n loc: { file, line, column, char }\n };\n}\nfunction run(fn) {\n return fn();\n}\nfunction blank_object() {\n return Object.create(null);\n}\nfunction run_all(fns) {\n fns.forEach(run);\n}\nfunction is_function(thing) {\n return typeof thing === 'function';\n}\nfunction safe_not_equal(a, b) {\n return a != a ? b == b : a !== b || ((a && typeof a === 'object') || typeof a === 'function');\n}\nlet src_url_equal_anchor;\nfunction src_url_equal(element_src, url) {\n if (!src_url_equal_anchor) {\n src_url_equal_anchor = document.createElement('a');\n }\n src_url_equal_anchor.href = url;\n return element_src === src_url_equal_anchor.href;\n}\nfunction not_equal(a, b) {\n return a != a ? b == b : a !== b;\n}\nfunction is_empty(obj) {\n return Object.keys(obj).length === 0;\n}\nfunction validate_store(store, name) {\n if (store != null && typeof store.subscribe !== 'function') {\n throw new Error(`'${name}' is not a store with a 'subscribe' method`);\n }\n}\nfunction subscribe(store, ...callbacks) {\n if (store == null) {\n return noop;\n }\n const unsub = store.subscribe(...callbacks);\n return unsub.unsubscribe ? () => unsub.unsubscribe() : unsub;\n}\nfunction get_store_value(store) {\n let value;\n subscribe(store, _ => value = _)();\n return value;\n}\nfunction component_subscribe(component, store, callback) {\n component.$$.on_destroy.push(subscribe(store, callback));\n}\nfunction create_slot(definition, ctx, $$scope, fn) {\n if (definition) {\n const slot_ctx = get_slot_context(definition, ctx, $$scope, fn);\n return definition[0](slot_ctx);\n }\n}\nfunction get_slot_context(definition, ctx, $$scope, fn) {\n return definition[1] && fn\n ? assign($$scope.ctx.slice(), definition[1](fn(ctx)))\n : $$scope.ctx;\n}\nfunction get_slot_changes(definition, $$scope, dirty, fn) {\n if (definition[2] && fn) {\n const lets = definition[2](fn(dirty));\n if ($$scope.dirty === undefined) {\n return lets;\n }\n if (typeof lets === 'object') {\n const merged = [];\n const len = Math.max($$scope.dirty.length, lets.length);\n for (let i = 0; i < len; i += 1) {\n merged[i] = $$scope.dirty[i] | lets[i];\n }\n return merged;\n }\n return $$scope.dirty | lets;\n }\n return $$scope.dirty;\n}\nfunction update_slot_base(slot, slot_definition, ctx, $$scope, slot_changes, get_slot_context_fn) {\n if (slot_changes) {\n const slot_context = get_slot_context(slot_definition, ctx, $$scope, get_slot_context_fn);\n slot.p(slot_context, slot_changes);\n }\n}\nfunction update_slot(slot, slot_definition, ctx, $$scope, dirty, get_slot_changes_fn, get_slot_context_fn) {\n const slot_changes = get_slot_changes(slot_definition, $$scope, dirty, get_slot_changes_fn);\n update_slot_base(slot, slot_definition, ctx, $$scope, slot_changes, get_slot_context_fn);\n}\nfunction get_all_dirty_from_scope($$scope) {\n if ($$scope.ctx.length > 32) {\n const dirty = [];\n const length = $$scope.ctx.length / 32;\n for (let i = 0; i < length; i++) {\n dirty[i] = -1;\n }\n return dirty;\n }\n return -1;\n}\nfunction exclude_internal_props(props) {\n const result = {};\n for (const k in props)\n if (k[0] !== '$')\n result[k] = props[k];\n return result;\n}\nfunction compute_rest_props(props, keys) {\n const rest = {};\n keys = new Set(keys);\n for (const k in props)\n if (!keys.has(k) && k[0] !== '$')\n rest[k] = props[k];\n return rest;\n}\nfunction compute_slots(slots) {\n const result = {};\n for (const key in slots) {\n result[key] = true;\n }\n return result;\n}\nfunction once(fn) {\n let ran = false;\n return function (...args) {\n if (ran)\n return;\n ran = true;\n fn.call(this, ...args);\n };\n}\nfunction null_to_empty(value) {\n return value == null ? '' : value;\n}\nfunction set_store_value(store, ret, value) {\n store.set(value);\n return ret;\n}\nconst has_prop = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop);\nfunction action_destroyer(action_result) {\n return action_result && is_function(action_result.destroy) ? action_result.destroy : noop;\n}\n\nconst is_client = typeof window !== 'undefined';\nlet now = is_client\n ? () => window.performance.now()\n : () => Date.now();\nlet raf = is_client ? cb => requestAnimationFrame(cb) : noop;\n// used internally for testing\nfunction set_now(fn) {\n now = fn;\n}\nfunction set_raf(fn) {\n raf = fn;\n}\n\nconst tasks = new Set();\nfunction run_tasks(now) {\n tasks.forEach(task => {\n if (!task.c(now)) {\n tasks.delete(task);\n task.f();\n }\n });\n if (tasks.size !== 0)\n raf(run_tasks);\n}\n/**\n * For testing purposes only!\n */\nfunction clear_loops() {\n tasks.clear();\n}\n/**\n * Creates a new task that runs on each raf frame\n * until it returns a falsy value or is aborted\n */\nfunction loop(callback) {\n let task;\n if (tasks.size === 0)\n raf(run_tasks);\n return {\n promise: new Promise(fulfill => {\n tasks.add(task = { c: callback, f: fulfill });\n }),\n abort() {\n tasks.delete(task);\n }\n };\n}\n\n// Track which nodes are claimed during hydration. Unclaimed nodes can then be removed from the DOM\n// at the end of hydration without touching the remaining nodes.\nlet is_hydrating = false;\nfunction start_hydrating() {\n is_hydrating = true;\n}\nfunction end_hydrating() {\n is_hydrating = false;\n}\nfunction upper_bound(low, high, key, value) {\n // Return first index of value larger than input value in the range [low, high)\n while (low < high) {\n const mid = low + ((high - low) >> 1);\n if (key(mid) <= value) {\n low = mid + 1;\n }\n else {\n high = mid;\n }\n }\n return low;\n}\nfunction init_hydrate(target) {\n if (target.hydrate_init)\n return;\n target.hydrate_init = true;\n // We know that all children have claim_order values since the unclaimed have been detached if target is not \n let children = target.childNodes;\n // If target is , there may be children without claim_order\n if (target.nodeName === 'HEAD') {\n const myChildren = [];\n for (let i = 0; i < children.length; i++) {\n const node = children[i];\n if (node.claim_order !== undefined) {\n myChildren.push(node);\n }\n }\n children = myChildren;\n }\n /*\n * Reorder claimed children optimally.\n * We can reorder claimed children optimally by finding the longest subsequence of\n * nodes that are already claimed in order and only moving the rest. The longest\n * subsequence subsequence of nodes that are claimed in order can be found by\n * computing the longest increasing subsequence of .claim_order values.\n *\n * This algorithm is optimal in generating the least amount of reorder operations\n * possible.\n *\n * Proof:\n * We know that, given a set of reordering operations, the nodes that do not move\n * always form an increasing subsequence, since they do not move among each other\n * meaning that they must be already ordered among each other. Thus, the maximal\n * set of nodes that do not move form a longest increasing subsequence.\n */\n // Compute longest increasing subsequence\n // m: subsequence length j => index k of smallest value that ends an increasing subsequence of length j\n const m = new Int32Array(children.length + 1);\n // Predecessor indices + 1\n const p = new Int32Array(children.length);\n m[0] = -1;\n let longest = 0;\n for (let i = 0; i < children.length; i++) {\n const current = children[i].claim_order;\n // Find the largest subsequence length such that it ends in a value less than our current value\n // upper_bound returns first greater value, so we subtract one\n // with fast path for when we are on the current longest subsequence\n const seqLen = ((longest > 0 && children[m[longest]].claim_order <= current) ? longest + 1 : upper_bound(1, longest, idx => children[m[idx]].claim_order, current)) - 1;\n p[i] = m[seqLen] + 1;\n const newLen = seqLen + 1;\n // We can guarantee that current is the smallest value. Otherwise, we would have generated a longer sequence.\n m[newLen] = i;\n longest = Math.max(newLen, longest);\n }\n // The longest increasing subsequence of nodes (initially reversed)\n const lis = [];\n // The rest of the nodes, nodes that will be moved\n const toMove = [];\n let last = children.length - 1;\n for (let cur = m[longest] + 1; cur != 0; cur = p[cur - 1]) {\n lis.push(children[cur - 1]);\n for (; last >= cur; last--) {\n toMove.push(children[last]);\n }\n last--;\n }\n for (; last >= 0; last--) {\n toMove.push(children[last]);\n }\n lis.reverse();\n // We sort the nodes being moved to guarantee that their insertion order matches the claim order\n toMove.sort((a, b) => a.claim_order - b.claim_order);\n // Finally, we move the nodes\n for (let i = 0, j = 0; i < toMove.length; i++) {\n while (j < lis.length && toMove[i].claim_order >= lis[j].claim_order) {\n j++;\n }\n const anchor = j < lis.length ? lis[j] : null;\n target.insertBefore(toMove[i], anchor);\n }\n}\nfunction append(target, node) {\n target.appendChild(node);\n}\nfunction append_styles(target, style_sheet_id, styles) {\n const append_styles_to = get_root_for_style(target);\n if (!append_styles_to.getElementById(style_sheet_id)) {\n const style = element('style');\n style.id = style_sheet_id;\n style.textContent = styles;\n append_stylesheet(append_styles_to, style);\n }\n}\nfunction get_root_for_style(node) {\n if (!node)\n return document;\n const root = node.getRootNode ? node.getRootNode() : node.ownerDocument;\n if (root && root.host) {\n return root;\n }\n return node.ownerDocument;\n}\nfunction append_empty_stylesheet(node) {\n const style_element = element('style');\n append_stylesheet(get_root_for_style(node), style_element);\n return style_element.sheet;\n}\nfunction append_stylesheet(node, style) {\n append(node.head || node, style);\n}\nfunction append_hydration(target, node) {\n if (is_hydrating) {\n init_hydrate(target);\n if ((target.actual_end_child === undefined) || ((target.actual_end_child !== null) && (target.actual_end_child.parentElement !== target))) {\n target.actual_end_child = target.firstChild;\n }\n // Skip nodes of undefined ordering\n while ((target.actual_end_child !== null) && (target.actual_end_child.claim_order === undefined)) {\n target.actual_end_child = target.actual_end_child.nextSibling;\n }\n if (node !== target.actual_end_child) {\n // We only insert if the ordering of this node should be modified or the parent node is not target\n if (node.claim_order !== undefined || node.parentNode !== target) {\n target.insertBefore(node, target.actual_end_child);\n }\n }\n else {\n target.actual_end_child = node.nextSibling;\n }\n }\n else if (node.parentNode !== target || node.nextSibling !== null) {\n target.appendChild(node);\n }\n}\nfunction insert(target, node, anchor) {\n target.insertBefore(node, anchor || null);\n}\nfunction insert_hydration(target, node, anchor) {\n if (is_hydrating && !anchor) {\n append_hydration(target, node);\n }\n else if (node.parentNode !== target || node.nextSibling != anchor) {\n target.insertBefore(node, anchor || null);\n }\n}\nfunction detach(node) {\n node.parentNode.removeChild(node);\n}\nfunction destroy_each(iterations, detaching) {\n for (let i = 0; i < iterations.length; i += 1) {\n if (iterations[i])\n iterations[i].d(detaching);\n }\n}\nfunction element(name) {\n return document.createElement(name);\n}\nfunction element_is(name, is) {\n return document.createElement(name, { is });\n}\nfunction object_without_properties(obj, exclude) {\n const target = {};\n for (const k in obj) {\n if (has_prop(obj, k)\n // @ts-ignore\n && exclude.indexOf(k) === -1) {\n // @ts-ignore\n target[k] = obj[k];\n }\n }\n return target;\n}\nfunction svg_element(name) {\n return document.createElementNS('http://www.w3.org/2000/svg', name);\n}\nfunction text(data) {\n return document.createTextNode(data);\n}\nfunction space() {\n return text(' ');\n}\nfunction empty() {\n return text('');\n}\nfunction listen(node, event, handler, options) {\n node.addEventListener(event, handler, options);\n return () => node.removeEventListener(event, handler, options);\n}\nfunction prevent_default(fn) {\n return function (event) {\n event.preventDefault();\n // @ts-ignore\n return fn.call(this, event);\n };\n}\nfunction stop_propagation(fn) {\n return function (event) {\n event.stopPropagation();\n // @ts-ignore\n return fn.call(this, event);\n };\n}\nfunction self(fn) {\n return function (event) {\n // @ts-ignore\n if (event.target === this)\n fn.call(this, event);\n };\n}\nfunction trusted(fn) {\n return function (event) {\n // @ts-ignore\n if (event.isTrusted)\n fn.call(this, event);\n };\n}\nfunction attr(node, attribute, value) {\n if (value == null)\n node.removeAttribute(attribute);\n else if (node.getAttribute(attribute) !== value)\n node.setAttribute(attribute, value);\n}\nfunction set_attributes(node, attributes) {\n // @ts-ignore\n const descriptors = Object.getOwnPropertyDescriptors(node.__proto__);\n for (const key in attributes) {\n if (attributes[key] == null) {\n node.removeAttribute(key);\n }\n else if (key === 'style') {\n node.style.cssText = attributes[key];\n }\n else if (key === '__value') {\n node.value = node[key] = attributes[key];\n }\n else if (descriptors[key] && descriptors[key].set) {\n node[key] = attributes[key];\n }\n else {\n attr(node, key, attributes[key]);\n }\n }\n}\nfunction set_svg_attributes(node, attributes) {\n for (const key in attributes) {\n attr(node, key, attributes[key]);\n }\n}\nfunction set_custom_element_data(node, prop, value) {\n if (prop in node) {\n node[prop] = typeof node[prop] === 'boolean' && value === '' ? true : value;\n }\n else {\n attr(node, prop, value);\n }\n}\nfunction xlink_attr(node, attribute, value) {\n node.setAttributeNS('http://www.w3.org/1999/xlink', attribute, value);\n}\nfunction get_binding_group_value(group, __value, checked) {\n const value = new Set();\n for (let i = 0; i < group.length; i += 1) {\n if (group[i].checked)\n value.add(group[i].__value);\n }\n if (!checked) {\n value.delete(__value);\n }\n return Array.from(value);\n}\nfunction to_number(value) {\n return value === '' ? null : +value;\n}\nfunction time_ranges_to_array(ranges) {\n const array = [];\n for (let i = 0; i < ranges.length; i += 1) {\n array.push({ start: ranges.start(i), end: ranges.end(i) });\n }\n return array;\n}\nfunction children(element) {\n return Array.from(element.childNodes);\n}\nfunction init_claim_info(nodes) {\n if (nodes.claim_info === undefined) {\n nodes.claim_info = { last_index: 0, total_claimed: 0 };\n }\n}\nfunction claim_node(nodes, predicate, processNode, createNode, dontUpdateLastIndex = false) {\n // Try to find nodes in an order such that we lengthen the longest increasing subsequence\n init_claim_info(nodes);\n const resultNode = (() => {\n // We first try to find an element after the previous one\n for (let i = nodes.claim_info.last_index; i < nodes.length; i++) {\n const node = nodes[i];\n if (predicate(node)) {\n const replacement = processNode(node);\n if (replacement === undefined) {\n nodes.splice(i, 1);\n }\n else {\n nodes[i] = replacement;\n }\n if (!dontUpdateLastIndex) {\n nodes.claim_info.last_index = i;\n }\n return node;\n }\n }\n // Otherwise, we try to find one before\n // We iterate in reverse so that we don't go too far back\n for (let i = nodes.claim_info.last_index - 1; i >= 0; i--) {\n const node = nodes[i];\n if (predicate(node)) {\n const replacement = processNode(node);\n if (replacement === undefined) {\n nodes.splice(i, 1);\n }\n else {\n nodes[i] = replacement;\n }\n if (!dontUpdateLastIndex) {\n nodes.claim_info.last_index = i;\n }\n else if (replacement === undefined) {\n // Since we spliced before the last_index, we decrease it\n nodes.claim_info.last_index--;\n }\n return node;\n }\n }\n // If we can't find any matching node, we create a new one\n return createNode();\n })();\n resultNode.claim_order = nodes.claim_info.total_claimed;\n nodes.claim_info.total_claimed += 1;\n return resultNode;\n}\nfunction claim_element_base(nodes, name, attributes, create_element) {\n return claim_node(nodes, (node) => node.nodeName === name, (node) => {\n const remove = [];\n for (let j = 0; j < node.attributes.length; j++) {\n const attribute = node.attributes[j];\n if (!attributes[attribute.name]) {\n remove.push(attribute.name);\n }\n }\n remove.forEach(v => node.removeAttribute(v));\n return undefined;\n }, () => create_element(name));\n}\nfunction claim_element(nodes, name, attributes) {\n return claim_element_base(nodes, name, attributes, element);\n}\nfunction claim_svg_element(nodes, name, attributes) {\n return claim_element_base(nodes, name, attributes, svg_element);\n}\nfunction claim_text(nodes, data) {\n return claim_node(nodes, (node) => node.nodeType === 3, (node) => {\n const dataStr = '' + data;\n if (node.data.startsWith(dataStr)) {\n if (node.data.length !== dataStr.length) {\n return node.splitText(dataStr.length);\n }\n }\n else {\n node.data = dataStr;\n }\n }, () => text(data), true // Text nodes should not update last index since it is likely not worth it to eliminate an increasing subsequence of actual elements\n );\n}\nfunction claim_space(nodes) {\n return claim_text(nodes, ' ');\n}\nfunction find_comment(nodes, text, start) {\n for (let i = start; i < nodes.length; i += 1) {\n const node = nodes[i];\n if (node.nodeType === 8 /* comment node */ && node.textContent.trim() === text) {\n return i;\n }\n }\n return nodes.length;\n}\nfunction claim_html_tag(nodes, is_svg) {\n // find html opening tag\n const start_index = find_comment(nodes, 'HTML_TAG_START', 0);\n const end_index = find_comment(nodes, 'HTML_TAG_END', start_index);\n if (start_index === end_index) {\n return new HtmlTagHydration(undefined, is_svg);\n }\n init_claim_info(nodes);\n const html_tag_nodes = nodes.splice(start_index, end_index - start_index + 1);\n detach(html_tag_nodes[0]);\n detach(html_tag_nodes[html_tag_nodes.length - 1]);\n const claimed_nodes = html_tag_nodes.slice(1, html_tag_nodes.length - 1);\n for (const n of claimed_nodes) {\n n.claim_order = nodes.claim_info.total_claimed;\n nodes.claim_info.total_claimed += 1;\n }\n return new HtmlTagHydration(claimed_nodes, is_svg);\n}\nfunction set_data(text, data) {\n data = '' + data;\n if (text.wholeText !== data)\n text.data = data;\n}\nfunction set_input_value(input, value) {\n input.value = value == null ? '' : value;\n}\nfunction set_input_type(input, type) {\n try {\n input.type = type;\n }\n catch (e) {\n // do nothing\n }\n}\nfunction set_style(node, key, value, important) {\n if (value === null) {\n node.style.removeProperty(key);\n }\n else {\n node.style.setProperty(key, value, important ? 'important' : '');\n }\n}\nfunction select_option(select, value) {\n for (let i = 0; i < select.options.length; i += 1) {\n const option = select.options[i];\n if (option.__value === value) {\n option.selected = true;\n return;\n }\n }\n select.selectedIndex = -1; // no option should be selected\n}\nfunction select_options(select, value) {\n for (let i = 0; i < select.options.length; i += 1) {\n const option = select.options[i];\n option.selected = ~value.indexOf(option.__value);\n }\n}\nfunction select_value(select) {\n const selected_option = select.querySelector(':checked') || select.options[0];\n return selected_option && selected_option.__value;\n}\nfunction select_multiple_value(select) {\n return [].map.call(select.querySelectorAll(':checked'), option => option.__value);\n}\n// unfortunately this can't be a constant as that wouldn't be tree-shakeable\n// so we cache the result instead\nlet crossorigin;\nfunction is_crossorigin() {\n if (crossorigin === undefined) {\n crossorigin = false;\n try {\n if (typeof window !== 'undefined' && window.parent) {\n void window.parent.document;\n }\n }\n catch (error) {\n crossorigin = true;\n }\n }\n return crossorigin;\n}\nfunction add_resize_listener(node, fn) {\n const computed_style = getComputedStyle(node);\n if (computed_style.position === 'static') {\n node.style.position = 'relative';\n }\n const iframe = element('iframe');\n iframe.setAttribute('style', 'display: block; position: absolute; top: 0; left: 0; width: 100%; height: 100%; ' +\n 'overflow: hidden; border: 0; opacity: 0; pointer-events: none; z-index: -1;');\n iframe.setAttribute('aria-hidden', 'true');\n iframe.tabIndex = -1;\n const crossorigin = is_crossorigin();\n let unsubscribe;\n if (crossorigin) {\n iframe.src = \"data:text/html,\";\n unsubscribe = listen(window, 'message', (event) => {\n if (event.source === iframe.contentWindow)\n fn();\n });\n }\n else {\n iframe.src = 'about:blank';\n iframe.onload = () => {\n unsubscribe = listen(iframe.contentWindow, 'resize', fn);\n };\n }\n append(node, iframe);\n return () => {\n if (crossorigin) {\n unsubscribe();\n }\n else if (unsubscribe && iframe.contentWindow) {\n unsubscribe();\n }\n detach(iframe);\n };\n}\nfunction toggle_class(element, name, toggle) {\n element.classList[toggle ? 'add' : 'remove'](name);\n}\nfunction custom_event(type, detail, { bubbles = false, cancelable = false } = {}) {\n const e = document.createEvent('CustomEvent');\n e.initCustomEvent(type, bubbles, cancelable, detail);\n return e;\n}\nfunction query_selector_all(selector, parent = document.body) {\n return Array.from(parent.querySelectorAll(selector));\n}\nclass HtmlTag {\n constructor(is_svg = false) {\n this.is_svg = false;\n this.is_svg = is_svg;\n this.e = this.n = null;\n }\n c(html) {\n this.h(html);\n }\n m(html, target, anchor = null) {\n if (!this.e) {\n if (this.is_svg)\n this.e = svg_element(target.nodeName);\n else\n this.e = element(target.nodeName);\n this.t = target;\n this.c(html);\n }\n this.i(anchor);\n }\n h(html) {\n this.e.innerHTML = html;\n this.n = Array.from(this.e.childNodes);\n }\n i(anchor) {\n for (let i = 0; i < this.n.length; i += 1) {\n insert(this.t, this.n[i], anchor);\n }\n }\n p(html) {\n this.d();\n this.h(html);\n this.i(this.a);\n }\n d() {\n this.n.forEach(detach);\n }\n}\nclass HtmlTagHydration extends HtmlTag {\n constructor(claimed_nodes, is_svg = false) {\n super(is_svg);\n this.e = this.n = null;\n this.l = claimed_nodes;\n }\n c(html) {\n if (this.l) {\n this.n = this.l;\n }\n else {\n super.c(html);\n }\n }\n i(anchor) {\n for (let i = 0; i < this.n.length; i += 1) {\n insert_hydration(this.t, this.n[i], anchor);\n }\n }\n}\nfunction attribute_to_object(attributes) {\n const result = {};\n for (const attribute of attributes) {\n result[attribute.name] = attribute.value;\n }\n return result;\n}\nfunction get_custom_elements_slots(element) {\n const result = {};\n element.childNodes.forEach((node) => {\n result[node.slot || 'default'] = true;\n });\n return result;\n}\n\n// we need to store the information for multiple documents because a Svelte application could also contain iframes\n// https://github.com/sveltejs/svelte/issues/3624\nconst managed_styles = new Map();\nlet active = 0;\n// https://github.com/darkskyapp/string-hash/blob/master/index.js\nfunction hash(str) {\n let hash = 5381;\n let i = str.length;\n while (i--)\n hash = ((hash << 5) - hash) ^ str.charCodeAt(i);\n return hash >>> 0;\n}\nfunction create_style_information(doc, node) {\n const info = { stylesheet: append_empty_stylesheet(node), rules: {} };\n managed_styles.set(doc, info);\n return info;\n}\nfunction create_rule(node, a, b, duration, delay, ease, fn, uid = 0) {\n const step = 16.666 / duration;\n let keyframes = '{\\n';\n for (let p = 0; p <= 1; p += step) {\n const t = a + (b - a) * ease(p);\n keyframes += p * 100 + `%{${fn(t, 1 - t)}}\\n`;\n }\n const rule = keyframes + `100% {${fn(b, 1 - b)}}\\n}`;\n const name = `__svelte_${hash(rule)}_${uid}`;\n const doc = get_root_for_style(node);\n const { stylesheet, rules } = managed_styles.get(doc) || create_style_information(doc, node);\n if (!rules[name]) {\n rules[name] = true;\n stylesheet.insertRule(`@keyframes ${name} ${rule}`, stylesheet.cssRules.length);\n }\n const animation = node.style.animation || '';\n node.style.animation = `${animation ? `${animation}, ` : ''}${name} ${duration}ms linear ${delay}ms 1 both`;\n active += 1;\n return name;\n}\nfunction delete_rule(node, name) {\n const previous = (node.style.animation || '').split(', ');\n const next = previous.filter(name\n ? anim => anim.indexOf(name) < 0 // remove specific animation\n : anim => anim.indexOf('__svelte') === -1 // remove all Svelte animations\n );\n const deleted = previous.length - next.length;\n if (deleted) {\n node.style.animation = next.join(', ');\n active -= deleted;\n if (!active)\n clear_rules();\n }\n}\nfunction clear_rules() {\n raf(() => {\n if (active)\n return;\n managed_styles.forEach(info => {\n const { stylesheet } = info;\n let i = stylesheet.cssRules.length;\n while (i--)\n stylesheet.deleteRule(i);\n info.rules = {};\n });\n managed_styles.clear();\n });\n}\n\nfunction create_animation(node, from, fn, params) {\n if (!from)\n return noop;\n const to = node.getBoundingClientRect();\n if (from.left === to.left && from.right === to.right && from.top === to.top && from.bottom === to.bottom)\n return noop;\n const { delay = 0, duration = 300, easing = identity, \n // @ts-ignore todo: should this be separated from destructuring? Or start/end added to public api and documentation?\n start: start_time = now() + delay, \n // @ts-ignore todo:\n end = start_time + duration, tick = noop, css } = fn(node, { from, to }, params);\n let running = true;\n let started = false;\n let name;\n function start() {\n if (css) {\n name = create_rule(node, 0, 1, duration, delay, easing, css);\n }\n if (!delay) {\n started = true;\n }\n }\n function stop() {\n if (css)\n delete_rule(node, name);\n running = false;\n }\n loop(now => {\n if (!started && now >= start_time) {\n started = true;\n }\n if (started && now >= end) {\n tick(1, 0);\n stop();\n }\n if (!running) {\n return false;\n }\n if (started) {\n const p = now - start_time;\n const t = 0 + 1 * easing(p / duration);\n tick(t, 1 - t);\n }\n return true;\n });\n start();\n tick(0, 1);\n return stop;\n}\nfunction fix_position(node) {\n const style = getComputedStyle(node);\n if (style.position !== 'absolute' && style.position !== 'fixed') {\n const { width, height } = style;\n const a = node.getBoundingClientRect();\n node.style.position = 'absolute';\n node.style.width = width;\n node.style.height = height;\n add_transform(node, a);\n }\n}\nfunction add_transform(node, a) {\n const b = node.getBoundingClientRect();\n if (a.left !== b.left || a.top !== b.top) {\n const style = getComputedStyle(node);\n const transform = style.transform === 'none' ? '' : style.transform;\n node.style.transform = `${transform} translate(${a.left - b.left}px, ${a.top - b.top}px)`;\n }\n}\n\nlet current_component;\nfunction set_current_component(component) {\n current_component = component;\n}\nfunction get_current_component() {\n if (!current_component)\n throw new Error('Function called outside component initialization');\n return current_component;\n}\nfunction beforeUpdate(fn) {\n get_current_component().$$.before_update.push(fn);\n}\nfunction onMount(fn) {\n get_current_component().$$.on_mount.push(fn);\n}\nfunction afterUpdate(fn) {\n get_current_component().$$.after_update.push(fn);\n}\nfunction onDestroy(fn) {\n get_current_component().$$.on_destroy.push(fn);\n}\nfunction createEventDispatcher() {\n const component = get_current_component();\n return (type, detail, { cancelable = false } = {}) => {\n const callbacks = component.$$.callbacks[type];\n if (callbacks) {\n // TODO are there situations where events could be dispatched\n // in a server (non-DOM) environment?\n const event = custom_event(type, detail, { cancelable });\n callbacks.slice().forEach(fn => {\n fn.call(component, event);\n });\n return !event.defaultPrevented;\n }\n return true;\n };\n}\nfunction setContext(key, context) {\n get_current_component().$$.context.set(key, context);\n return context;\n}\nfunction getContext(key) {\n return get_current_component().$$.context.get(key);\n}\nfunction getAllContexts() {\n return get_current_component().$$.context;\n}\nfunction hasContext(key) {\n return get_current_component().$$.context.has(key);\n}\n// TODO figure out if we still want to support\n// shorthand events, or if we want to implement\n// a real bubbling mechanism\nfunction bubble(component, event) {\n const callbacks = component.$$.callbacks[event.type];\n if (callbacks) {\n // @ts-ignore\n callbacks.slice().forEach(fn => fn.call(this, event));\n }\n}\n\nconst dirty_components = [];\nconst intros = { enabled: false };\nconst binding_callbacks = [];\nconst render_callbacks = [];\nconst flush_callbacks = [];\nconst resolved_promise = Promise.resolve();\nlet update_scheduled = false;\nfunction schedule_update() {\n if (!update_scheduled) {\n update_scheduled = true;\n resolved_promise.then(flush);\n }\n}\nfunction tick() {\n schedule_update();\n return resolved_promise;\n}\nfunction add_render_callback(fn) {\n render_callbacks.push(fn);\n}\nfunction add_flush_callback(fn) {\n flush_callbacks.push(fn);\n}\n// flush() calls callbacks in this order:\n// 1. All beforeUpdate callbacks, in order: parents before children\n// 2. All bind:this callbacks, in reverse order: children before parents.\n// 3. All afterUpdate callbacks, in order: parents before children. EXCEPT\n// for afterUpdates called during the initial onMount, which are called in\n// reverse order: children before parents.\n// Since callbacks might update component values, which could trigger another\n// call to flush(), the following steps guard against this:\n// 1. During beforeUpdate, any updated components will be added to the\n// dirty_components array and will cause a reentrant call to flush(). Because\n// the flush index is kept outside the function, the reentrant call will pick\n// up where the earlier call left off and go through all dirty components. The\n// current_component value is saved and restored so that the reentrant call will\n// not interfere with the \"parent\" flush() call.\n// 2. bind:this callbacks cannot trigger new flush() calls.\n// 3. During afterUpdate, any updated components will NOT have their afterUpdate\n// callback called a second time; the seen_callbacks set, outside the flush()\n// function, guarantees this behavior.\nconst seen_callbacks = new Set();\nlet flushidx = 0; // Do *not* move this inside the flush() function\nfunction flush() {\n const saved_component = current_component;\n do {\n // first, call beforeUpdate functions\n // and update components\n while (flushidx < dirty_components.length) {\n const component = dirty_components[flushidx];\n flushidx++;\n set_current_component(component);\n update(component.$$);\n }\n set_current_component(null);\n dirty_components.length = 0;\n flushidx = 0;\n while (binding_callbacks.length)\n binding_callbacks.pop()();\n // then, once components are updated, call\n // afterUpdate functions. This may cause\n // subsequent updates...\n for (let i = 0; i < render_callbacks.length; i += 1) {\n const callback = render_callbacks[i];\n if (!seen_callbacks.has(callback)) {\n // ...so guard against infinite loops\n seen_callbacks.add(callback);\n callback();\n }\n }\n render_callbacks.length = 0;\n } while (dirty_components.length);\n while (flush_callbacks.length) {\n flush_callbacks.pop()();\n }\n update_scheduled = false;\n seen_callbacks.clear();\n set_current_component(saved_component);\n}\nfunction update($$) {\n if ($$.fragment !== null) {\n $$.update();\n run_all($$.before_update);\n const dirty = $$.dirty;\n $$.dirty = [-1];\n $$.fragment && $$.fragment.p($$.ctx, dirty);\n $$.after_update.forEach(add_render_callback);\n }\n}\n\nlet promise;\nfunction wait() {\n if (!promise) {\n promise = Promise.resolve();\n promise.then(() => {\n promise = null;\n });\n }\n return promise;\n}\nfunction dispatch(node, direction, kind) {\n node.dispatchEvent(custom_event(`${direction ? 'intro' : 'outro'}${kind}`));\n}\nconst outroing = new Set();\nlet outros;\nfunction group_outros() {\n outros = {\n r: 0,\n c: [],\n p: outros // parent group\n };\n}\nfunction check_outros() {\n if (!outros.r) {\n run_all(outros.c);\n }\n outros = outros.p;\n}\nfunction transition_in(block, local) {\n if (block && block.i) {\n outroing.delete(block);\n block.i(local);\n }\n}\nfunction transition_out(block, local, detach, callback) {\n if (block && block.o) {\n if (outroing.has(block))\n return;\n outroing.add(block);\n outros.c.push(() => {\n outroing.delete(block);\n if (callback) {\n if (detach)\n block.d(1);\n callback();\n }\n });\n block.o(local);\n }\n else if (callback) {\n callback();\n }\n}\nconst null_transition = { duration: 0 };\nfunction create_in_transition(node, fn, params) {\n let config = fn(node, params);\n let running = false;\n let animation_name;\n let task;\n let uid = 0;\n function cleanup() {\n if (animation_name)\n delete_rule(node, animation_name);\n }\n function go() {\n const { delay = 0, duration = 300, easing = identity, tick = noop, css } = config || null_transition;\n if (css)\n animation_name = create_rule(node, 0, 1, duration, delay, easing, css, uid++);\n tick(0, 1);\n const start_time = now() + delay;\n const end_time = start_time + duration;\n if (task)\n task.abort();\n running = true;\n add_render_callback(() => dispatch(node, true, 'start'));\n task = loop(now => {\n if (running) {\n if (now >= end_time) {\n tick(1, 0);\n dispatch(node, true, 'end');\n cleanup();\n return running = false;\n }\n if (now >= start_time) {\n const t = easing((now - start_time) / duration);\n tick(t, 1 - t);\n }\n }\n return running;\n });\n }\n let started = false;\n return {\n start() {\n if (started)\n return;\n started = true;\n delete_rule(node);\n if (is_function(config)) {\n config = config();\n wait().then(go);\n }\n else {\n go();\n }\n },\n invalidate() {\n started = false;\n },\n end() {\n if (running) {\n cleanup();\n running = false;\n }\n }\n };\n}\nfunction create_out_transition(node, fn, params) {\n let config = fn(node, params);\n let running = true;\n let animation_name;\n const group = outros;\n group.r += 1;\n function go() {\n const { delay = 0, duration = 300, easing = identity, tick = noop, css } = config || null_transition;\n if (css)\n animation_name = create_rule(node, 1, 0, duration, delay, easing, css);\n const start_time = now() + delay;\n const end_time = start_time + duration;\n add_render_callback(() => dispatch(node, false, 'start'));\n loop(now => {\n if (running) {\n if (now >= end_time) {\n tick(0, 1);\n dispatch(node, false, 'end');\n if (!--group.r) {\n // this will result in `end()` being called,\n // so we don't need to clean up here\n run_all(group.c);\n }\n return false;\n }\n if (now >= start_time) {\n const t = easing((now - start_time) / duration);\n tick(1 - t, t);\n }\n }\n return running;\n });\n }\n if (is_function(config)) {\n wait().then(() => {\n // @ts-ignore\n config = config();\n go();\n });\n }\n else {\n go();\n }\n return {\n end(reset) {\n if (reset && config.tick) {\n config.tick(1, 0);\n }\n if (running) {\n if (animation_name)\n delete_rule(node, animation_name);\n running = false;\n }\n }\n };\n}\nfunction create_bidirectional_transition(node, fn, params, intro) {\n let config = fn(node, params);\n let t = intro ? 0 : 1;\n let running_program = null;\n let pending_program = null;\n let animation_name = null;\n function clear_animation() {\n if (animation_name)\n delete_rule(node, animation_name);\n }\n function init(program, duration) {\n const d = (program.b - t);\n duration *= Math.abs(d);\n return {\n a: t,\n b: program.b,\n d,\n duration,\n start: program.start,\n end: program.start + duration,\n group: program.group\n };\n }\n function go(b) {\n const { delay = 0, duration = 300, easing = identity, tick = noop, css } = config || null_transition;\n const program = {\n start: now() + delay,\n b\n };\n if (!b) {\n // @ts-ignore todo: improve typings\n program.group = outros;\n outros.r += 1;\n }\n if (running_program || pending_program) {\n pending_program = program;\n }\n else {\n // if this is an intro, and there's a delay, we need to do\n // an initial tick and/or apply CSS animation immediately\n if (css) {\n clear_animation();\n animation_name = create_rule(node, t, b, duration, delay, easing, css);\n }\n if (b)\n tick(0, 1);\n running_program = init(program, duration);\n add_render_callback(() => dispatch(node, b, 'start'));\n loop(now => {\n if (pending_program && now > pending_program.start) {\n running_program = init(pending_program, duration);\n pending_program = null;\n dispatch(node, running_program.b, 'start');\n if (css) {\n clear_animation();\n animation_name = create_rule(node, t, running_program.b, running_program.duration, 0, easing, config.css);\n }\n }\n if (running_program) {\n if (now >= running_program.end) {\n tick(t = running_program.b, 1 - t);\n dispatch(node, running_program.b, 'end');\n if (!pending_program) {\n // we're done\n if (running_program.b) {\n // intro — we can tidy up immediately\n clear_animation();\n }\n else {\n // outro — needs to be coordinated\n if (!--running_program.group.r)\n run_all(running_program.group.c);\n }\n }\n running_program = null;\n }\n else if (now >= running_program.start) {\n const p = now - running_program.start;\n t = running_program.a + running_program.d * easing(p / running_program.duration);\n tick(t, 1 - t);\n }\n }\n return !!(running_program || pending_program);\n });\n }\n }\n return {\n run(b) {\n if (is_function(config)) {\n wait().then(() => {\n // @ts-ignore\n config = config();\n go(b);\n });\n }\n else {\n go(b);\n }\n },\n end() {\n clear_animation();\n running_program = pending_program = null;\n }\n };\n}\n\nfunction handle_promise(promise, info) {\n const token = info.token = {};\n function update(type, index, key, value) {\n if (info.token !== token)\n return;\n info.resolved = value;\n let child_ctx = info.ctx;\n if (key !== undefined) {\n child_ctx = child_ctx.slice();\n child_ctx[key] = value;\n }\n const block = type && (info.current = type)(child_ctx);\n let needs_flush = false;\n if (info.block) {\n if (info.blocks) {\n info.blocks.forEach((block, i) => {\n if (i !== index && block) {\n group_outros();\n transition_out(block, 1, 1, () => {\n if (info.blocks[i] === block) {\n info.blocks[i] = null;\n }\n });\n check_outros();\n }\n });\n }\n else {\n info.block.d(1);\n }\n block.c();\n transition_in(block, 1);\n block.m(info.mount(), info.anchor);\n needs_flush = true;\n }\n info.block = block;\n if (info.blocks)\n info.blocks[index] = block;\n if (needs_flush) {\n flush();\n }\n }\n if (is_promise(promise)) {\n const current_component = get_current_component();\n promise.then(value => {\n set_current_component(current_component);\n update(info.then, 1, info.value, value);\n set_current_component(null);\n }, error => {\n set_current_component(current_component);\n update(info.catch, 2, info.error, error);\n set_current_component(null);\n if (!info.hasCatch) {\n throw error;\n }\n });\n // if we previously had a then/catch block, destroy it\n if (info.current !== info.pending) {\n update(info.pending, 0);\n return true;\n }\n }\n else {\n if (info.current !== info.then) {\n update(info.then, 1, info.value, promise);\n return true;\n }\n info.resolved = promise;\n }\n}\nfunction update_await_block_branch(info, ctx, dirty) {\n const child_ctx = ctx.slice();\n const { resolved } = info;\n if (info.current === info.then) {\n child_ctx[info.value] = resolved;\n }\n if (info.current === info.catch) {\n child_ctx[info.error] = resolved;\n }\n info.block.p(child_ctx, dirty);\n}\n\nconst globals = (typeof window !== 'undefined'\n ? window\n : typeof globalThis !== 'undefined'\n ? globalThis\n : global);\n\nfunction destroy_block(block, lookup) {\n block.d(1);\n lookup.delete(block.key);\n}\nfunction outro_and_destroy_block(block, lookup) {\n transition_out(block, 1, 1, () => {\n lookup.delete(block.key);\n });\n}\nfunction fix_and_destroy_block(block, lookup) {\n block.f();\n destroy_block(block, lookup);\n}\nfunction fix_and_outro_and_destroy_block(block, lookup) {\n block.f();\n outro_and_destroy_block(block, lookup);\n}\nfunction update_keyed_each(old_blocks, dirty, get_key, dynamic, ctx, list, lookup, node, destroy, create_each_block, next, get_context) {\n let o = old_blocks.length;\n let n = list.length;\n let i = o;\n const old_indexes = {};\n while (i--)\n old_indexes[old_blocks[i].key] = i;\n const new_blocks = [];\n const new_lookup = new Map();\n const deltas = new Map();\n i = n;\n while (i--) {\n const child_ctx = get_context(ctx, list, i);\n const key = get_key(child_ctx);\n let block = lookup.get(key);\n if (!block) {\n block = create_each_block(key, child_ctx);\n block.c();\n }\n else if (dynamic) {\n block.p(child_ctx, dirty);\n }\n new_lookup.set(key, new_blocks[i] = block);\n if (key in old_indexes)\n deltas.set(key, Math.abs(i - old_indexes[key]));\n }\n const will_move = new Set();\n const did_move = new Set();\n function insert(block) {\n transition_in(block, 1);\n block.m(node, next);\n lookup.set(block.key, block);\n next = block.first;\n n--;\n }\n while (o && n) {\n const new_block = new_blocks[n - 1];\n const old_block = old_blocks[o - 1];\n const new_key = new_block.key;\n const old_key = old_block.key;\n if (new_block === old_block) {\n // do nothing\n next = new_block.first;\n o--;\n n--;\n }\n else if (!new_lookup.has(old_key)) {\n // remove old block\n destroy(old_block, lookup);\n o--;\n }\n else if (!lookup.has(new_key) || will_move.has(new_key)) {\n insert(new_block);\n }\n else if (did_move.has(old_key)) {\n o--;\n }\n else if (deltas.get(new_key) > deltas.get(old_key)) {\n did_move.add(new_key);\n insert(new_block);\n }\n else {\n will_move.add(old_key);\n o--;\n }\n }\n while (o--) {\n const old_block = old_blocks[o];\n if (!new_lookup.has(old_block.key))\n destroy(old_block, lookup);\n }\n while (n)\n insert(new_blocks[n - 1]);\n return new_blocks;\n}\nfunction validate_each_keys(ctx, list, get_context, get_key) {\n const keys = new Set();\n for (let i = 0; i < list.length; i++) {\n const key = get_key(get_context(ctx, list, i));\n if (keys.has(key)) {\n throw new Error('Cannot have duplicate keys in a keyed each');\n }\n keys.add(key);\n }\n}\n\nfunction get_spread_update(levels, updates) {\n const update = {};\n const to_null_out = {};\n const accounted_for = { $$scope: 1 };\n let i = levels.length;\n while (i--) {\n const o = levels[i];\n const n = updates[i];\n if (n) {\n for (const key in o) {\n if (!(key in n))\n to_null_out[key] = 1;\n }\n for (const key in n) {\n if (!accounted_for[key]) {\n update[key] = n[key];\n accounted_for[key] = 1;\n }\n }\n levels[i] = n;\n }\n else {\n for (const key in o) {\n accounted_for[key] = 1;\n }\n }\n }\n for (const key in to_null_out) {\n if (!(key in update))\n update[key] = undefined;\n }\n return update;\n}\nfunction get_spread_object(spread_props) {\n return typeof spread_props === 'object' && spread_props !== null ? spread_props : {};\n}\n\n// source: https://html.spec.whatwg.org/multipage/indices.html\nconst boolean_attributes = new Set([\n 'allowfullscreen',\n 'allowpaymentrequest',\n 'async',\n 'autofocus',\n 'autoplay',\n 'checked',\n 'controls',\n 'default',\n 'defer',\n 'disabled',\n 'formnovalidate',\n 'hidden',\n 'ismap',\n 'loop',\n 'multiple',\n 'muted',\n 'nomodule',\n 'novalidate',\n 'open',\n 'playsinline',\n 'readonly',\n 'required',\n 'reversed',\n 'selected'\n]);\n\nconst void_element_names = /^(?:area|base|br|col|command|embed|hr|img|input|keygen|link|meta|param|source|track|wbr)$/;\nfunction is_void(name) {\n return void_element_names.test(name) || name.toLowerCase() === '!doctype';\n}\n\nconst invalid_attribute_name_character = /[\\s'\">/=\\u{FDD0}-\\u{FDEF}\\u{FFFE}\\u{FFFF}\\u{1FFFE}\\u{1FFFF}\\u{2FFFE}\\u{2FFFF}\\u{3FFFE}\\u{3FFFF}\\u{4FFFE}\\u{4FFFF}\\u{5FFFE}\\u{5FFFF}\\u{6FFFE}\\u{6FFFF}\\u{7FFFE}\\u{7FFFF}\\u{8FFFE}\\u{8FFFF}\\u{9FFFE}\\u{9FFFF}\\u{AFFFE}\\u{AFFFF}\\u{BFFFE}\\u{BFFFF}\\u{CFFFE}\\u{CFFFF}\\u{DFFFE}\\u{DFFFF}\\u{EFFFE}\\u{EFFFF}\\u{FFFFE}\\u{FFFFF}\\u{10FFFE}\\u{10FFFF}]/u;\n// https://html.spec.whatwg.org/multipage/syntax.html#attributes-2\n// https://infra.spec.whatwg.org/#noncharacter\nfunction spread(args, attrs_to_add) {\n const attributes = Object.assign({}, ...args);\n if (attrs_to_add) {\n const classes_to_add = attrs_to_add.classes;\n const styles_to_add = attrs_to_add.styles;\n if (classes_to_add) {\n if (attributes.class == null) {\n attributes.class = classes_to_add;\n }\n else {\n attributes.class += ' ' + classes_to_add;\n }\n }\n if (styles_to_add) {\n if (attributes.style == null) {\n attributes.style = style_object_to_string(styles_to_add);\n }\n else {\n attributes.style = style_object_to_string(merge_ssr_styles(attributes.style, styles_to_add));\n }\n }\n }\n let str = '';\n Object.keys(attributes).forEach(name => {\n if (invalid_attribute_name_character.test(name))\n return;\n const value = attributes[name];\n if (value === true)\n str += ' ' + name;\n else if (boolean_attributes.has(name.toLowerCase())) {\n if (value)\n str += ' ' + name;\n }\n else if (value != null) {\n str += ` ${name}=\"${value}\"`;\n }\n });\n return str;\n}\nfunction merge_ssr_styles(style_attribute, style_directive) {\n const style_object = {};\n for (const individual_style of style_attribute.split(';')) {\n const colon_index = individual_style.indexOf(':');\n const name = individual_style.slice(0, colon_index).trim();\n const value = individual_style.slice(colon_index + 1).trim();\n if (!name)\n continue;\n style_object[name] = value;\n }\n for (const name in style_directive) {\n const value = style_directive[name];\n if (value) {\n style_object[name] = value;\n }\n else {\n delete style_object[name];\n }\n }\n return style_object;\n}\nconst ATTR_REGEX = /[&\"]/g;\nconst CONTENT_REGEX = /[&<]/g;\n/**\n * Note: this method is performance sensitive and has been optimized\n * https://github.com/sveltejs/svelte/pull/5701\n */\nfunction escape(value, is_attr = false) {\n const str = String(value);\n const pattern = is_attr ? ATTR_REGEX : CONTENT_REGEX;\n pattern.lastIndex = 0;\n let escaped = '';\n let last = 0;\n while (pattern.test(str)) {\n const i = pattern.lastIndex - 1;\n const ch = str[i];\n escaped += str.substring(last, i) + (ch === '&' ? '&' : (ch === '\"' ? '"' : '<'));\n last = i + 1;\n }\n return escaped + str.substring(last);\n}\nfunction escape_attribute_value(value) {\n // keep booleans, null, and undefined for the sake of `spread`\n const should_escape = typeof value === 'string' || (value && typeof value === 'object');\n return should_escape ? escape(value, true) : value;\n}\nfunction escape_object(obj) {\n const result = {};\n for (const key in obj) {\n result[key] = escape_attribute_value(obj[key]);\n }\n return result;\n}\nfunction each(items, fn) {\n let str = '';\n for (let i = 0; i < items.length; i += 1) {\n str += fn(items[i], i);\n }\n return str;\n}\nconst missing_component = {\n $$render: () => ''\n};\nfunction validate_component(component, name) {\n if (!component || !component.$$render) {\n if (name === 'svelte:component')\n name += ' this={...}';\n throw new Error(`<${name}> is not a valid SSR component. You may need to review your build config to ensure that dependencies are compiled, rather than imported as pre-compiled modules`);\n }\n return component;\n}\nfunction debug(file, line, column, values) {\n console.log(`{@debug} ${file ? file + ' ' : ''}(${line}:${column})`); // eslint-disable-line no-console\n console.log(values); // eslint-disable-line no-console\n return '';\n}\nlet on_destroy;\nfunction create_ssr_component(fn) {\n function $$render(result, props, bindings, slots, context) {\n const parent_component = current_component;\n const $$ = {\n on_destroy,\n context: new Map(context || (parent_component ? parent_component.$$.context : [])),\n // these will be immediately discarded\n on_mount: [],\n before_update: [],\n after_update: [],\n callbacks: blank_object()\n };\n set_current_component({ $$ });\n const html = fn(result, props, bindings, slots);\n set_current_component(parent_component);\n return html;\n }\n return {\n render: (props = {}, { $$slots = {}, context = new Map() } = {}) => {\n on_destroy = [];\n const result = { title: '', head: '', css: new Set() };\n const html = $$render(result, props, {}, $$slots, context);\n run_all(on_destroy);\n return {\n html,\n css: {\n code: Array.from(result.css).map(css => css.code).join('\\n'),\n map: null // TODO\n },\n head: result.title + result.head\n };\n },\n $$render\n };\n}\nfunction add_attribute(name, value, boolean) {\n if (value == null || (boolean && !value))\n return '';\n const assignment = (boolean && value === true) ? '' : `=\"${escape(value, true)}\"`;\n return ` ${name}${assignment}`;\n}\nfunction add_classes(classes) {\n return classes ? ` class=\"${classes}\"` : '';\n}\nfunction style_object_to_string(style_object) {\n return Object.keys(style_object)\n .filter(key => style_object[key])\n .map(key => `${key}: ${style_object[key]};`)\n .join(' ');\n}\nfunction add_styles(style_object) {\n const styles = style_object_to_string(style_object);\n return styles ? ` style=\"${styles}\"` : '';\n}\n\nfunction bind(component, name, callback) {\n const index = component.$$.props[name];\n if (index !== undefined) {\n component.$$.bound[index] = callback;\n callback(component.$$.ctx[index]);\n }\n}\nfunction create_component(block) {\n block && block.c();\n}\nfunction claim_component(block, parent_nodes) {\n block && block.l(parent_nodes);\n}\nfunction mount_component(component, target, anchor, customElement) {\n const { fragment, on_mount, on_destroy, after_update } = component.$$;\n fragment && fragment.m(target, anchor);\n if (!customElement) {\n // onMount happens before the initial afterUpdate\n add_render_callback(() => {\n const new_on_destroy = on_mount.map(run).filter(is_function);\n if (on_destroy) {\n on_destroy.push(...new_on_destroy);\n }\n else {\n // Edge case - component was destroyed immediately,\n // most likely as a result of a binding initialising\n run_all(new_on_destroy);\n }\n component.$$.on_mount = [];\n });\n }\n after_update.forEach(add_render_callback);\n}\nfunction destroy_component(component, detaching) {\n const $$ = component.$$;\n if ($$.fragment !== null) {\n run_all($$.on_destroy);\n $$.fragment && $$.fragment.d(detaching);\n // TODO null out other refs, including component.$$ (but need to\n // preserve final state?)\n $$.on_destroy = $$.fragment = null;\n $$.ctx = [];\n }\n}\nfunction make_dirty(component, i) {\n if (component.$$.dirty[0] === -1) {\n dirty_components.push(component);\n schedule_update();\n component.$$.dirty.fill(0);\n }\n component.$$.dirty[(i / 31) | 0] |= (1 << (i % 31));\n}\nfunction init(component, options, instance, create_fragment, not_equal, props, append_styles, dirty = [-1]) {\n const parent_component = current_component;\n set_current_component(component);\n const $$ = component.$$ = {\n fragment: null,\n ctx: null,\n // state\n props,\n update: noop,\n not_equal,\n bound: blank_object(),\n // lifecycle\n on_mount: [],\n on_destroy: [],\n on_disconnect: [],\n before_update: [],\n after_update: [],\n context: new Map(options.context || (parent_component ? parent_component.$$.context : [])),\n // everything else\n callbacks: blank_object(),\n dirty,\n skip_bound: false,\n root: options.target || parent_component.$$.root\n };\n append_styles && append_styles($$.root);\n let ready = false;\n $$.ctx = instance\n ? instance(component, options.props || {}, (i, ret, ...rest) => {\n const value = rest.length ? rest[0] : ret;\n if ($$.ctx && not_equal($$.ctx[i], $$.ctx[i] = value)) {\n if (!$$.skip_bound && $$.bound[i])\n $$.bound[i](value);\n if (ready)\n make_dirty(component, i);\n }\n return ret;\n })\n : [];\n $$.update();\n ready = true;\n run_all($$.before_update);\n // `false` as a special case of no DOM component\n $$.fragment = create_fragment ? create_fragment($$.ctx) : false;\n if (options.target) {\n if (options.hydrate) {\n start_hydrating();\n const nodes = children(options.target);\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n $$.fragment && $$.fragment.l(nodes);\n nodes.forEach(detach);\n }\n else {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n $$.fragment && $$.fragment.c();\n }\n if (options.intro)\n transition_in(component.$$.fragment);\n mount_component(component, options.target, options.anchor, options.customElement);\n end_hydrating();\n flush();\n }\n set_current_component(parent_component);\n}\nlet SvelteElement;\nif (typeof HTMLElement === 'function') {\n SvelteElement = class extends HTMLElement {\n constructor() {\n super();\n this.attachShadow({ mode: 'open' });\n }\n connectedCallback() {\n const { on_mount } = this.$$;\n this.$$.on_disconnect = on_mount.map(run).filter(is_function);\n // @ts-ignore todo: improve typings\n for (const key in this.$$.slotted) {\n // @ts-ignore todo: improve typings\n this.appendChild(this.$$.slotted[key]);\n }\n }\n attributeChangedCallback(attr, _oldValue, newValue) {\n this[attr] = newValue;\n }\n disconnectedCallback() {\n run_all(this.$$.on_disconnect);\n }\n $destroy() {\n destroy_component(this, 1);\n this.$destroy = noop;\n }\n $on(type, callback) {\n // TODO should this delegate to addEventListener?\n const callbacks = (this.$$.callbacks[type] || (this.$$.callbacks[type] = []));\n callbacks.push(callback);\n return () => {\n const index = callbacks.indexOf(callback);\n if (index !== -1)\n callbacks.splice(index, 1);\n };\n }\n $set($$props) {\n if (this.$$set && !is_empty($$props)) {\n this.$$.skip_bound = true;\n this.$$set($$props);\n this.$$.skip_bound = false;\n }\n }\n };\n}\n/**\n * Base class for Svelte components. Used when dev=false.\n */\nclass SvelteComponent {\n $destroy() {\n destroy_component(this, 1);\n this.$destroy = noop;\n }\n $on(type, callback) {\n const callbacks = (this.$$.callbacks[type] || (this.$$.callbacks[type] = []));\n callbacks.push(callback);\n return () => {\n const index = callbacks.indexOf(callback);\n if (index !== -1)\n callbacks.splice(index, 1);\n };\n }\n $set($$props) {\n if (this.$$set && !is_empty($$props)) {\n this.$$.skip_bound = true;\n this.$$set($$props);\n this.$$.skip_bound = false;\n }\n }\n}\n\nfunction dispatch_dev(type, detail) {\n document.dispatchEvent(custom_event(type, Object.assign({ version: '3.49.0' }, detail), { bubbles: true }));\n}\nfunction append_dev(target, node) {\n dispatch_dev('SvelteDOMInsert', { target, node });\n append(target, node);\n}\nfunction append_hydration_dev(target, node) {\n dispatch_dev('SvelteDOMInsert', { target, node });\n append_hydration(target, node);\n}\nfunction insert_dev(target, node, anchor) {\n dispatch_dev('SvelteDOMInsert', { target, node, anchor });\n insert(target, node, anchor);\n}\nfunction insert_hydration_dev(target, node, anchor) {\n dispatch_dev('SvelteDOMInsert', { target, node, anchor });\n insert_hydration(target, node, anchor);\n}\nfunction detach_dev(node) {\n dispatch_dev('SvelteDOMRemove', { node });\n detach(node);\n}\nfunction detach_between_dev(before, after) {\n while (before.nextSibling && before.nextSibling !== after) {\n detach_dev(before.nextSibling);\n }\n}\nfunction detach_before_dev(after) {\n while (after.previousSibling) {\n detach_dev(after.previousSibling);\n }\n}\nfunction detach_after_dev(before) {\n while (before.nextSibling) {\n detach_dev(before.nextSibling);\n }\n}\nfunction listen_dev(node, event, handler, options, has_prevent_default, has_stop_propagation) {\n const modifiers = options === true ? ['capture'] : options ? Array.from(Object.keys(options)) : [];\n if (has_prevent_default)\n modifiers.push('preventDefault');\n if (has_stop_propagation)\n modifiers.push('stopPropagation');\n dispatch_dev('SvelteDOMAddEventListener', { node, event, handler, modifiers });\n const dispose = listen(node, event, handler, options);\n return () => {\n dispatch_dev('SvelteDOMRemoveEventListener', { node, event, handler, modifiers });\n dispose();\n };\n}\nfunction attr_dev(node, attribute, value) {\n attr(node, attribute, value);\n if (value == null)\n dispatch_dev('SvelteDOMRemoveAttribute', { node, attribute });\n else\n dispatch_dev('SvelteDOMSetAttribute', { node, attribute, value });\n}\nfunction prop_dev(node, property, value) {\n node[property] = value;\n dispatch_dev('SvelteDOMSetProperty', { node, property, value });\n}\nfunction dataset_dev(node, property, value) {\n node.dataset[property] = value;\n dispatch_dev('SvelteDOMSetDataset', { node, property, value });\n}\nfunction set_data_dev(text, data) {\n data = '' + data;\n if (text.wholeText === data)\n return;\n dispatch_dev('SvelteDOMSetData', { node: text, data });\n text.data = data;\n}\nfunction validate_each_argument(arg) {\n if (typeof arg !== 'string' && !(arg && typeof arg === 'object' && 'length' in arg)) {\n let msg = '{#each} only iterates over array-like objects.';\n if (typeof Symbol === 'function' && arg && Symbol.iterator in arg) {\n msg += ' You can use a spread to convert this iterable into an array.';\n }\n throw new Error(msg);\n }\n}\nfunction validate_slots(name, slot, keys) {\n for (const slot_key of Object.keys(slot)) {\n if (!~keys.indexOf(slot_key)) {\n console.warn(`<${name}> received an unexpected slot \"${slot_key}\".`);\n }\n }\n}\nfunction validate_dynamic_element(tag) {\n const is_string = typeof tag === 'string';\n if (tag && !is_string) {\n throw new Error(' expects \"this\" attribute to be a string.');\n }\n}\nfunction validate_void_dynamic_element(tag) {\n if (tag && is_void(tag)) {\n throw new Error(` is self-closing and cannot have content.`);\n }\n}\n/**\n * Base class for Svelte components with some minor dev-enhancements. Used when dev=true.\n */\nclass SvelteComponentDev extends SvelteComponent {\n constructor(options) {\n if (!options || (!options.target && !options.$$inline)) {\n throw new Error(\"'target' is a required option\");\n }\n super();\n }\n $destroy() {\n super.$destroy();\n this.$destroy = () => {\n console.warn('Component was already destroyed'); // eslint-disable-line no-console\n };\n }\n $capture_state() { }\n $inject_state() { }\n}\n/**\n * Base class to create strongly typed Svelte components.\n * This only exists for typing purposes and should be used in `.d.ts` files.\n *\n * ### Example:\n *\n * You have component library on npm called `component-library`, from which\n * you export a component called `MyComponent`. For Svelte+TypeScript users,\n * you want to provide typings. Therefore you create a `index.d.ts`:\n * ```ts\n * import { SvelteComponentTyped } from \"svelte\";\n * export class MyComponent extends SvelteComponentTyped<{foo: string}> {}\n * ```\n * Typing this makes it possible for IDEs like VS Code with the Svelte extension\n * to provide intellisense and to use the component like this in a Svelte file\n * with TypeScript:\n * ```svelte\n * \n * \n * ```\n *\n * #### Why not make this part of `SvelteComponent(Dev)`?\n * Because\n * ```ts\n * class ASubclassOfSvelteComponent extends SvelteComponent<{foo: string}> {}\n * const component: typeof SvelteComponent = ASubclassOfSvelteComponent;\n * ```\n * will throw a type error, so we need to separate the more strictly typed class.\n */\nclass SvelteComponentTyped extends SvelteComponentDev {\n constructor(options) {\n super(options);\n }\n}\nfunction loop_guard(timeout) {\n const start = Date.now();\n return () => {\n if (Date.now() - start > timeout) {\n throw new Error('Infinite loop detected');\n }\n };\n}\n\nexport { HtmlTag, HtmlTagHydration, SvelteComponent, SvelteComponentDev, SvelteComponentTyped, SvelteElement, action_destroyer, add_attribute, add_classes, add_flush_callback, add_location, add_render_callback, add_resize_listener, add_styles, add_transform, afterUpdate, append, append_dev, append_empty_stylesheet, append_hydration, append_hydration_dev, append_styles, assign, attr, attr_dev, attribute_to_object, beforeUpdate, bind, binding_callbacks, blank_object, bubble, check_outros, children, claim_component, claim_element, claim_html_tag, claim_space, claim_svg_element, claim_text, clear_loops, component_subscribe, compute_rest_props, compute_slots, createEventDispatcher, create_animation, create_bidirectional_transition, create_component, create_in_transition, create_out_transition, create_slot, create_ssr_component, current_component, custom_event, dataset_dev, debug, destroy_block, destroy_component, destroy_each, detach, detach_after_dev, detach_before_dev, detach_between_dev, detach_dev, dirty_components, dispatch_dev, each, element, element_is, empty, end_hydrating, escape, escape_attribute_value, escape_object, exclude_internal_props, fix_and_destroy_block, fix_and_outro_and_destroy_block, fix_position, flush, getAllContexts, getContext, get_all_dirty_from_scope, get_binding_group_value, get_current_component, get_custom_elements_slots, get_root_for_style, get_slot_changes, get_spread_object, get_spread_update, get_store_value, globals, group_outros, handle_promise, hasContext, has_prop, identity, init, insert, insert_dev, insert_hydration, insert_hydration_dev, intros, invalid_attribute_name_character, is_client, is_crossorigin, is_empty, is_function, is_promise, is_void, listen, listen_dev, loop, loop_guard, merge_ssr_styles, missing_component, mount_component, noop, not_equal, now, null_to_empty, object_without_properties, onDestroy, onMount, once, outro_and_destroy_block, prevent_default, prop_dev, query_selector_all, raf, run, run_all, safe_not_equal, schedule_update, select_multiple_value, select_option, select_options, select_value, self, setContext, set_attributes, set_current_component, set_custom_element_data, set_data, set_data_dev, set_input_type, set_input_value, set_now, set_raf, set_store_value, set_style, set_svg_attributes, space, spread, src_url_equal, start_hydrating, stop_propagation, subscribe, svg_element, text, tick, time_ranges_to_array, to_number, toggle_class, transition_in, transition_out, trusted, update_await_block_branch, update_keyed_each, update_slot, update_slot_base, validate_component, validate_dynamic_element, validate_each_argument, validate_each_keys, validate_slots, validate_store, validate_void_dynamic_element, xlink_attr };\n","import { noop, safe_not_equal, subscribe, run_all, is_function } from '../internal/index.mjs';\nexport { get_store_value as get } from '../internal/index.mjs';\n\nconst subscriber_queue = [];\n/**\n * Creates a `Readable` store that allows reading by subscription.\n * @param value initial value\n * @param {StartStopNotifier}start start and stop notifications for subscriptions\n */\nfunction readable(value, start) {\n return {\n subscribe: writable(value, start).subscribe\n };\n}\n/**\n * Create a `Writable` store that allows both updating and reading by subscription.\n * @param {*=}value initial value\n * @param {StartStopNotifier=}start start and stop notifications for subscriptions\n */\nfunction writable(value, start = noop) {\n let stop;\n const subscribers = new Set();\n function set(new_value) {\n if (safe_not_equal(value, new_value)) {\n value = new_value;\n if (stop) { // store is ready\n const run_queue = !subscriber_queue.length;\n for (const subscriber of subscribers) {\n subscriber[1]();\n subscriber_queue.push(subscriber, value);\n }\n if (run_queue) {\n for (let i = 0; i < subscriber_queue.length; i += 2) {\n subscriber_queue[i][0](subscriber_queue[i + 1]);\n }\n subscriber_queue.length = 0;\n }\n }\n }\n }\n function update(fn) {\n set(fn(value));\n }\n function subscribe(run, invalidate = noop) {\n const subscriber = [run, invalidate];\n subscribers.add(subscriber);\n if (subscribers.size === 1) {\n stop = start(set) || noop;\n }\n run(value);\n return () => {\n subscribers.delete(subscriber);\n if (subscribers.size === 0) {\n stop();\n stop = null;\n }\n };\n }\n return { set, update, subscribe };\n}\nfunction derived(stores, fn, initial_value) {\n const single = !Array.isArray(stores);\n const stores_array = single\n ? [stores]\n : stores;\n const auto = fn.length < 2;\n return readable(initial_value, (set) => {\n let inited = false;\n const values = [];\n let pending = 0;\n let cleanup = noop;\n const sync = () => {\n if (pending) {\n return;\n }\n cleanup();\n const result = fn(single ? values[0] : values, set);\n if (auto) {\n set(result);\n }\n else {\n cleanup = is_function(result) ? result : noop;\n }\n };\n const unsubscribers = stores_array.map((store, i) => subscribe(store, (value) => {\n values[i] = value;\n pending &= ~(1 << i);\n if (inited) {\n sync();\n }\n }, () => {\n pending |= (1 << i);\n }));\n inited = true;\n sync();\n return function stop() {\n run_all(unsubscribers);\n cleanup();\n };\n });\n}\n\nexport { derived, readable, writable };\n","/**\n * Does the current object have different keys or values compared to the previous version?\n *\n * @param {object} previous\n * @param {object} current\n *\n * @returns {boolean}\n */\nexport function objectsDiffer( [previous, current] ) {\n\tif ( !previous || !current ) {\n\t\treturn false;\n\t}\n\n\t// Any difference in keys?\n\tconst prevKeys = Object.keys( previous );\n\tconst currKeys = Object.keys( current );\n\n\tif ( prevKeys.length !== currKeys.length ) {\n\t\treturn true;\n\t}\n\n\t// Symmetrical diff to find extra keys in either object.\n\tif (\n\t\tprevKeys.filter( x => !currKeys.includes( x ) )\n\t\t\t.concat(\n\t\t\t\tcurrKeys.filter( x => !prevKeys.includes( x ) )\n\t\t\t)\n\t\t\t.length > 0\n\t) {\n\t\treturn true;\n\t}\n\n\t// Any difference in values?\n\tfor ( const key in previous ) {\n\t\tif ( JSON.stringify( current[ key ] ) !== JSON.stringify( previous[ key ] ) ) {\n\t\t\treturn true;\n\t\t}\n\t}\n\n\treturn false;\n}\n","import {derived, writable, get, readable} from \"svelte/store\";\nimport {objectsDiffer} from \"./objectsDiffer\";\n\n// Initial config store.\nexport const config = writable( {} );\n\n// Whether settings are locked due to background activity such as upgrade.\nexport const settingsLocked = writable( false );\n\n// Convenience readable store of server's settings, derived from config.\nexport const current_settings = derived( config, $config => $config.settings );\n\n// Convenience readable store of defined settings keys, derived from config.\nexport const defined_settings = derived( config, $config => $config.defined_settings );\n\n// Convenience readable store of translated strings, derived from config.\nexport const strings = derived( config, $config => $config.strings );\n\n// Convenience readable store for nonce, derived from config.\nexport const nonce = derived( config, $config => $config.nonce );\n\n// Convenience readable store of urls, derived from config.\nexport const urls = derived( config, $config => $config.urls );\n\n// Convenience readable store of docs, derived from config.\nexport const docs = derived( config, $config => $config.docs );\n\n// Convenience readable store of api endpoints, derived from config.\nexport const endpoints = derived( config, $config => $config.endpoints );\n\n// Convenience readable store of diagnostics, derived from config.\nexport const diagnostics = derived( config, $config => $config.diagnostics );\n\n// Convenience readable store of counts, derived from config.\nexport const counts = derived( config, $config => $config.counts );\n\n// Convenience readable store of upgrades, derived from config.\nexport const upgrades = derived( config, $config => $config.upgrades );\n\n// Convenience readable store of whether plugin is set up, derived from config.\nexport const is_plugin_setup = derived( config, $config => $config.is_plugin_setup );\n\n// Convenience readable store of whether plugin is set up, including with credentials, derived from config.\nexport const is_plugin_setup_with_credentials = derived( config, $config => $config.is_plugin_setup_with_credentials );\n\n// Convenience readable store of whether storage provider needs access credentials, derived from config.\nexport const needs_access_keys = derived( config, $config => $config.needs_access_keys );\n\n// Convenience readable store of whether bucket is writable, derived from config.\nexport const bucket_writable = derived( config, $config => $config.bucket_writable );\n\n// Store of inline errors and warnings to be shown next to settings.\n// Format is a map using settings key for keys, values are an array of objects that can be used to instantiate a notification.\nexport const settings_notifications = writable( new Map() );\n\n// Store of validation errors for settings.\n// Format is a map using settings key for keys, values are strings containing validation error.\nexport const validationErrors = writable( new Map() );\n\n// Does the app need a page refresh to resolve conflicts?\nexport const needs_refresh = writable( false );\n\n// Various stores may call the API, and the api object uses some stores.\n// To avoid cyclic dependencies, we therefore co-locate the api object with the stores.\n// We also need to add its functions much later so that JSHint does not complain about using the stores too early.\nexport const api = {};\n\n/**\n * Creates store of settings.\n *\n * @return {Object}\n */\nfunction createSettings() {\n\tconst { subscribe, set, update } = writable( [] );\n\n\treturn {\n\t\tsubscribe,\n\t\tset,\n\t\tasync save() {\n\t\t\tconst json = await api.put( \"settings\", get( this ) );\n\n\t\t\tif ( json.hasOwnProperty( \"saved\" ) && true === json.saved ) {\n\t\t\t\t// Sync settings with what the server has.\n\t\t\t\tthis.updateSettings( json );\n\n\t\t\t\treturn json;\n\t\t\t}\n\n\t\t\treturn {};\n\t\t},\n\t\treset() {\n\t\t\tset( { ...get( current_settings ) } );\n\t\t},\n\t\tasync fetch() {\n\t\t\tconst json = await api.get( \"settings\", {} );\n\t\t\tthis.updateSettings( json );\n\t\t},\n\t\tupdateSettings( json ) {\n\t\t\tif (\n\t\t\t\tjson.hasOwnProperty( \"defined_settings\" ) &&\n\t\t\t\tjson.hasOwnProperty( \"settings\" ) &&\n\t\t\t\tjson.hasOwnProperty( \"storage_providers\" ) &&\n\t\t\t\tjson.hasOwnProperty( \"delivery_providers\" ) &&\n\t\t\t\tjson.hasOwnProperty( \"is_plugin_setup\" ) &&\n\t\t\t\tjson.hasOwnProperty( \"is_plugin_setup_with_credentials\" ) &&\n\t\t\t\tjson.hasOwnProperty( \"needs_access_keys\" ) &&\n\t\t\t\tjson.hasOwnProperty( \"bucket_writable\" ) &&\n\t\t\t\tjson.hasOwnProperty( \"urls\" )\n\t\t\t) {\n\t\t\t\t// Update our understanding of what the server's settings are.\n\t\t\t\tconfig.update( $config => {\n\t\t\t\t\treturn {\n\t\t\t\t\t\t...$config,\n\t\t\t\t\t\tdefined_settings: json.defined_settings,\n\t\t\t\t\t\tsettings: json.settings,\n\t\t\t\t\t\tstorage_providers: json.storage_providers,\n\t\t\t\t\t\tdelivery_providers: json.delivery_providers,\n\t\t\t\t\t\tis_plugin_setup: json.is_plugin_setup,\n\t\t\t\t\t\tis_plugin_setup_with_credentials: json.is_plugin_setup_with_credentials,\n\t\t\t\t\t\tneeds_access_keys: json.needs_access_keys,\n\t\t\t\t\t\tbucket_writable: json.bucket_writable,\n\t\t\t\t\t\turls: json.urls\n\t\t\t\t\t};\n\t\t\t\t} );\n\t\t\t\t// Update our local working copy of the settings.\n\t\t\t\tupdate( $settings => {\n\t\t\t\t\treturn { ...json.settings };\n\t\t\t\t} );\n\t\t\t}\n\t\t}\n\t};\n}\n\nexport const settings = createSettings();\n\n// Have the settings been changed from current server side settings?\nexport const settings_changed = derived( [settings, current_settings], objectsDiffer );\n\n// Convenience readable store of available storage providers.\nexport const storage_providers = derived( [config, urls], ( [$config, $urls] ) => {\n\tfor ( const key in $config.storage_providers ) {\n\t\t$config.storage_providers[ key ].icon = $urls.assets + \"img/icon/provider/storage/\" + $config.storage_providers[ key ].provider_key_name + \".svg\";\n\t\t$config.storage_providers[ key ].link_icon = $urls.assets + \"img/icon/provider/storage/\" + $config.storage_providers[ key ].provider_key_name + \"-link.svg\";\n\t\t$config.storage_providers[ key ].round_icon = $urls.assets + \"img/icon/provider/storage/\" + $config.storage_providers[ key ].provider_key_name + \"-round.svg\";\n\t}\n\n\treturn $config.storage_providers;\n} );\n\n// Convenience readable store of storage provider's details.\nexport const storage_provider = derived( [settings, storage_providers], ( [$settings, $storage_providers] ) => {\n\tif ( $settings.hasOwnProperty( \"provider\" ) && $storage_providers.hasOwnProperty( $settings.provider ) ) {\n\t\treturn $storage_providers[ $settings.provider ];\n\t} else {\n\t\treturn [];\n\t}\n} );\n\n// Convenience readable store of available delivery providers.\nexport const delivery_providers = derived( [config, urls, storage_provider], ( [$config, $urls, $storage_provider] ) => {\n\tfor ( const key in $config.delivery_providers ) {\n\t\tif ( \"storage\" === key ) {\n\t\t\t$config.delivery_providers[ key ].icon = $storage_provider.icon;\n\t\t\t$config.delivery_providers[ key ].round_icon = $storage_provider.round_icon;\n\t\t\t$config.delivery_providers[ key ].provider_service_quick_start_url = $storage_provider.provider_service_quick_start_url;\n\t\t} else {\n\t\t\t$config.delivery_providers[ key ].icon = $urls.assets + \"img/icon/provider/delivery/\" + $config.delivery_providers[ key ].provider_key_name + \".svg\";\n\t\t\t$config.delivery_providers[ key ].round_icon = $urls.assets + \"img/icon/provider/delivery/\" + $config.delivery_providers[ key ].provider_key_name + \"-round.svg\";\n\t\t}\n\t}\n\n\treturn $config.delivery_providers;\n} );\n\n// Convenience readable store of delivery provider's details.\nexport const delivery_provider = derived( [settings, delivery_providers, urls], ( [$settings, $delivery_providers, $urls] ) => {\n\tif ( $settings.hasOwnProperty( \"delivery-provider\" ) && $delivery_providers.hasOwnProperty( $settings[ \"delivery-provider\" ] ) ) {\n\t\treturn $delivery_providers[ $settings[ \"delivery-provider\" ] ];\n\t} else {\n\t\treturn [];\n\t}\n} );\n\n// Full name for current region.\nexport const region_name = derived( [settings, storage_provider, strings], ( [$settings, $storage_provider, $strings] ) => {\n\tif ( $settings.region && $storage_provider.regions && $storage_provider.regions.hasOwnProperty( $settings.region ) ) {\n\t\treturn $storage_provider.regions[ $settings.region ];\n\t} else if ( $settings.region && $storage_provider.regions ) {\n\t\t// Region set but not available in list of regions.\n\t\treturn $strings.unknown;\n\t} else if ( $storage_provider.default_region && $storage_provider.regions && $storage_provider.regions.hasOwnProperty( $storage_provider.default_region ) ) {\n\t\t// Region not set but default available.\n\t\treturn $storage_provider.regions[ $storage_provider.default_region ];\n\t} else {\n\t\t// Possibly no default region or regions available.\n\t\treturn $strings.unknown;\n\t}\n} );\n\n// Convenience readable store of whether Block All Public Access is enabled.\nexport const bapa = derived( [settings, storage_provider], ( [$settings, $storage_provider] ) => {\n\treturn $storage_provider.block_public_access_supported && $settings.hasOwnProperty( \"block-public-access\" ) && $settings[ \"block-public-access\" ];\n} );\n\n// Convenience readable store of whether Object Ownership is enforced.\nexport const ooe = derived( [settings, storage_provider], ( [$settings, $storage_provider] ) => {\n\treturn $storage_provider.object_ownership_supported && $settings.hasOwnProperty( \"object-ownership-enforced\" ) && $settings[ \"object-ownership-enforced\" ];\n} );\n\n/**\n * Creates a store of notifications.\n *\n * Example object in the array:\n * {\n * \tid: \"error-message\",\n * \ttype: \"error\", // error | warning | success | primary (default)\n * \tdismissible: true,\n * \tflash: true, // Optional, means notification is context specific and will not persist on server, defaults to true.\n * \tinline: false, // Optional, unlikely to be true, included here for completeness.\n * \tonly_show_on_tab: \"media-library\", // Optional, blank/missing means on all tabs.\n * \theading: \"Global Error: Something has gone terribly pear shaped.\", // Optional.\n * \tmessage: \"We're so sorry, but unfortunately we're going to have to delete the year 2020.\", // Optional.\n * \ticon: \"notification-error.svg\", // Optional icon file name to be shown in front of heading.\n * \tplainHeading: false, // Optional boolean as to whether a

tag should be used instead of

for heading content.\n * \textra: \"\", // Optional extra content to be shown in paragraph below message.\n * \tlinks: [], // Optional list of links to be shown at bottom of notice.\n * },\n *\n * @return {Object}\n */\nfunction createNotifications() {\n\tconst { subscribe, set, update } = writable( [] );\n\n\treturn {\n\t\tset,\n\t\tsubscribe,\n\t\tadd( notification ) {\n\t\t\t// There's a slight difference between our notification's formatting and what WP uses.\n\t\t\tif ( notification.hasOwnProperty( \"type\" ) && notification.type === \"updated\" ) {\n\t\t\t\tnotification.type = \"success\";\n\t\t\t}\n\t\t\tif ( notification.hasOwnProperty( \"type\" ) && notification.type === \"notice-warning\" ) {\n\t\t\t\tnotification.type = \"warning\";\n\t\t\t}\n\t\t\tif ( notification.hasOwnProperty( \"type\" ) && notification.type === \"notice-info\" ) {\n\t\t\t\tnotification.type = \"info\";\n\t\t\t}\n\t\t\tif (\n\t\t\t\tnotification.hasOwnProperty( \"message\" ) &&\n\t\t\t\t(!notification.hasOwnProperty( \"heading\" ) || notification.heading.trim().length === 0)\n\t\t\t) {\n\t\t\t\tnotification.heading = notification.message;\n\t\t\t\tnotification.plainHeading = true;\n\t\t\t\tdelete notification.message;\n\t\t\t}\n\t\t\tif ( !notification.hasOwnProperty( \"flash\" ) ) {\n\t\t\t\tnotification.flash = true;\n\t\t\t}\n\n\t\t\t// We need some sort of id for indexing and to ensure rendering is efficient.\n\t\t\tif ( !notification.hasOwnProperty( \"id\" ) ) {\n\t\t\t\t// Notifications are useless without at least a heading or message, so we can be sure at least one exists.\n\t\t\t\tconst idHeading = notification.hasOwnProperty( \"heading\" ) ? notification.heading.trim() : \"dynamic-heading\";\n\t\t\t\tconst idMessage = notification.hasOwnProperty( \"message\" ) ? notification.message.trim() : \"dynamic-message\";\n\n\t\t\t\tnotification.id = btoa( idHeading + idMessage );\n\t\t\t}\n\n\t\t\t// So that rendering is efficient, but updates displayed notifications that re-use keys,\n\t\t\t// we create a render_key based on id and created_at as created_at is churned on re-use.\n\t\t\tconst createdAt = notification.hasOwnProperty( \"created_at\" ) ? notification.created_at : 0;\n\t\t\tnotification.render_key = notification.id + \"-\" + createdAt;\n\n\t\t\tupdate( $notifications => {\n\t\t\t\t// Maybe update a notification if id already exists.\n\t\t\t\tlet index = -1;\n\t\t\t\tif ( notification.hasOwnProperty( \"id\" ) ) {\n\t\t\t\t\tindex = $notifications.findIndex( _notification => _notification.id === notification.id );\n\t\t\t\t}\n\n\t\t\t\tif ( index >= 0 ) {\n\t\t\t\t\t// If the id exists but has been dismissed, add the replacement notification to the end of the array\n\t\t\t\t\t// if given notification is newer, otherwise skip it entirely.\n\t\t\t\t\tif ( $notifications[ index ].hasOwnProperty( \"dismissed\" ) ) {\n\t\t\t\t\t\tif ( $notifications[ index ].dismissed < notification.created_at ) {\n\t\t\t\t\t\t\t$notifications.push( notification );\n\t\t\t\t\t\t\t$notifications.splice( index, 1 );\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// Update existing.\n\t\t\t\t\t\t$notifications.splice( index, 1, notification );\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t// Add new.\n\t\t\t\t\t$notifications.push( notification );\n\t\t\t\t}\n\n\t\t\t\treturn $notifications.sort( this.sortCompare );\n\t\t\t} );\n\t\t},\n\t\tsortCompare( a, b ) {\n\t\t\t// Sort by created_at in case an existing notification was updated.\n\t\t\tif ( a.created_at < b.created_at ) {\n\t\t\t\treturn -1;\n\t\t\t}\n\n\t\t\tif ( a.created_at > b.created_at ) {\n\t\t\t\treturn 1;\n\t\t\t}\n\n\t\t\treturn 0;\n\t\t},\n\t\tasync dismiss( id ) {\n\t\t\tupdate( $notifications => {\n\t\t\t\tconst index = $notifications.findIndex( notification => notification.id === id );\n\n\t\t\t\t// If the notification still exists, set a \"dismissed\" tombstone with the created_at value.\n\t\t\t\t// The cleanup will delete any notifications that have been dismissed and no longer exist\n\t\t\t\t// in the list of notifications retrieved from the server.\n\t\t\t\t// The created_at value ensures that if a notification is retrieved from the server that\n\t\t\t\t// has the same id but later created_at, then it can be added, otherwise it is skipped.\n\t\t\t\tif ( index >= 0 ) {\n\t\t\t\t\tif ( $notifications[ index ].hasOwnProperty( \"created_at\" ) ) {\n\t\t\t\t\t\t$notifications[ index ].dismissed = $notifications[ index ].created_at;\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// Notification likely did not come from server, maybe a local \"flash\" notification.\n\t\t\t\t\t\t$notifications.splice( index, 1 );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn $notifications;\n\t\t\t} );\n\n\t\t\t// Tell server to dismiss notification, still ok to try if flash notification, makes sure it is definitely removed.\n\t\t\tawait api.delete( \"notifications\", { id: id, all_tabs: true } );\n\t\t},\n\t\t/**\n\t\t * Delete removes a notification from the UI without telling the server.\n\t\t */\n\t\tdelete( id ) {\n\t\t\tupdate( $notifications => {\n\t\t\t\tconst index = $notifications.findIndex( notification => notification.id === id );\n\n\t\t\t\tif ( index >= 0 ) {\n\t\t\t\t\t$notifications.splice( index, 1 );\n\t\t\t\t}\n\n\t\t\t\treturn $notifications;\n\t\t\t} );\n\t\t},\n\t\tcleanup( latest ) {\n\t\t\tupdate( $notifications => {\n\t\t\t\tfor ( const [index, notification] of $notifications.entries() ) {\n\t\t\t\t\t// Only clean up dismissed or server created notices that no longer exist.\n\t\t\t\t\tif ( notification.hasOwnProperty( \"dismissed\" ) || notification.hasOwnProperty( \"created_at\" ) ) {\n\t\t\t\t\t\tconst latestIndex = latest.findIndex( _notification => _notification.id === notification.id );\n\n\t\t\t\t\t\t// If server doesn't know about the notification anymore, remove it.\n\t\t\t\t\t\tif ( latestIndex < 0 ) {\n\t\t\t\t\t\t\t$notifications.splice( index, 1 );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn $notifications;\n\t\t\t} );\n\t\t}\n\t};\n}\n\nexport const notifications = createNotifications();\n\n// Controller for periodic fetch of state info.\nlet stateFetchInterval;\nlet stateFetchIntervalStarted = false;\nlet stateFetchIntervalPaused = false;\n\n// Store of functions to call before an update of state processes the result into config.\nexport const preStateUpdateCallbacks = writable( [] );\n\n// Store of functions to call after an update of state processes the result into config.\nexport const postStateUpdateCallbacks = writable( [] );\n\n/**\n * Store of functions to call when state info is updated, and actual API access methods.\n *\n * Functions are called after the returned state info has been used to update the config store.\n * Therefore, functions should only be added to the store if extra processing is required.\n * The functions should be asynchronous as they are part of the reactive chain and called with await.\n *\n * @return {Object}\n */\nfunction createState() {\n\tconst { subscribe, set, update } = writable( [] );\n\n\treturn {\n\t\tsubscribe,\n\t\tset,\n\t\tupdate,\n\t\tasync fetch() {\n\t\t\tconst json = await api.get( \"state\", {} );\n\n\t\t\t// Abort controller is still a bit hit or miss, so we'll go old skool.\n\t\t\tif ( stateFetchIntervalStarted && !stateFetchIntervalPaused ) {\n\t\t\t\tthis.updateState( json );\n\t\t\t}\n\t\t},\n\t\tupdateState( json ) {\n\t\t\tfor ( const callable of get( preStateUpdateCallbacks ) ) {\n\t\t\t\tcallable( json );\n\t\t\t}\n\n\t\t\tconst dirty = get( settings_changed );\n\t\t\tconst previous_settings = { ...get( current_settings ) }; // cloned\n\n\t\t\tconfig.update( $config => {\n\t\t\t\treturn { ...$config, ...json };\n\t\t\t} );\n\n\t\t\t// If the settings weren't changed before, they shouldn't be now.\n\t\t\tif ( !dirty && get( settings_changed ) ) {\n\t\t\t\tsettings.reset();\n\t\t\t}\n\n\t\t\t// If settings are in middle of being changed when changes come in\n\t\t\t// from server, reset to server version.\n\t\t\tif ( dirty && objectsDiffer( [previous_settings, get( current_settings )] ) ) {\n\t\t\t\tneeds_refresh.update( $needs_refresh => true );\n\t\t\t\tsettings.reset();\n\t\t\t}\n\n\t\t\tfor ( const callable of get( postStateUpdateCallbacks ) ) {\n\t\t\t\tcallable( json );\n\t\t\t}\n\t\t},\n\t\tstartPeriodicFetch() {\n\t\t\tstateFetchIntervalStarted = true;\n\t\t\tstateFetchIntervalPaused = false;\n\n\t\t\tstateFetchInterval = setInterval( async () => {\n\t\t\t\tawait this.fetch();\n\t\t\t}, 5000 );\n\t\t},\n\t\tstopPeriodicFetch() {\n\t\t\tstateFetchIntervalStarted = false;\n\t\t\tstateFetchIntervalPaused = false;\n\n\t\t\tclearInterval( stateFetchInterval );\n\t\t},\n\t\tpausePeriodicFetch() {\n\t\t\tif ( stateFetchIntervalStarted ) {\n\t\t\t\tstateFetchIntervalPaused = true;\n\t\t\t\tclearInterval( stateFetchInterval );\n\t\t\t}\n\t\t},\n\t\tresumePeriodicFetch() {\n\t\t\tstateFetchIntervalPaused = false;\n\n\t\t\tif ( stateFetchIntervalStarted ) {\n\t\t\t\tthis.startPeriodicFetch();\n\t\t\t}\n\t\t}\n\t};\n}\n\nexport const state = createState();\n\n// API functions added here to avoid JSHint errors.\napi.headers = () => {\n\treturn {\n\t\t'Accept': 'application/json',\n\t\t'Content-Type': 'application/json',\n\t\t'X-WP-Nonce': get( nonce )\n\t};\n};\n\napi.url = ( endpoint ) => {\n\treturn get( urls ).api + get( endpoints )[ endpoint ];\n};\n\napi.get = async ( endpoint, params ) => {\n\tlet url = new URL( api.url( endpoint ) );\n\n\tconst searchParams = new URLSearchParams( params );\n\n\tsearchParams.forEach( function( value, name ) {\n\t\turl.searchParams.set( name, value );\n\t} );\n\n\tconst response = await fetch( url.toString(), {\n\t\tmethod: 'GET',\n\t\theaders: api.headers()\n\t} );\n\treturn response.json().then( json => {\n\t\tjson = api.check_response( json );\n\t\treturn json;\n\t} );\n};\n\napi.post = async ( endpoint, body ) => {\n\tconst response = await fetch( api.url( endpoint ), {\n\t\tmethod: 'POST',\n\t\theaders: api.headers(),\n\t\tbody: JSON.stringify( body )\n\t} );\n\treturn response.json().then( json => {\n\t\tjson = api.check_response( json );\n\t\treturn json;\n\t} );\n};\n\napi.put = async ( endpoint, body ) => {\n\tconst response = await fetch( api.url( endpoint ), {\n\t\tmethod: 'PUT',\n\t\theaders: api.headers(),\n\t\tbody: JSON.stringify( body )\n\t} );\n\treturn response.json().then( json => {\n\t\tjson = api.check_response( json );\n\t\treturn json;\n\t} );\n};\n\napi.delete = async ( endpoint, body ) => {\n\tconst response = await fetch( api.url( endpoint ), {\n\t\tmethod: 'DELETE',\n\t\theaders: api.headers(),\n\t\tbody: JSON.stringify( body )\n\t} );\n\treturn response.json().then( json => {\n\t\tjson = api.check_response( json );\n\t\treturn json;\n\t} );\n};\n\napi.check_errors = ( json ) => {\n\tif ( json.code && json.message ) {\n\t\tnotifications.add( {\n\t\t\tid: json.code,\n\t\t\ttype: 'error',\n\t\t\tdismissible: true,\n\t\t\theading: get( strings ).api_error_notice_heading,\n\t\t\tmessage: json.message\n\t\t} );\n\n\t\t// Just in case resultant json is expanded into a store.\n\t\tdelete json.code;\n\t\tdelete json.message;\n\t}\n\n\treturn json;\n};\n\napi.check_notifications = ( json ) => {\n\tconst _notifications = json.hasOwnProperty( \"notifications\" ) ? json.notifications : [];\n\tif ( _notifications ) {\n\t\tfor ( const notification of _notifications ) {\n\t\t\tnotifications.add( notification );\n\t\t}\n\t}\n\tnotifications.cleanup( _notifications );\n\n\t// Just in case resultant json is expanded into a store.\n\tdelete json.notifications;\n\n\treturn json;\n};\n\napi.check_response = ( json ) => {\n\tjson = api.check_notifications( json );\n\tjson = api.check_errors( json );\n\n\treturn json;\n};\n","/**\n * @typedef {Object} WrappedComponent Object returned by the `wrap` method\n * @property {SvelteComponent} component - Component to load (this is always asynchronous)\n * @property {RoutePrecondition[]} [conditions] - Route pre-conditions to validate\n * @property {Object} [props] - Optional dictionary of static props\n * @property {Object} [userData] - Optional user data dictionary\n * @property {bool} _sveltesparouter - Internal flag; always set to true\n */\n\n/**\n * @callback AsyncSvelteComponent\n * @returns {Promise} Returns a Promise that resolves with a Svelte component\n */\n\n/**\n * @callback RoutePrecondition\n * @param {RouteDetail} detail - Route detail object\n * @returns {boolean|Promise} If the callback returns a false-y value, it's interpreted as the precondition failed, so it aborts loading the component (and won't process other pre-condition callbacks)\n */\n\n/**\n * @typedef {Object} WrapOptions Options object for the call to `wrap`\n * @property {SvelteComponent} [component] - Svelte component to load (this is incompatible with `asyncComponent`)\n * @property {AsyncSvelteComponent} [asyncComponent] - Function that returns a Promise that fulfills with a Svelte component (e.g. `{asyncComponent: () => import('Foo.svelte')}`)\n * @property {SvelteComponent} [loadingComponent] - Svelte component to be displayed while the async route is loading (as a placeholder); when unset or false-y, no component is shown while component\n * @property {object} [loadingParams] - Optional dictionary passed to the `loadingComponent` component as params (for an exported prop called `params`)\n * @property {object} [userData] - Optional object that will be passed to events such as `routeLoading`, `routeLoaded`, `conditionsFailed`\n * @property {object} [props] - Optional key-value dictionary of static props that will be passed to the component. The props are expanded with {...props}, so the key in the dictionary becomes the name of the prop.\n * @property {RoutePrecondition[]|RoutePrecondition} [conditions] - Route pre-conditions to add, which will be executed in order\n */\n\n/**\n * Wraps a component to enable multiple capabilities:\n * 1. Using dynamically-imported component, with (e.g. `{asyncComponent: () => import('Foo.svelte')}`), which also allows bundlers to do code-splitting.\n * 2. Adding route pre-conditions (e.g. `{conditions: [...]}`)\n * 3. Adding static props that are passed to the component\n * 4. Adding custom userData, which is passed to route events (e.g. route loaded events) or to route pre-conditions (e.g. `{userData: {foo: 'bar}}`)\n * \n * @param {WrapOptions} args - Arguments object\n * @returns {WrappedComponent} Wrapped component\n */\nexport function wrap(args) {\n if (!args) {\n throw Error('Parameter args is required')\n }\n\n // We need to have one and only one of component and asyncComponent\n // This does a \"XNOR\"\n if (!args.component == !args.asyncComponent) {\n throw Error('One and only one of component and asyncComponent is required')\n }\n\n // If the component is not async, wrap it into a function returning a Promise\n if (args.component) {\n args.asyncComponent = () => Promise.resolve(args.component)\n }\n\n // Parameter asyncComponent and each item of conditions must be functions\n if (typeof args.asyncComponent != 'function') {\n throw Error('Parameter asyncComponent must be a function')\n }\n if (args.conditions) {\n // Ensure it's an array\n if (!Array.isArray(args.conditions)) {\n args.conditions = [args.conditions]\n }\n for (let i = 0; i < args.conditions.length; i++) {\n if (!args.conditions[i] || typeof args.conditions[i] != 'function') {\n throw Error('Invalid parameter conditions[' + i + ']')\n }\n }\n }\n\n // Check if we have a placeholder component\n if (args.loadingComponent) {\n args.asyncComponent.loading = args.loadingComponent\n args.asyncComponent.loadingParams = args.loadingParams || undefined\n }\n\n // Returns an object that contains all the functions to execute too\n // The _sveltesparouter flag is to confirm the object was created by this router\n const obj = {\n component: args.asyncComponent,\n userData: args.userData,\n conditions: (args.conditions && args.conditions.length) ? args.conditions : undefined,\n props: (args.props && Object.keys(args.props).length) ? args.props : {},\n _sveltesparouter: true\n }\n\n return obj\n}\n\nexport default wrap\n","import {derived, writable, get} from \"svelte/store\";\nimport {wrap} from \"svelte-spa-router/wrap\";\n\n/**\n * Creates store of default pages.\n *\n * Having a title means inclusion in main tabs.\n *\n * @return {Object}\n */\nfunction createPages() {\n\t// NOTE: get() only resolves after initialization, hence arrow functions for getting titles.\n\tconst { subscribe, set, update } = writable( [] );\n\n\treturn {\n\t\tsubscribe,\n\t\tset,\n\t\tadd( page ) {\n\t\t\tupdate( $pages => {\n\t\t\t\treturn [...$pages, page]\n\t\t\t\t\t.sort( ( a, b ) => {\n\t\t\t\t\t\treturn a.position - b.position;\n\t\t\t\t\t} );\n\t\t\t} );\n\t\t},\n\t\twithPrefix( prefix = null ) {\n\t\t\treturn get( this ).filter( ( page ) => {\n\t\t\t\treturn (prefix && page.route.startsWith( prefix )) || !prefix;\n\t\t\t} );\n\t\t},\n\t\troutes( prefix = null ) {\n\t\t\tlet defaultComponent = null;\n\t\t\tlet defaultUserData = null;\n\t\t\tconst routes = new Map();\n\n\t\t\t// If a page can be enabled/disabled, check whether it is enabled before displaying.\n\t\t\tconst conditions = [\n\t\t\t\t( detail ) => {\n\t\t\t\t\tif (\n\t\t\t\t\t\tdetail.hasOwnProperty( \"userData\" ) &&\n\t\t\t\t\t\tdetail.userData.hasOwnProperty( \"page\" ) &&\n\t\t\t\t\t\tdetail.userData.page.hasOwnProperty( \"enabled\" )\n\t\t\t\t\t) {\n\t\t\t\t\t\treturn detail.userData.page.enabled();\n\t\t\t\t\t}\n\n\t\t\t\t\treturn true;\n\t\t\t\t}\n\t\t\t];\n\n\t\t\tfor ( const page of this.withPrefix( prefix ) ) {\n\t\t\t\tconst userData = { page: page };\n\n\t\t\t\tlet route = page.route;\n\n\t\t\t\tif ( prefix && route !== prefix + \"/*\" ) {\n\t\t\t\t\troute = route.replace( prefix, \"\" );\n\t\t\t\t}\n\n\t\t\t\troutes.set( route, wrap( {\n\t\t\t\t\tcomponent: page.component,\n\t\t\t\t\tuserData: userData,\n\t\t\t\t\tconditions: conditions\n\t\t\t\t} ) );\n\n\t\t\t\tif ( !defaultComponent && page.default ) {\n\t\t\t\t\tdefaultComponent = page.component;\n\t\t\t\t\tdefaultUserData = userData;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif ( defaultComponent ) {\n\t\t\t\troutes.set( \"*\", wrap( {\n\t\t\t\t\tcomponent: defaultComponent,\n\t\t\t\t\tuserData: defaultUserData,\n\t\t\t\t\tconditions: conditions\n\t\t\t\t} ) );\n\t\t\t}\n\n\t\t\treturn routes;\n\t\t},\n\t\thandleRouteEvent( detail ) {\n\t\t\tif ( detail.hasOwnProperty( \"event\" ) ) {\n\t\t\t\tif ( !detail.hasOwnProperty( \"data\" ) ) {\n\t\t\t\t\tdetail.data = {};\n\t\t\t\t}\n\n\t\t\t\t// Find the first page that wants to handle the event\n\t\t\t\t// , but also let other pages see the event\n\t\t\t\t// so they can set any initial state etc.\n\t\t\t\tlet route = false;\n\t\t\t\tfor ( const page of get( this ).values() ) {\n\t\t\t\t\tif ( page.events && page.events[ detail.event ] && page.events[ detail.event ]( detail.data ) && !route ) {\n\t\t\t\t\t\troute = page.route;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif ( route ) {\n\t\t\t\t\treturn route;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif ( detail.hasOwnProperty( \"default\" ) ) {\n\t\t\t\treturn detail.default;\n\t\t\t}\n\n\t\t\treturn false;\n\t\t}\n\t};\n}\n\nexport const pages = createPages();\n\n// Convenience readable store of all routes.\nexport const routes = derived( pages, () => {\n\treturn pages.routes();\n} );","export function parse(str, loose) {\n\tif (str instanceof RegExp) return { keys:false, pattern:str };\n\tvar c, o, tmp, ext, keys=[], pattern='', arr = str.split('/');\n\tarr[0] || arr.shift();\n\n\twhile (tmp = arr.shift()) {\n\t\tc = tmp[0];\n\t\tif (c === '*') {\n\t\t\tkeys.push('wild');\n\t\t\tpattern += '/(.*)';\n\t\t} else if (c === ':') {\n\t\t\to = tmp.indexOf('?', 1);\n\t\t\text = tmp.indexOf('.', 1);\n\t\t\tkeys.push( tmp.substring(1, !!~o ? o : !!~ext ? ext : tmp.length) );\n\t\t\tpattern += !!~o && !~ext ? '(?:/([^/]+?))?' : '/([^/]+?)';\n\t\t\tif (!!~ext) pattern += (!!~o ? '?' : '') + '\\\\' + tmp.substring(ext);\n\t\t} else {\n\t\t\tpattern += '/' + tmp;\n\t\t}\n\t}\n\n\treturn {\n\t\tkeys: keys,\n\t\tpattern: new RegExp('^' + pattern + (loose ? '(?=$|\\/)' : '\\/?$'), 'i')\n\t};\n}\n\nvar RGX = /*#__PURE__*/ /(\\/|^)([:*][^/]*?)(\\?)?(?=[/.]|$)/g;\n\n// error if key missing?\nexport function inject(route, values) {\n\treturn route.replace(RGX, (x, lead, key, optional) => {\n\t\tx = values[key=='*' ? 'wild' : key.substring(1)];\n\t\treturn x ? '/'+x : (optional || key=='*') ? '' : '/' + key;\n\t});\n}\n","\n\n{#if componentParams}\n \n{:else}\n \n{/if}\n\n\n","\n\n
\n\t\n
\n","export { identity as linear } from '../internal/index.mjs';\n\n/*\nAdapted from https://github.com/mattdesl\nDistributed under MIT License https://github.com/mattdesl/eases/blob/master/LICENSE.md\n*/\nfunction backInOut(t) {\n const s = 1.70158 * 1.525;\n if ((t *= 2) < 1)\n return 0.5 * (t * t * ((s + 1) * t - s));\n return 0.5 * ((t -= 2) * t * ((s + 1) * t + s) + 2);\n}\nfunction backIn(t) {\n const s = 1.70158;\n return t * t * ((s + 1) * t - s);\n}\nfunction backOut(t) {\n const s = 1.70158;\n return --t * t * ((s + 1) * t + s) + 1;\n}\nfunction bounceOut(t) {\n const a = 4.0 / 11.0;\n const b = 8.0 / 11.0;\n const c = 9.0 / 10.0;\n const ca = 4356.0 / 361.0;\n const cb = 35442.0 / 1805.0;\n const cc = 16061.0 / 1805.0;\n const t2 = t * t;\n return t < a\n ? 7.5625 * t2\n : t < b\n ? 9.075 * t2 - 9.9 * t + 3.4\n : t < c\n ? ca * t2 - cb * t + cc\n : 10.8 * t * t - 20.52 * t + 10.72;\n}\nfunction bounceInOut(t) {\n return t < 0.5\n ? 0.5 * (1.0 - bounceOut(1.0 - t * 2.0))\n : 0.5 * bounceOut(t * 2.0 - 1.0) + 0.5;\n}\nfunction bounceIn(t) {\n return 1.0 - bounceOut(1.0 - t);\n}\nfunction circInOut(t) {\n if ((t *= 2) < 1)\n return -0.5 * (Math.sqrt(1 - t * t) - 1);\n return 0.5 * (Math.sqrt(1 - (t -= 2) * t) + 1);\n}\nfunction circIn(t) {\n return 1.0 - Math.sqrt(1.0 - t * t);\n}\nfunction circOut(t) {\n return Math.sqrt(1 - --t * t);\n}\nfunction cubicInOut(t) {\n return t < 0.5 ? 4.0 * t * t * t : 0.5 * Math.pow(2.0 * t - 2.0, 3.0) + 1.0;\n}\nfunction cubicIn(t) {\n return t * t * t;\n}\nfunction cubicOut(t) {\n const f = t - 1.0;\n return f * f * f + 1.0;\n}\nfunction elasticInOut(t) {\n return t < 0.5\n ? 0.5 *\n Math.sin(((+13.0 * Math.PI) / 2) * 2.0 * t) *\n Math.pow(2.0, 10.0 * (2.0 * t - 1.0))\n : 0.5 *\n Math.sin(((-13.0 * Math.PI) / 2) * (2.0 * t - 1.0 + 1.0)) *\n Math.pow(2.0, -10.0 * (2.0 * t - 1.0)) +\n 1.0;\n}\nfunction elasticIn(t) {\n return Math.sin((13.0 * t * Math.PI) / 2) * Math.pow(2.0, 10.0 * (t - 1.0));\n}\nfunction elasticOut(t) {\n return (Math.sin((-13.0 * (t + 1.0) * Math.PI) / 2) * Math.pow(2.0, -10.0 * t) + 1.0);\n}\nfunction expoInOut(t) {\n return t === 0.0 || t === 1.0\n ? t\n : t < 0.5\n ? +0.5 * Math.pow(2.0, 20.0 * t - 10.0)\n : -0.5 * Math.pow(2.0, 10.0 - t * 20.0) + 1.0;\n}\nfunction expoIn(t) {\n return t === 0.0 ? t : Math.pow(2.0, 10.0 * (t - 1.0));\n}\nfunction expoOut(t) {\n return t === 1.0 ? t : 1.0 - Math.pow(2.0, -10.0 * t);\n}\nfunction quadInOut(t) {\n t /= 0.5;\n if (t < 1)\n return 0.5 * t * t;\n t--;\n return -0.5 * (t * (t - 2) - 1);\n}\nfunction quadIn(t) {\n return t * t;\n}\nfunction quadOut(t) {\n return -t * (t - 2.0);\n}\nfunction quartInOut(t) {\n return t < 0.5\n ? +8.0 * Math.pow(t, 4.0)\n : -8.0 * Math.pow(t - 1.0, 4.0) + 1.0;\n}\nfunction quartIn(t) {\n return Math.pow(t, 4.0);\n}\nfunction quartOut(t) {\n return Math.pow(t - 1.0, 3.0) * (1.0 - t) + 1.0;\n}\nfunction quintInOut(t) {\n if ((t *= 2) < 1)\n return 0.5 * t * t * t * t * t;\n return 0.5 * ((t -= 2) * t * t * t * t + 2);\n}\nfunction quintIn(t) {\n return t * t * t * t * t;\n}\nfunction quintOut(t) {\n return --t * t * t * t * t + 1;\n}\nfunction sineInOut(t) {\n return -0.5 * (Math.cos(Math.PI * t) - 1);\n}\nfunction sineIn(t) {\n const v = Math.cos(t * Math.PI * 0.5);\n if (Math.abs(v) < 1e-14)\n return 1;\n else\n return 1 - v;\n}\nfunction sineOut(t) {\n return Math.sin((t * Math.PI) / 2);\n}\n\nexport { backIn, backInOut, backOut, bounceIn, bounceInOut, bounceOut, circIn, circInOut, circOut, cubicIn, cubicInOut, cubicOut, elasticIn, elasticInOut, elasticOut, expoIn, expoInOut, expoOut, quadIn, quadInOut, quadOut, quartIn, quartInOut, quartOut, quintIn, quintInOut, quintOut, sineIn, sineInOut, sineOut };\n","import { cubicInOut, linear, cubicOut } from '../easing/index.mjs';\nimport { is_function, assign } from '../internal/index.mjs';\n\n/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n\r\nfunction __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\n\nfunction blur(node, { delay = 0, duration = 400, easing = cubicInOut, amount = 5, opacity = 0 } = {}) {\n const style = getComputedStyle(node);\n const target_opacity = +style.opacity;\n const f = style.filter === 'none' ? '' : style.filter;\n const od = target_opacity * (1 - opacity);\n return {\n delay,\n duration,\n easing,\n css: (_t, u) => `opacity: ${target_opacity - (od * u)}; filter: ${f} blur(${u * amount}px);`\n };\n}\nfunction fade(node, { delay = 0, duration = 400, easing = linear } = {}) {\n const o = +getComputedStyle(node).opacity;\n return {\n delay,\n duration,\n easing,\n css: t => `opacity: ${t * o}`\n };\n}\nfunction fly(node, { delay = 0, duration = 400, easing = cubicOut, x = 0, y = 0, opacity = 0 } = {}) {\n const style = getComputedStyle(node);\n const target_opacity = +style.opacity;\n const transform = style.transform === 'none' ? '' : style.transform;\n const od = target_opacity * (1 - opacity);\n return {\n delay,\n duration,\n easing,\n css: (t, u) => `\n\t\t\ttransform: ${transform} translate(${(1 - t) * x}px, ${(1 - t) * y}px);\n\t\t\topacity: ${target_opacity - (od * u)}`\n };\n}\nfunction slide(node, { delay = 0, duration = 400, easing = cubicOut } = {}) {\n const style = getComputedStyle(node);\n const opacity = +style.opacity;\n const height = parseFloat(style.height);\n const padding_top = parseFloat(style.paddingTop);\n const padding_bottom = parseFloat(style.paddingBottom);\n const margin_top = parseFloat(style.marginTop);\n const margin_bottom = parseFloat(style.marginBottom);\n const border_top_width = parseFloat(style.borderTopWidth);\n const border_bottom_width = parseFloat(style.borderBottomWidth);\n return {\n delay,\n duration,\n easing,\n css: t => 'overflow: hidden;' +\n `opacity: ${Math.min(t * 20, 1) * opacity};` +\n `height: ${t * height}px;` +\n `padding-top: ${t * padding_top}px;` +\n `padding-bottom: ${t * padding_bottom}px;` +\n `margin-top: ${t * margin_top}px;` +\n `margin-bottom: ${t * margin_bottom}px;` +\n `border-top-width: ${t * border_top_width}px;` +\n `border-bottom-width: ${t * border_bottom_width}px;`\n };\n}\nfunction scale(node, { delay = 0, duration = 400, easing = cubicOut, start = 0, opacity = 0 } = {}) {\n const style = getComputedStyle(node);\n const target_opacity = +style.opacity;\n const transform = style.transform === 'none' ? '' : style.transform;\n const sd = 1 - start;\n const od = target_opacity * (1 - opacity);\n return {\n delay,\n duration,\n easing,\n css: (_t, u) => `\n\t\t\ttransform: ${transform} scale(${1 - (sd * u)});\n\t\t\topacity: ${target_opacity - (od * u)}\n\t\t`\n };\n}\nfunction draw(node, { delay = 0, speed, duration, easing = cubicInOut } = {}) {\n let len = node.getTotalLength();\n const style = getComputedStyle(node);\n if (style.strokeLinecap !== 'butt') {\n len += parseInt(style.strokeWidth);\n }\n if (duration === undefined) {\n if (speed === undefined) {\n duration = 800;\n }\n else {\n duration = len / speed;\n }\n }\n else if (typeof duration === 'function') {\n duration = duration(len);\n }\n return {\n delay,\n duration,\n easing,\n css: (t, u) => `stroke-dasharray: ${t * len} ${u * len}`\n };\n}\nfunction crossfade(_a) {\n var { fallback } = _a, defaults = __rest(_a, [\"fallback\"]);\n const to_receive = new Map();\n const to_send = new Map();\n function crossfade(from, node, params) {\n const { delay = 0, duration = d => Math.sqrt(d) * 30, easing = cubicOut } = assign(assign({}, defaults), params);\n const to = node.getBoundingClientRect();\n const dx = from.left - to.left;\n const dy = from.top - to.top;\n const dw = from.width / to.width;\n const dh = from.height / to.height;\n const d = Math.sqrt(dx * dx + dy * dy);\n const style = getComputedStyle(node);\n const transform = style.transform === 'none' ? '' : style.transform;\n const opacity = +style.opacity;\n return {\n delay,\n duration: is_function(duration) ? duration(d) : duration,\n easing,\n css: (t, u) => `\n\t\t\t\topacity: ${t * opacity};\n\t\t\t\ttransform-origin: top left;\n\t\t\t\ttransform: ${transform} translate(${u * dx}px,${u * dy}px) scale(${t + (1 - t) * dw}, ${t + (1 - t) * dh});\n\t\t\t`\n };\n }\n function transition(items, counterparts, intro) {\n return (node, params) => {\n items.set(params.key, {\n rect: node.getBoundingClientRect()\n });\n return () => {\n if (counterparts.has(params.key)) {\n const { rect } = counterparts.get(params.key);\n counterparts.delete(params.key);\n return crossfade(rect, node, params);\n }\n // if the node is disappearing altogether\n // (i.e. wasn't claimed by the other list)\n // then we need to supply an outro\n items.delete(params.key);\n return fallback && fallback(node, params, intro);\n };\n };\n }\n return [\n transition(to_send, to_receive, false),\n transition(to_receive, to_send, true)\n ];\n}\n\nexport { blur, crossfade, draw, fade, fly, scale, slide };\n","\n\n\n\t
\n\t\t{#if iconURL}\n\t\t\t
\n\t\t\t\t\"{notification.type}\n\t\t\t
\n\t\t{/if}\n\t\t
\n\t\t\t{#if heading || dismissible || expandable}\n\t\t\t\t
\n\t\t\t\t\t{#if heading}\n\t\t\t\t\t\t{#if plainHeading}\n\t\t\t\t\t\t\t

{@html heading}

\n\t\t\t\t\t\t{:else}\n\t\t\t\t\t\t\t

{@html heading}

\n\t\t\t\t\t\t{/if}\n\t\t\t\t\t{/if}\n\t\t\t\t\t{#if dismissible && expandable}\n\t\t\t\t\t\t\n\t\t\t\t\t\t\n\t\t\t\t\t{:else if expandable}\n\t\t\t\t\t\t\n\t\t\t\t\t{:else if dismissible}\n\t\t\t\t\t\t\n\t\t\t\t\t{/if}\n\t\t\t\t
\n\t\t\t{/if}\n\t\t\t\n\t\t\t{#if extra}\n\t\t\t\t

{@html extra}

\n\t\t\t{/if}\n\t\t\t{#if linksHTML}\n\t\t\t\t

{@html linksHTML}

\n\t\t\t{/if}\n\t\t
\n\t
\n\t\n\n","\n\n{#if $notifications.length}\n\t
\n\t\t{#each $notifications as notification (notification.render_key)}\n\t\t\t{#if !notification.dismissed && (notification.only_show_on_tab === tab || notification.only_show_on_tab === tabParent || !notification.only_show_on_tab)}\n\t\t\t\t\n\t\t\t\t\t{#if notification.message}\n\t\t\t\t\t\t

{@html notification.message}

\n\t\t\t\t\t{/if}\n\t\t\t\t
\n\t\t\t{/if}\n\t\t{/each}\n\t
\n{/if}\n","\n\n{#if $bapa && !$delivery_provider.block_public_access_supported}\n\t\n\t\t

{@html $storage_provider.block_public_access_warning.message}

\n\t
\n{/if}\n","\n\n{#if $ooe && !$delivery_provider.object_ownership_supported}\n\t\n\t\t

{@html $storage_provider.object_ownership_enforced_warning.message}

\n\t
\n{/if}\n","\n\n
  • \n\t focus = true}\n\t\ton:focusout={() => focus = false}\n\t\ton:mouseenter={() => hover = true}\n\t\ton:mouseleave={() => hover = false}\n\t>\n\t\t{page.title()}\n\t\n
  • \n","\n\n{#if displayItems}\n\t
      \n\t\t{#each displayItems as page, index}\n\t\t\t\n\t\t\t\n\t\t\t{#if progress && index < (displayItems.length - 1)}\n\t\t\t\t
    • \n\t\t\t\t\t\"\"\n\t\t\t\t
    • \n\t\t\t{/if}\n\t\t{/each}\n\t
    \n{/if}\n","\n\n{#if routes}\n\t
    \n\t\t\n\t\t\n\t\t\t\n\t\t\n\t
    \n{/if}","import {parse} from 'regexparam'\nimport {loc} from './Router.svelte'\n\n// List of nodes to update\nconst nodes = []\n\n// Current location\nlet location\n\n// Function that updates all nodes marking the active ones\nfunction checkActive(el) {\n const matchesLocation = el.pattern.test(location)\n toggleClasses(el, el.className, matchesLocation)\n toggleClasses(el, el.inactiveClassName, !matchesLocation)\n}\n\nfunction toggleClasses(el, className, shouldAdd) {\n (className || '').split(' ').forEach((cls) => {\n if (!cls) {\n return\n }\n // Remove the class firsts\n el.node.classList.remove(cls)\n\n // If the pattern doesn't match, then set the class\n if (shouldAdd) {\n el.node.classList.add(cls)\n }\n })\n}\n\n// Listen to changes in the location\nloc.subscribe((value) => {\n // Update the location\n location = value.location + (value.querystring ? '?' + value.querystring : '')\n\n // Update all nodes\n nodes.map(checkActive)\n})\n\n/**\n * @typedef {Object} ActiveOptions\n * @property {string|RegExp} [path] - Path expression that makes the link active when matched (must start with '/' or '*'); default is the link's href\n * @property {string} [className] - CSS class to apply to the element when active; default value is \"active\"\n */\n\n/**\n * Svelte Action for automatically adding the \"active\" class to elements (links, or any other DOM element) when the current location matches a certain path.\n * \n * @param {HTMLElement} node - The target node (automatically set by Svelte)\n * @param {ActiveOptions|string|RegExp} [opts] - Can be an object of type ActiveOptions, or a string (or regular expressions) representing ActiveOptions.path.\n * @returns {{destroy: function(): void}} Destroy function\n */\nexport default function active(node, opts) {\n // Check options\n if (opts && (typeof opts == 'string' || (typeof opts == 'object' && opts instanceof RegExp))) {\n // Interpret strings and regular expressions as opts.path\n opts = {\n path: opts\n }\n }\n else {\n // Ensure opts is a dictionary\n opts = opts || {}\n }\n\n // Path defaults to link target\n if (!opts.path && node.hasAttribute('href')) {\n opts.path = node.getAttribute('href')\n if (opts.path && opts.path.length > 1 && opts.path.charAt(0) == '#') {\n opts.path = opts.path.substring(1)\n }\n }\n\n // Default class name\n if (!opts.className) {\n opts.className = 'active'\n }\n\n // If path is a string, it must start with '/' or '*'\n if (!opts.path || \n typeof opts.path == 'string' && (opts.path.length < 1 || (opts.path.charAt(0) != '/' && opts.path.charAt(0) != '*'))\n ) {\n throw Error('Invalid value for \"path\" argument')\n }\n\n // If path is not a regular expression already, make it\n const {pattern} = typeof opts.path == 'string' ?\n parse(opts.path) :\n {pattern: opts.path}\n\n // Add the node to the list\n const el = {\n node,\n className: opts.className,\n inactiveClassName: opts.inactiveClassName,\n pattern\n }\n nodes.push(el)\n\n // Trigger the action right away\n checkActive(el)\n\n return {\n // When the element is destroyed, remove it from the list\n destroy() {\n nodes.splice(nodes.indexOf(el), 1)\n }\n }\n}\n","\n\n
    \n\t\n
    \n","\n\n
    \n\t\n
    \n","\n\n
    \n\t{#if gradient}\n\t\t
    \n\t{/if}\n\t\n
    \n\n\n","\n\n{#if defined}\n\t

    {$strings.defined_in_wp_config}

    \n{/if}","\n\n
    \n\t\n\t\n
    ","\n\n{#if url}\n\t\n\t\t\n\t\n{/if}\n","\n\n
    \n\t{#if !multi && heading}\n\t\t
    \n\t\t\t

    {heading}

    \n\t\t\t{#if helpURL}\n\t\t\t\t\n\t\t\t{:else if helpKey}\n\t\t\t\t\n\t\t\t{/if}\n\t\t\t\n\t\t
    \n\t{/if}\n\t\n\t\t{#if multi && heading}\n\t\t\t\n\t\t\t\t{#if toggleName}\n\t\t\t\t\t\n\t\t\t\t\t\t{heading}\n\t\t\t\t\t\n\t\t\t\t\t

    {heading}

    \n\t\t\t\t{:else}\n\t\t\t\t\t

    {heading}

    \n\t\t\t\t{/if}\n\t\t\t\t\n\t\t\t\t{#if storageProvider}\n\t\t\t\t\t\n\t\t\t\t{/if}\n\t\t\t\t{#if helpURL}\n\t\t\t\t\t\n\t\t\t\t{:else if helpKey}\n\t\t\t\t\t\n\t\t\t\t{/if}\n\t\t\t
    \n\t\t{/if}\n\n\t\t\n\t
    \n
    \n\n\n","\n\n\n\t\n\n","\n\n\n\t{$storage_provider.provider_service_name}/\n\t
    \n\t\t

    {$storage_provider.provider_service_name}

    \n\t\t

    \n\t\t\t{$settings.bucket}\n\t\t\t{$region_name}\n\t\t

    \n\t
    \n\t\n
    \n\n\n","\n\n{#if $settings_notifications.has( settingKey )}\n\t{#each [...$settings_notifications.get( settingKey ).values()].sort( compareNotificationTypes ) as notification (notification)}\n\t\t\n\t\t\t

    {@html notification.message}

    \n\t\t
    \n\t{/each}\n{/if}\n","\n\n
    \n\t\n\t\t{#if toggleName}\n\t\t\t\n\t\t\t\t{heading}\n\t\t\t\n\t\t\t

    {heading}

    \n\t\t{:else}\n\t\t\t

    {heading}

    \n\t\t{/if}\n\t\t\n\t
    \n\t\n\t\t

    {@html description}

    \n\t
    \n\t{#if input}\n\t\t\n\t\t\t\n\t\t\t\n\t\t\n\t\t{#if validationError}\n\t\t\t

    {validationError}

    \n\t\t{/if}\n\t{/if}\n\n\t{#if toggleName}\n\t\t\n\t{/if}\n\n\t{#if textName}\n\t\t\n\t{/if}\n\n\t\n
    \n\n\n","\n\n\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\n","\n\n\n\t{$delivery_provider.provider_service_name}/\n\t
    \n\t\t

    {$delivery_provider.provider_service_name}

    \n\t\t

    \n\t\t\t{$delivery_provider.console_title}\n\t\t

    \n\t
    \n\t\n
    \n\n\n","\n\n\n\t\n\t\n\n\t{#if $delivery_provider.delivery_domain_allowed}\n\t\t\n\t\t{#if $delivery_provider.use_signed_urls_key_file_allowed && $settings[ \"enable-delivery-domain\" ]}\n\t\t\t\n\t\t\t\t\n\t\t\t\t{#if $settings[ \"enable-signed-urls\" ]}\n\t\t\t\t\t\n\n\t\t\t\t\t\n\n\t\t\t\t\t\n\t\t\t\t{/if}\n\t\t\t\n\t\t{/if}\n\t{/if}\n\n\t\n\n","\n\n\n","\n\n{#if parts.length > 0}\n\t\n\t\t\n\t\t\t

    {$strings.url_preview_desc}

    \n\t\t
    \n\t\t\n\t\t\t
    \n\t\t\t\t{#each parts as part (part.title)}\n\t\t\t\t\t
    \n\t\t\t\t\t\t
    {part.title}
    \n\t\t\t\t\t\t
    {part.example}
    \n\t\t\t\t\t
    \n\t\t\t\t{/each}\n\t\t\t
    \n\t\t
    \n\t
    \n{/if}\n","/**\n * Scrolls the notifications into view.\n */\nexport function scrollNotificationsIntoView() {\n\tconst element = document.getElementById( \"notifications\" );\n\n\tif ( element ) {\n\t\telement.scrollIntoView( { behavior: \"smooth\", block: \"start\" } );\n\t}\n}\n","\n\n{#if $settingsChangedStore}\n\t
    \n\t\t
    \n\t\t\t\n\t\t\t\n\t\t
    \n\t
    \n{/if}\n","\n\n\n\t\n\t
    \n\t\t\n\t\t\n\t
    \n\t\n\t\n\t\n
    \n\n{#if sidebar}\n\t\n{/if}\n\n